@charset "UTF-8";
/*
Theme Name: Studendorm v2
Theme URI: https://studendorm.com
Description:
2023.6.27 初版
2023.9.28 簡単な調整
2024.1.23 簡単な調整
2024.1.24 物件ページ
2024.1.25 物件一覧仮
2024.1.28 フロントページ・都市・大学追加
2024.1.31 検索結果ページスタイル
2024.2.4 色々
2024.2.16 shutto言語切り替え
2024.2.29 再設計
2024.3.3 タブレット対応
2024.3.8 間取り月表示されないのを修正
2024.3.14 WeChatコードの追加
2024.3.19 GAタグ削除
2024.5.1 言語切り替えにリダイレクト処理を追加
2024.5.28 Shuttoのキャッシュサーバーに対応（動画とスライドショーのだし分け）
2024.5.31 設備アイコン不具合修正
2024.6.30 物件詳細表記変更
2024.8.28 物件詳細表記修正
2024.9.4 物件詳細表記修正（言語ごとの賃料表示対応）
2024.10.5 共用コインランドリー表示修正・共用シャワー追加
2024.10.18 アナリティクスコード読み込みスクリプト
2024.11.5 Baidu所有権確認コード追加
2024.11.11 物件詳細・暫定処理でDB内のシャワーとバスルームを出力時に統合
2024.11.22 Google Tagマネージャー追加
2024.11.26 フォームからGTMにカスタムイベントを送信。を追加。
2024.12.5 物件詳細、公共料⾦＆⾷費の表示方法変更。
2024.12.6 物件詳細、公共料⾦＆⾷費の表示方法変更。
2024.12.7 物件詳細、設備とルールのACF値変更。Singleの表示方法変更。共用設備の追加（空調設備・バルコニー）
2024.12.11 wpcf7に現在のURLを取得するコードを追加。
2024.12.20 共用設備から空調設備を削除。
2024.12.25 問い合わせフォームのクエリパラメータをjavascriptで取得する方法に変更。
2025.1.9 Mapbox仕様変更に伴い人気の大学を一時非表示
2025.1.18 フォームにreCAPTCHAと文言、バッジを消すCSS追加。
2025.2.13 人気の都市、人気の大学の出力方法を変更
2025.2.26 問い合わせフォームに性別欄を追加。
2025.2.27 物件リストの表示調整。
2025.3.23 サインアップページにreCAPTCHA v3導入。
2025.6.17 サブドメイン切り替えのために一時的にドロップダウンでサブドメイン切り替えを無効化。
2025.6.18 サブドメイン切り替えのために、ドロップダウン・Access-Control-Allow-Originヘッダ修正。
2025.6.29 hreflangの出力修正。
2025.7.4 問い合わせフォームの調整。
2025.7.22 問い合わせフォームの調整。
2025.7.23 問い合わせフォームに送信元の言語を追記。
2025.9.15 テスト用テンプレを追加 page-test.php
2025.9.19 v2として2024とは別テーマに変更
2025.10.3 リリース。お問合せリストモバイル版調整。
2025.10.16 404ページGitでShutto/ナビを非表示に調整。
2025.10.23 フロントページ：ヒーロー動画をACF依存からテーマ内固定ファイル参照へ変更（poster/playsinline/preload=metadata 追加、WebM/MP4 並列指定）。
2025.10.23 app-front-page.jsでヒーロー動画のsrc自動代入を条件付きに変更し、SPスライダー初期化を最適化。
2025.10.23 ヘッダーのロゴ切替とモバイルメニュー（nav-btn）カラー／トランジション調整。
2025.10.23 モバイルナビの高さ・スクロール制御を改善（100dvh／html固定）。
2025.10.24 モバイルナビ開閉時の高さとヘッダー重なりを調整。
2025.10.24 モバイルナビ下部の余白調整。
2025.10.24 モバイルナビ下部スペースを拡張し、ドロップダウン全体を表示。
2025.10.24 404ページで正しくHTTP 404ステータスを返すよう修正（外部挙動変更のためマイナーバージョン更新）。
2025.10.24 404ページが200を返すケースに対応（WPクエリ強制404／HTTPレスポンスコード明示）。
2025.10.24 404ページでナビボタン未出力時のJSエラーを回避。
2025.10.24 モバイルナビ開閉時に背景スクロールをロック。
2025.10.29 物件詳細の設備表記を「ベッド」に統一。

Author: tankdesign
Author URI: https://tankdesign.jp
Version: 3.2.4
*/
/* Box sizing rules */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
html,
body {
  -webkit-font-smoothing: antialiased !important;
}

body {
  background-color: #ffffff;
  color: #333333;
  font-size: 15px;
  line-height: 1.6em;
  font-family: sans-serif;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  word-break: break-all;
  position: relative;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 13px;
  }
}

a {
  text-decoration: none;
  color: #fc6635;
}
p {
  line-height: 1.6em;
}

b {
  font-weight: 700;
}

ul {
  line-height: 1.8em;
}

footer {
  border-bottom: 10px solid #ffffff;
}
footer .footer-inner .footer-info {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 940px;
  margin: 0 auto;
  padding: 60px 0;
}
@media screen and (max-width: 960px) {
  footer .footer-inner .footer-info {
    width: calc(100% - 20px);
    margin: 0 auto;
    padding: 30px 0;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (max-width: 768px) {
  footer .footer-inner .footer-info {
    width: 100%;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
footer .footer-inner .footer-info .footer-logo {
  width: 300px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 960px) {
  footer .footer-inner .footer-info .footer-logo {
    width: 200px;
  }
}
footer .footer-inner .footer-info .footer-logo img {
  width: 300px;
  height: 28px;
}
@media screen and (max-width: 768px) {
  footer .footer-inner .footer-info .footer-logo img {
    width: 200px;
    height: auto;
  }
}
footer .footer-inner .footer-info .footer-menu {
  width: 640px;
}
@media screen and (max-width: 960px) {
  footer .footer-inner .footer-info .footer-menu {
    width: calc(100% - 220px);
  }
}
@media screen and (max-width: 768px) {
  footer .footer-inner .footer-info .footer-menu {
    display: none;
  }
}
footer .footer-inner .footer-info .footer-menu .footer-nav {
  font-size: 14px;
}
footer .footer-inner .footer-info .footer-menu .footer-nav ul {
  list-style: none;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
footer .footer-inner .footer-info .footer-menu .footer-nav ul li {
  padding: 5px 10px;
}
footer .footer-inner .footer-copy {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 130px;
  color: #ffffff;
  background-color: #fc6635;
}
@media screen and (max-width: 768px) {
  footer .footer-inner .footer-copy {
    height: 80px;
  }
}
footer .footer-inner .footer-copy address {
  font-style: normal;
}
@media screen and (max-width: 768px) {
  footer .footer-inner .footer-copy address {
    font-size: 12px;
  }
}
footer .footer-inner .footer-copy address a {
  color: #ffffff;
}
footer .footer-inner .footer-copy .small {
  font-size: 12px;
  position: absolute;
  right: 10px;
  bottom: 5px;
  color: #ffaf94;
}
@media screen and (max-width: 768px) {
  footer .footer-inner .footer-copy .small {
    font-size: 10px;
  }
}

html.is-scroll-locked,
body.is-scroll-locked {
  overflow: hidden;
}

body.is-scroll-locked {
  position: fixed;
  width: 100%;
}

header {
  position: relative;
  z-index: 1000;
}
header.header-front .header-inner {
  position: absolute;
}
header.header-front .header-inner .header-logo img {
  -webkit-filter: none;
          filter: none;
}
header.header-front .header-inner .header-logo img:not(.is-dropdown-open):not(.is-nav-open) {
  -webkit-filter: drop-shadow(0 2px 5px rgba(127, 56, 33, 0.25));
          filter: drop-shadow(0 2px 5px rgba(127, 56, 33, 0.25));
}
header.header-front .header-inner .header-nav ul li.btn-border {
  position: relative;
  z-index: 1;
  background-color: transparent;
  border: 1px solid #fff;
  -webkit-filter: drop-shadow(0 2px 3px rgba(72, 34, 21, 0.35));
          filter: drop-shadow(0 2px 3px rgba(72, 34, 21, 0.35));
  color: #fff;
}
header.header-front .header-inner .header-nav ul li.btn-border a {
  color: #fff;
}
header.header-front .header-inner .header-nav ul li.btn-border a i {
  color: #fff;
}
header.header-front .header-inner .header-nav ul li.btn-border.has-items {
  border: none;
  background-color: #fc6635;
  color: #fff;
}
header.header-front .header-inner .header-nav ul li.btn-border.has-items a {
  color: #fff;
}
header.header-front .header-inner .header-nav ul li.btn-border.has-items a i {
  color: #fff;
}

.header-inner {
  width: 80%;
  height: 130px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  padding: 0;
  z-index: 1000;
}
@media screen and (max-width: 960px) {
  .header-inner {
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  .header-inner {
    width: 100%;
    height: 80px;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.header-logo {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 1101;
}
@media screen and (max-width: 768px) {
  .header-logo {
    margin-right: 15px;
  }
}
.header-logo img {
  width: 300px;
  height: 28px;
  opacity: 1;
  -webkit-filter: none;
          filter: none;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
@media screen and (max-width: 768px) {
  .header-logo img {
    width: 220px;
    height: auto;
  }
}
.header-logo img.is-switching {
  opacity: 0;
}
.header-logo img.is-dropdown-open, .header-logo img.is-nav-open {
  -webkit-filter: none;
          filter: none;
  -webkit-transition: opacity 0.3s ease, -webkit-filter 0.3s ease;
  transition: opacity 0.3s ease, -webkit-filter 0.3s ease;
  transition: opacity 0.3s ease, filter 0.3s ease;
  transition: opacity 0.3s ease, filter 0.3s ease, -webkit-filter 0.3s ease;
}

.header-nav {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .header-nav {
    display: none;
  }
}
.header-nav ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  padding: 0;
}
.header-nav ul li.header-button.white-border {
  border: 1px solid #999999;
  -webkit-filter: none;
          filter: none;
}
.header-nav ul li.header-button.white-border a {
  color: #999999;
}

#nav-btn-check {
  display: none;
  visibility: hidden;
}

.nav-btn {
  font-size: 40px;
  color: #fc6635;
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 1001;
  display: none;
  -webkit-transition: none;
  transition: none;
}
@media screen and (max-width: 768px) {
  .nav-btn {
    display: block;
  }
}
.nav-btn.is-open {
  color: #fc6635;
  -webkit-filter: none;
          filter: none;
  -webkit-transition: color 0.3s ease, -webkit-filter 0.3s ease;
  transition: color 0.3s ease, -webkit-filter 0.3s ease;
  transition: color 0.3s ease, filter 0.3s ease;
  transition: color 0.3s ease, filter 0.3s ease, -webkit-filter 0.3s ease;
}
.nav-btn.is-open i::before {
  -webkit-filter: none;
          filter: none;
  -webkit-transition: -webkit-filter 0.3s ease;
  transition: -webkit-filter 0.3s ease;
  transition: filter 0.3s ease;
  transition: filter 0.3s ease, -webkit-filter 0.3s ease;
}

.header-front .nav-btn {
  color: #fff;
}
.header-front .nav-btn i::before {
  -webkit-filter: drop-shadow(0 2px 5px rgba(127, 56, 33, 0.45));
          filter: drop-shadow(0 2px 5px rgba(127, 56, 33, 0.45));
}
.header-front .nav-btn.is-open {
  color: #fc6635;
}
.header-front .nav-btn.is-open i::before {
  -webkit-filter: none;
          filter: none;
  -webkit-transition: -webkit-filter 0.3s ease;
  transition: -webkit-filter 0.3s ease;
  transition: filter 0.3s ease;
  transition: filter 0.3s ease, -webkit-filter 0.3s ease;
}

.mobile-nav {
  display: none;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  width: 100%;
  height: 100dvh;
  min-height: 100vh;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  padding: 80px 20px 120px;
  padding: calc(80px + env(safe-area-inset-top)) 20px calc(120px + env(safe-area-inset-bottom));
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: #ffffff;
  z-index: 1000;
  overflow-y: auto;
}
@media screen and (max-width: 768px) {
  .mobile-nav.is-show {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-animation: mobileMenu 0.3s cubic-bezier(0.23, 1, 0.32, 1) 0s 1 normal forwards;
            animation: mobileMenu 0.3s cubic-bezier(0.23, 1, 0.32, 1) 0s 1 normal forwards;
  }
}
.mobile-nav ul {
  width: 100%;
  padding: 0;
  margin: 0;
  list-style-type: none;
  font-size: 15px;
  line-height: 1.4em;
  text-align: center;
}
.mobile-nav ul li {
  padding: 5px 0;
}
.mobile-nav ul li a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.mobile-nav ul li a i {
  font-size: 18px;
  margin-right: 5px;
}

/* お問合せリストボタン */
.btn-contactlist {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  line-height: 15px;
  border-radius: 3px;
  margin: 10px;
  padding: 5px !important;
  color: #fff;
  font-size: 14px;
  border: none;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .btn-contactlist {
    margin: 20px 10px 10px !important;
  }
}
.btn-contactlist a i {
  font-size: 32px !important;
  margin-right: 0;
  color: #999999;
}
@media screen and (max-width: 768px) {
  .btn-contactlist a i {
    margin: 0 !important;
  }
}

/* ドロップダウン内容 */
.dropdown {
  position: relative;
  display: block;
}
@media screen and (max-width: 768px) {
  .dropdown {
    display: none;
  }
}

.dropdown-mobile {
  position: relative;
  display: block;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0 !important;
}
/* ドロップダウンボタン */
.btn-drop {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  width: 120px !important;
  border: none;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .btn-drop {
    width: 140px !important;
    height: auto !important;
    padding: 10px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.btn-drop i {
  font-size: 32px;
}

.btn-text {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding-left: 15px;
}
@media screen and (max-width: 768px) {
  .btn-text {
    padding-left: 10px;
  }
}
.btn-text i {
  margin-left: 5px;
  font-size: 10px;
}

/* ドロップダウンメニュー */
.dropdown-content {
  display: none;
  position: absolute;
  width: calc(100% + 20px);
  border-radius: 3px;
  left: 50%;
  top: 32px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background-color: #ffffff;
  -webkit-box-shadow: 0px 2px 5px rgba(127, 56, 33, 0.25);
          box-shadow: 0px 2px 5px rgba(127, 56, 33, 0.25);
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .dropdown-content {
    width: calc(50% + 20px);
    top: -50%;
  }
}
.dropdown-content.is-show {
  display: block;
  -webkit-animation: popUp 0.3s cubic-bezier(0.23, 1, 0.32, 1) 0s 1 normal forwards;
          animation: popUp 0.3s cubic-bezier(0.23, 1, 0.32, 1) 0s 1 normal forwards;
}

/* ドロップダウンメニューのリンク */
.dropdown-content a {
  color: black;
  padding: 7px 10px;
  font-size: 12px;
  line-height: 1.2em;
  text-align: center;
  text-decoration: none;
  display: block;
}

/* ドロップダウンメニューのリンク（マウスオーバー時） */
.dropdown-content a:hover {
  background-color: #f2f2f2;
}

/* ドロップダウン表示時 */
/* アクティブなリンク */
.dropdown-content a.active {
  background-color: #fc6635;
  color: #ffffff;
  font-weight: 700;
}

.btn {
  display: inline-block;
  border-radius: 3px;
}

.btn-theme {
  color: #ffffff;
  background-color: #fc6635;
  padding: 5px 20px;
}
@media screen and (max-width: 768px) {
  .btn-theme {
    padding: 5px 10px;
  }
}

.btn-white {
  color: #fc6635;
  background-color: #ffffff;
  padding: 5px 20px;
}

.btn-border {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  line-height: 15px;
  border-radius: 3px;
  margin: 0 10px;
  width: 120px;
  height: 72px;
  border: 1px solid #999999;
}
@media screen and (max-width: 768px) {
  .btn-border {
    width: 140px;
  }
}
.btn-border a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  font-weight: 700;
  width: 100%;
  height: 100%;
  color: #999999;
}
.btn-border a i {
  display: block;
  font-size: 32px;
}

.btn-fill {
  line-height: 15px;
  border-radius: 3px;
  margin: 0 10px;
  width: 72px;
  height: 72px;
  background-color: #fc6635;
  color: #ffffff;
}
.btn-fill a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  font-weight: 700;
  width: 100%;
  height: 100%;
  color: #ffffff;
}
.btn-fill a i {
  display: block;
  font-size: 32px;
}

.btn-contact,
.btn-more {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 60px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .btn-contact,
  .btn-more {
    width: calc(100% - 20px);
    margin: 0 auto !important;
  }
}
.btn-contact i,
.btn-more i {
  font-size: 22px;
  margin-right: 5px;
}
.btn-contact.about,
.btn-more.about {
  width: 50%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .btn-contact.about,
  .btn-more.about {
    width: 100%;
  }
}

.btn-more {
  border: 1px solid #fc6635;
  margin: 0 !important;
}
@media screen and (max-width: 768px) {
  .btn-more {
    margin: 0 auto !important;
  }
}

.hidden {
  display: none;
}
.hidden table {
  width: 60%;
  margin: 50px auto;
  border-collapse: collapse;
}
.hidden table tbody tr th,
.hidden table tbody tr td {
  border: 1px solid #ccc;
  padding: 5px;
}
.hidden table tbody tr th {
  width: 40%;
  text-align: left;
}
.hidden table tbody tr td {
  width: 60%;
}

.lSSlideOuter .lSSlideWrapper ul.lightSlider {
  list-style-type: none;
}
.lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide {
  width: 620px;
  height: 465px;
}
@media screen and (max-width: 768px) {
  .lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide {
    width: 96%;
    height: auto;
    aspect-ratio: 1/1;
  }
}
.lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide img {
  width: 620px;
  height: 465px;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 768px) {
  .lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide img {
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
  }
}
.lSSlideOuter .lSSlideWrapper .lSAction a {
  background-image: url("assets/images/LScontrols.svg");
}
.lSSlideOuter .lSSlideWrapper .lSAction .lSPrev {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
.lSSlideOuter ul.lSPager {
  list-style-type: none;
}
.lSSlideOuter ul.lSPager li {
  border-radius: 3px !important;
  width: 150px;
  height: 150px;
}
@media screen and (max-width: 960px) {
  .lSSlideOuter ul.lSPager li {
    width: calc((100% - 60px) / 4);
    height: auto;
    aspect-ratio: 1/1;
  }
}
.lSSlideOuter ul.lSPager li.active a {
  opacity: 1;
}
.lSSlideOuter ul.lSPager li a {
  opacity: 0.75;
}
.lSSlideOuter ul.lSPager li a img {
  width: 150px !important;
  height: 150px !important;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  .lSSlideOuter ul.lSPager li a img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1/1;
  }
}

.simplefavorite-button {
  margin-left: 10px;
}
.simplefavorite-button:hover {
  cursor: pointer;
}
.simplefavorite-button i {
  font-size: 28px;
  line-height: 32px;
  vertical-align: bottom;
}

#map #app4_root .map-container {
  padding: 0;
}
#map #app4_root .map-container .map {
  height: 400px;
}
.search-container {
  width: 780px;
  height: 60px;
  margin: 0 auto;
  padding: 0 !important;
}
@media screen and (max-width: 768px) {
  .search-container {
    width: 100%;
    height: 50px;
  }
}
.search-container .geocoder {
  width: 100% !important;
}
.search-container .geocoder .mapboxgl-ctrl-geocoder,
.search-container .geocoder .mapboxgl-ctrl-geocoder .suggestions {
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}
.search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input {
  height: 60px !important;
  font-family: sans-serif !important;
  font-size: 20px !important;
  font-weight: 700;
  border: none;
  background-color: #eee;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input {
    height: 50px !important;
    font-size: 18px !important;
  }
}
.search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input:focus {
  outline: none;
}
.search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input::-webkit-input-placeholder {
  color: #cccccc;
}
.search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input::-moz-placeholder {
  color: #cccccc;
}
.search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input:-ms-input-placeholder {
  color: #cccccc;
}
.search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input::-ms-input-placeholder {
  color: #cccccc;
}
.search-container .geocoder .mapboxgl-ctrl input.mapboxgl-ctrl-geocoder--input::placeholder {
  color: #cccccc;
}
.search-container .geocoder .mapboxgl-ctrl svg.mapboxgl-ctrl-geocoder--icon-search {
  top: 20px !important;
}
@media screen and (max-width: 768px) {
  .search-container .geocoder .mapboxgl-ctrl svg.mapboxgl-ctrl-geocoder--icon-search {
    top: 15px !important;
  }
}
.search-container .geocoder .mapboxgl-ctrl-geocoder--pin-right button.mapboxgl-ctrl-geocoder--button {
  top: 20px !important;
  background: transparent !important;
}
@media screen and (max-width: 768px) {
  .search-container .geocoder .mapboxgl-ctrl-geocoder--pin-right button.mapboxgl-ctrl-geocoder--button {
    top: 15px !important;
  }
}
.search-container .geocoder .mapboxgl-ctrl-geocoder--pin-right button.mapboxgl-ctrl-geocoder--button svg.mapboxgl-ctrl-geocoder--icon-close {
  margin: 0 !important;
  width: 20px !important;
  height: 20px !important;
}

.search {
  width: 100% !important;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .search {
    width: 96% !important;
  }
}
@media screen and (max-width: 768px) {
  .search .map-outer-container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 10px 0 !important;
  }
}
.search .map-outer-container .sidebar {
  width: calc(40% + 20px) !important;
}
@media screen and (max-width: 768px) {
  .search .map-outer-container .sidebar {
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
        -ms-flex-order: 2;
            order: 2;
    height: 50vh !important;
    width: 100% !important;
  }
}
.search .map-outer-container .sidebar .list-container {
  padding: 15px 0;
}
.search .map-outer-container .sidebar .list-container .item {
  width: calc(50% - 15px);
  margin: 5px;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.search .map-outer-container .sidebar .list-container .item:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  background-color: #ffe8e1;
  -webkit-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out;
}
.search .map-outer-container .sidebar .list-container.no-items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-align-content: center;
      -ms-flex-line-pack: center;
          align-content: center;
}
.search .map-outer-container .sidebar .list-container.no-items .no-list-item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 18px;
  font-weight: 700;
}
.search .map-outer-container .sidebar .list-container.no-items .no-list-item::before {
  content: "\e995";
  font-family: "Phosphor-Fill" !important;
  speak: never;
  font-size: 28px;
  color: #333333;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  margin-right: 10px;
}
.search .map-outer-container .map-inner-container {
  width: calc(60% - 20px) !important;
}
@media screen and (max-width: 768px) {
  .search .map-outer-container .map-inner-container {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1/1;
    margin-bottom: 15px;
  }
}
.search .language-select-wrapper {
  display: none;
}

#wpmem_login,
#wpmem_reg {
  width: 470px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  #wpmem_login,
  #wpmem_reg {
    width: 100%;
  }
}
#wpmem_login form fieldset legend,
#wpmem_reg form fieldset legend {
  font-size: 20px;
  font-weight: 700;
}
#wpmem_login form fieldset .div_text input,
#wpmem_reg form fieldset .div_text input {
  width: 100%;
  font-size: 20px;
  font-weight: 700;
  border: none;
  background-color: #eee;
}
#wpmem_login form fieldset .div_text input:focus,
#wpmem_reg form fieldset .div_text input:focus {
  outline: none;
}
#wpmem_login form fieldset .div_text input::-webkit-input-placeholder, #wpmem_reg form fieldset .div_text input::-webkit-input-placeholder {
  color: #cccccc;
}
#wpmem_login form fieldset .div_text input::-moz-placeholder, #wpmem_reg form fieldset .div_text input::-moz-placeholder {
  color: #cccccc;
}
#wpmem_login form fieldset .div_text input:-ms-input-placeholder, #wpmem_reg form fieldset .div_text input:-ms-input-placeholder {
  color: #cccccc;
}
#wpmem_login form fieldset .div_text input::-ms-input-placeholder, #wpmem_reg form fieldset .div_text input::-ms-input-placeholder {
  color: #cccccc;
}
#wpmem_login form fieldset .div_text input::placeholder,
#wpmem_reg form fieldset .div_text input::placeholder {
  color: #cccccc;
}
#wpmem_login form fieldset .button_div input.buttons,
#wpmem_reg form fieldset .button_div input.buttons {
  padding: 10px 20px;
  font-size: 16px;
  font-weight: 700;
  background-color: #fc6635;
  color: #ffffff;
  border: none;
  border-radius: 3px;
}
#wpmem_login form fieldset .button_div input.buttons i,
#wpmem_reg form fieldset .button_div input.buttons i {
  display: block;
  font-size: 32px;
}
#wpmem_login form fieldset .button_div input:hover,
#wpmem_reg form fieldset .button_div input:hover {
  opacity: 0.75;
  cursor: pointer;
}
.wpmem_msg {
  width: 470px;
  margin: 0 auto;
  border: none;
  background: #f8f8f8;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 30px;
}
@media screen and (max-width: 768px) {
  .wpmem_msg {
    width: 100%;
  }
}

.register_status,
.login_status,
.register_links {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 470px;
  margin: 0 auto 30px;
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .register_status,
  .login_status,
  .register_links {
    width: 100%;
  }
}
.register_status a,
.login_status a,
.register_links a {
  font-size: 16px;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .wpcf7 {
    width: calc(100% - 20px);
    margin: 0 auto !important;
  }
}
.wpcf7 form p {
  font-weight: 700;
}
.wpcf7 form p label {
  display: block;
  width: 100%;
}
.wpcf7 form p label .wpcf7-form-control-wrap input[type=text],
.wpcf7 form p label .wpcf7-form-control-wrap input[type=email],
.wpcf7 form p label .wpcf7-form-control-wrap select,
.wpcf7 form p label .wpcf7-form-control-wrap textarea {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  padding: 5px 10px;
  background: #f2f2f2;
  border: none;
  font-size: 18px;
  font-weight: 500;
}
.wpcf7 form p label .wpcf7-form-control-wrap input[type=text].id, .wpcf7 form p label .wpcf7-form-control-wrap input[type=text].PropertyName {
  background: transparent;
  font-weight: 700;
  pointer-events: none;
}
.wpcf7 form p label .wpcf7-form-control-wrap input[type=text].id:focus, .wpcf7 form p label .wpcf7-form-control-wrap input[type=text].PropertyName:focus {
  outline: none;
  border: none;
}
.wpcf7 form p label .wpcf7-form-control-wrap input[type=text].wpcf7-phonetext {
  padding-left: 50px;
}
.wpcf7 form p label .wpcf7-form-control-wrap input[type=text].wpcf7-validates-as-countrytext {
  padding-left: 50px;
}
.wpcf7 form p label .wpcf7-form-control-wrap select {
  height: 40px;
}
.wpcf7 form p label .wpcf7-form-control-wrap .wpcf7-radio {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.wpcf7 form p label .wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin: 0;
}
.wpcf7 form p label .required {
  font-size: 12px;
  color: #fc6635;
}
.wpcf7 form p label.optin .small {
  font-size: 12px;
}
.wpcf7 form p input[type=submit] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  padding: 20px 20px;
  margin: 0 auto;
  border: none;
  background: #fc6635;
  color: #ffffff;
  border-radius: 3px;
  opacity: 1;
}
.wpcf7 form p input[type=submit]:hover {
  cursor: pointer;
  opacity: 0.75;
  -webkit-transition: opacity 1s ease;
  transition: opacity 1s ease;
}
.wpcf7 form p .wpcf7-spinner {
  display: block;
  margin: 10px auto 0;
}

.grecaptcha-badge {
  visibility: hidden;
}

.wrapper {
  width: 100%;
}

.section {
  width: 940px;
  margin: 0 auto 60px;
}
@media screen and (max-width: 960px) {
  .section {
    width: calc(100% - 20px);
    margin: 0 auto 30px;
  }
}

.section-header {
  width: 100%;
  padding: 0 10px;
}
@media screen and (max-width: 960px) {
  .section-header {
    margin: 0 auto;
    padding: 0;
  }
}

.section-header-title.front {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding-right: 10px;
}

.page-header {
  width: 100%;
  height: auto;
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  .page-header {
    height: auto;
    padding: 0 10px;
  }
}
.page-header.about, .page-header.support, .page-header.type {
  width: 100%;
  height: 300px;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 960px) {
  .page-header.about, .page-header.support, .page-header.type {
    height: 200px;
  }
}
@media screen and (max-width: 768px) {
  .page-header.about .page-header-inner, .page-header.support .page-header-inner, .page-header.type .page-header-inner {
    padding: 30px 0;
  }
}

.page-header-inner {
  width: 940px;
  height: 100%;
  margin: 0 auto;
  padding: 30px 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 960px) {
  .page-header-inner {
    width: 100%;
    padding: 30px;
  }
}
@media screen and (max-width: 768px) {
  .page-header-inner {
    width: 100%;
    padding: 0;
  }
}
.page-header-inner .page-header-desc {
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .page-header-inner h1 {
    bottom: 20px;
  }
}

.hero {
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  max-height: calc(100vh - 130px);
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .hero {
    width: 100%;
    aspect-ratio: 1/1;
    max-height: none;
    margin-bottom: 30px;
  }
}

.hero-video {
  display: block;
  position: relative;
  width: 100%;
  max-width: 100%;
  max-height: 80vh;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .hero-video {
    display: none;
  }
}

.hero-slide {
  display: none;
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .hero-slide {
    display: block;
  }
}
.hero-slide.cS-hidden {
  opacity: 0;
}
.hero-slide .lSSlideOuter .lSSlideWrapper ul.lightSlider {
  list-style-type: none;
}
.hero-slide .lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
@media screen and (max-width: 768px) {
  .hero-slide .lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide {
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
  }
}
.hero-slide .lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 768px) {
  .hero-slide .lSSlideOuter .lSSlideWrapper ul.lightSlider li.lslide img {
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.search-box {
  width: 780px;
  height: 60px;
  position: absolute;
  left: 50%;
  bottom: 35%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 100;
}
@media screen and (max-width: 960px) {
  .search-box {
    width: 80%;
    bottom: 30%;
  }
}
@media screen and (max-width: 768px) {
  .search-box {
    width: calc(100% - 20px);
    bottom: 20%;
  }
}
.search-box h2 {
  letter-spacing: -0.03em;
}
.search-box .search {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  background: #ffffff;
  z-index: 101;
  border-radius: 3px;
}
@media screen and (max-width: 960px) {
  .search-box .search {
    height: 50px;
  }
}
@media screen and (max-width: 768px) {
  .search-box .search {
    height: 40px;
  }
}

.banner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.banner a {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
  -webkit-justify-content: start;
      -ms-flex-pack: start;
          justify-content: start;
  -webkit-box-align: start;
  -webkit-align-items: start;
      -ms-flex-align: start;
          align-items: start;
  width: 450px;
  height: auto;
  aspect-ratio: 3/1;
  margin: 10px;
  padding: 20px;
  border-radius: 3px;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 960px) {
  .banner a {
    width: calc(50% - 20px);
    aspect-ratio: 2/1;
  }
}
@media screen and (max-width: 768px) {
  .banner a {
    width: 100%;
  }
}
.banner a h3 {
  position: relative;
  z-index: 3;
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .banner a h3 {
    font-size: 18px;
  }
}
.banner a .desc {
  position: relative;
  z-index: 3;
  font-size: 12px;
  font-weight: 700;
}
.banner a .more {
  -webkit-align-self: flex-end;
      -ms-flex-item-align: end;
          align-self: flex-end;
  margin-top: auto;
  position: relative;
  z-index: 3;
  font-size: 12px;
  font-weight: 700;
  padding: 10px;
  border-radius: 3px;
  background: #ffffff;
}
.card-list,
.prop-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}

.card {
  width: calc(25% - 10px);
  margin: 5px;
}
@media screen and (max-width: 768px) {
  .card {
    width: calc(50% - 10px);
  }
}

.card-link {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
  padding: 10px;
  border-radius: 3px;
}
.card-thumb {
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 3px;
}

.card-title {
  position: relative;
  text-align: center;
  font-size: 18px;
  line-height: 1.2em;
  color: #ffffff;
  padding: 0 0 20px;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .card-title {
    font-size: 15px;
  }
}

.card-desc {
  padding: 10px;
}
.card-desc p {
  margin-bottom: 1em;
}
.card-desc p:last-child {
  margin-bottom: 0;
}

.card-desc-header {
  padding-bottom: 10px;
  border-bottom: 1px solid #333333;
}

.prop {
  display: block;
  width: calc(25% - 10px);
  margin: 5px;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .prop {
    width: calc(50% - 10px);
  }
}

.prop-link {
  display: block;
  height: 100%;
  padding: 10px;
  border-radius: 3px;
}

.prop-thumb {
  width: 100%;
  height: auto;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 10px;
}

.prop-title {
  font-size: 15px;
  margin-bottom: 10px;
  color: #fc6635;
}
@media screen and (max-width: 768px) {
  .prop-title {
    font-size: 13px;
  }
}

.prop-info {
  font-size: 14px;
  color: #333333;
}
@media screen and (max-width: 768px) {
  .prop-info {
    font-size: 12px;
  }
}

.feature-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-justify-content: space-around;
      -ms-flex-pack: distribute;
          justify-content: space-around;
}

.feature-item {
  width: 376px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 768px) {
  .feature-item {
    width: calc(50% - 10px);
  }
}

.icon-md i {
  font-size: 80px;
}
@media screen and (max-width: 768px) {
  .icon-md i {
    font-size: 50px;
  }
}

.icon-lg i {
  font-size: 100px;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 768px) {
  .icon-lg i {
    font-size: 75px;
  }
}

.icon-circle {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 120px;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .icon-circle {
    width: 80px;
  }
}

.icon-orange i {
  background: -webkit-linear-gradient(70deg, #fc6635 30%, #fcaf35) text;
  background: linear-gradient(20deg, #fc6635 30%, #fcaf35) text;
  color: #fc6635;
}

.icon-blue i {
  background: -webkit-linear-gradient(70deg, #3c75c3 30%, #3589fc) text;
  background: linear-gradient(20deg, #3c75c3 30%, #3589fc) text;
  color: #3c75c3;
}

.icon-white i {
  color: #ffffff;
}

.feature-card-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
.feature-card {
  width: calc(25% - 20px);
  padding: 15px;
  margin: 10px;
  background-color: #f2f2f2;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .feature-card {
    width: calc(50% - 10px);
    padding: 10px;
    margin: 5px;
  }
}

.step-item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .step-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.step-item:last-child .step-text::after {
  display: none;
}

.step-image {
  width: 300px;
  aspect-ratio: 4/3;
  -o-object-position: center center;
     object-position: center center;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .step-image {
    width: 100%;
    aspect-ratio: 2/1;
    margin-bottom: 15px;
  }
}

.step-text {
  position: relative;
  width: 620px;
}
@media screen and (max-width: 960px) {
  .step-text {
    width: calc(100% - 320px);
  }
}
@media screen and (max-width: 768px) {
  .step-text {
    width: 100%;
  }
}
.step-text::after {
  display: block;
  content: "";
  width: 100px;
  height: 20px;
  position: absolute;
  bottom: -45px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
          clip-path: polygon(0 0, 100% 0, 50% 100%);
  background: #8790d1;
}
@media screen and (max-width: 768px) {
  .step-text::after {
    bottom: -22.5px;
  }
}

.step-title {
  background-color: #8790d1;
  border-radius: 3px;
  padding: 20px;
}
@media screen and (max-width: 768px) {
  .step-title {
    padding: 10px 20px;
  }
}

.step-desc {
  display: block;
  padding: 20px;
}
@media screen and (max-width: 768px) {
  .step-desc {
    padding: 10px;
  }
}

.feature-flow-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .feature-flow-list {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
}

.flow-item {
  width: 16.6666666667%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .flow-item {
    width: calc(33.3333% - 10px);
    margin-bottom: 10px;
  }
}
.flow-item:nth-child(2n) .flow-line {
  height: 40px;
}
@media screen and (max-width: 768px) {
  .flow-item:nth-child(2n) .flow-line {
    height: 20px;
  }
}
.flow-item .flow-line {
  width: 2px;
  height: 80px;
}
@media screen and (max-width: 768px) {
  .flow-item .flow-line {
    height: 40px;
  }
}

.flow-num {
  font-size: 60px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .flow-num {
    font-size: 30px;
  }
}

.support-card-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.support-card {
  width: calc(33.3333% - 20px);
  margin: 10px;
}
@media screen and (max-width: 768px) {
  .support-card {
    width: calc(50% - 10px);
    margin: 5px;
  }
}

.support-card-menu {
  padding: 15px;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .support-card-menu {
    padding: 10px;
  }
}

.support-card-title {
  padding: 30px 15px;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .support-card-title {
    padding: 15px 10px;
  }
}

.support-card-num {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-weight: 700;
  background-color: #ffffff;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .support-card-num {
    width: 30px;
    height: 30px;
  }
}

.support-card-menu-desc {
  width: 100%;
}

.support-case-list {
  width: 780px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .support-case-list {
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  .support-case-list {
    width: 100%;
  }
}

.support-case-item {
  width: 100%;
  height: 60px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #f2f2f2;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .support-case-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
    border-radius: 0 0 3px 3px;
  }
}

.support-case-item-header {
  position: relative;
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 20px;
  background: #3c75c3;
  border-radius: 3px 0 0 3px;
}
@media screen and (max-width: 768px) {
  .support-case-item-header {
    width: 100%;
    padding: 10px;
    border-radius: 3px 3px 0 0;
  }
}
.support-case-item-header i {
  margin-right: 10px;
}
.support-case-item-header::after {
  position: absolute;
  right: -29.5px;
  content: "";
  width: 30px;
  height: 60px;
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
          clip-path: polygon(0 0, 100% 50%, 0 100%);
  background: #3c75c3;
}
@media screen and (max-width: 768px) {
  .support-case-item-header::after {
    display: none;
  }
}

.support-case-item-desc {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 20px;
}
@media screen and (max-width: 768px) {
  .support-case-item-desc {
    padding: 10px;
  }
}

.support-case-feature {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.support-case-feature-item {
  width: calc(33.3333% - 20px);
  margin: 10px;
}
@media screen and (max-width: 768px) {
  .support-case-feature-item {
    width: calc(33.3333% - 5px);
    margin: 0;
  }
}

.support-guarantee {
  width: 700px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .support-guarantee {
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  .support-guarantee {
    width: 100%;
  }
}
.support-guarantee ul {
  padding-left: 1em;
}

.support-guarantee-feature {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.support-guarantee-feature-item {
  width: calc(33.3333% - 20px);
  margin: 10px;
  padding: 30px 15px;
  background-color: #f2f2f2;
  border-radius: 3px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .support-guarantee-feature-item {
    width: calc(33.3333% - 5px);
    margin: 0;
    padding: 15px 10px;
  }
}

.guarantee-item-num {
  width: 100%;
  font-weight: 700;
  padding-left: 30px;
}

.type-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .type-list {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
}

.type-item {
  width: calc(33.3333% - 20px);
  margin: 10px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 768px) {
  .type-item {
    width: 100%;
    margin: 0 0 30px;
  }
  .type-item:last-child {
    margin: 0;
  }
}

.type-item-header {
  padding: 15px;
  background: #3c75c3;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .type-item-header {
    font-size: 16px;
    padding: 10px;
    margin-bottom: 15px;
  }
}
.type-item-header .small {
  font-size: 15px;
}

.type-item-feature {
  list-style: none;
  padding: 10px;
  margin: 0;
}
.type-item-feature li {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 15px;
}
.type-item-feature li .desc {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4em;
}

.feature-item-num {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #3c75c3;
  color: #ffffff;
  font-size: 20px;
  font-weight: 700;
  margin-right: 10px;
}

.feature-item-desc {
  font-weight: 700;
}

.type-item-desc {
  padding: 10px;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

.type-item-gallery {
  list-style: none;
  padding: 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.type-item-gallery .gallery-item {
  width: calc(50% - 5px);
  margin-bottom: 10px;
}
.type-item-gallery .gallery-item img {
  display: block;
  width: 100%;
  height: auto;
}

.faq-group {
  width: 700px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .faq-group {
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  .faq-group {
    width: 100%;
  }
}

.faq-cat-desc {
  padding: 10px;
}

.faq-list {
  list-style: none;
  padding-left: 1em;
}
@media screen and (max-width: 768px) {
  .faq-list {
    padding: 0;
  }
}

.faq-item-question {
  position: relative;
  background: #f2f2f2;
  border-radius: 3px;
  padding: 10px 50px 10px 20px;
  font-weight: 700;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .faq-item-question {
    padding: 10px 40px 10px 10px;
  }
}
.faq-item-question::after {
  content: "\e3d4";
  display: block;
  font-family: "Phosphor-Bold" !important;
  font-size: 20px;
  position: absolute;
  right: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .faq-item-question::after {
    right: 10px;
  }
}
.faq-item-question.active::after {
  content: "\e32a";
}

.faq-item-answer {
  display: none;
}
.faq-item-answer .faq-item-answer-inner {
  padding: 20px;
}
@media screen and (max-width: 768px) {
  .faq-item-answer .faq-item-answer-inner {
    padding: 10px;
  }
}
.faq-item-answer .faq-item-answer-inner p {
  margin-bottom: 1em;
}
.faq-item-answer .faq-item-answer-inner p:last-child {
  margin-bottom: 0;
}

.policy {
  width: 700px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .policy {
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  .policy {
    width: 100%;
  }
}

.policy-content {
  padding-left: 2em;
}
@media screen and (max-width: 768px) {
  .policy-content {
    padding-left: 1em;
  }
}
.policy-content h4 {
  margin-bottom: 10px;
}
.policy-content p {
  margin-bottom: 1em;
}
.policy-content p:last-child {
  margin-bottom: 0;
}
.policy-content ul {
  padding-left: 1em;
}
.policy-content table {
  width: 100%;
  margin-bottom: 30px;
  border-collapse: collapse;
  font-size: 12px;
  line-height: 1.4em;
}
.policy-content table th,
.policy-content table td {
  border: 1px solid #333333;
  padding: 15px;
}
.policy-content table th {
  text-align: center;
  background-color: #f2f2f2;
}
.policy-content table td {
  vertical-align: top;
}

.contact {
  width: 470px;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .contact {
    width: 60%;
  }
}
@media screen and (max-width: 768px) {
  .contact {
    width: 100%;
  }
}
.contact p {
  margin-bottom: 1em;
}
.contact .form-text {
  font-weight: 700;
  margin-bottom: 10px;
}
.contact .form-notice {
  font-size: 12px;
}
.contact .copy-box {
  display: inline-block;
  border-radius: 3%;
  padding: 5px 10px;
  color: #ffffff;
  background: #fc6635;
  position: relative;
}
.contact .copy-btn {
  display: inline-block;
  color: #ffffff;
  cursor: pointer;
}
.contact .copy-btn::after {
  opacity: 0;
}
.contact .copy-btn.copied::after {
  display: inline-block;
  content: "copied!";
  font-size: 10px;
  border-radius: 3px;
  padding: 5px 10px;
  background: #ffffff;
  color: #fc6635;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: 0.3s;
  transition: 0.3s;
  opacity: 1;
}
.contact #contact-list {
  margin-bottom: 10px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .contact #contact-list {
    width: calc(100% - 20px);
    margin: 0 auto 30px;
  }
}
.contact #contact-list .no-contact-list {
  font-weight: 700;
  text-align: center;
  margin: 0;
}
.contact #contact-list .contact-list-box {
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 15px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-bottom: 10px;
  background-color: #f9f9f9;
}
@media screen and (max-width: 768px) {
  .contact #contact-list .contact-list-box {
    padding: 10px;
  }
}
.contact #contact-list .contact-list-box h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .contact #contact-list .contact-list-box h3 {
    font-size: 16px;
  }
}
.contact #contact-list .contact-list-box .contact-list-content {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
}
.contact #contact-list .contact-list-box .contact-list-content img {
  display: block;
  width: 120px;
  height: 120px;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .contact #contact-list .contact-list-box .contact-list-content img {
    width: 30%;
    height: auto;
  }
}
.contact #contact-list .contact-list-box .contact-list-content .property-details {
  -webkit-box-flex: 2;
  -webkit-flex-grow: 2;
      -ms-flex-positive: 2;
          flex-grow: 2;
  list-style-type: none;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6em;
  -webkit-padding-start: 0;
          padding-inline-start: 0;
}
@media screen and (max-width: 768px) {
  .contact #contact-list .contact-list-box .contact-list-content .property-details {
    font-size: 12px;
  }
}
.property-name {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .property-name {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.property-name .contact-list-button {
  margin-left: 20px;
}
@media screen and (max-width: 768px) {
  .property-name .contact-list-button {
    margin: 0;
    padding: 10px 0;
  }
}
.property-name .contact-list-button .label {
  white-space: nowrap;
}

.property-basic {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
.property-basic .spacer {
  width: 100%;
}

.property-basic-item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-right: 10px;
}
.property-basic-item i {
  font-size: 22px;
  margin-right: 5px;
}

.property-summary {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 768px) {
  .property-summary {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
}

.property-gallery {
  width: 620px;
  opacity: 1;
  -webkit-transition: opacity 1s ease;
  transition: opacity 1s ease;
}
@media screen and (max-width: 960px) {
  .property-gallery {
    width: calc(65% - 10px);
  }
}
@media screen and (max-width: 768px) {
  .property-gallery {
    width: 100%;
    margin-bottom: 30px;
  }
}

.property-fees {
  width: 300px;
  padding: 40px 20px;
  background-color: #f2f2f2;
}
@media screen and (max-width: 960px) {
  .property-fees {
    width: calc(35% - 10px);
  }
}
@media screen and (max-width: 768px) {
  .property-fees {
    width: 100%;
  }
}
.property-fees .fees {
  font-weight: 700;
}
.property-fees .fees .small {
  font-size: 12px;
}
.property-fees dl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.property-fees dl dt {
  width: 65%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 700;
}
.property-fees dl dt i {
  font-size: 22px;
  margin-right: 5px;
}
.property-fees dl dd {
  width: 35%;
}
.property-fees dl.rent dt {
  width: 100%;
}
.property-fees dl.rent dd {
  width: 100%;
}

.facility-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  list-style-type: none;
  padding: 0;
}
.facility-list li {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  color: #bbbbbb;
  margin: 0 20px 10px 0;
}
.facility-list li.checked {
  color: #333333;
}
.facility-list li i {
  font-size: 22px;
  margin-right: 5px;
}

.property-details .section-inner.recommendation p {
  margin-bottom: 1em;
}
.property-details .section-inner.recommendation p:last-child {
  margin: 0;
}
.property-details .section-inner.shared .facility-list, .property-details .section-inner.private .facility-list, .property-details .section-inner.rules .facility-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.property-details .section-inner.shared .facility-list li, .property-details .section-inner.private .facility-list li, .property-details .section-inner.rules .facility-list li {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  color: #bbbbbb;
  margin: 0 20px 10px 0;
}
@media screen and (max-width: 768px) {
  .property-details .section-inner.shared .facility-list li, .property-details .section-inner.private .facility-list li, .property-details .section-inner.rules .facility-list li {
    margin: 0 10px 10px 0;
  }
}
.property-details .section-inner.shared .facility-list li.checked, .property-details .section-inner.private .facility-list li.checked, .property-details .section-inner.rules .facility-list li.checked {
  color: #000000;
}
.property-details .section-inner.shared .facility-list li.checked i.sd-fill::before, .property-details .section-inner.private .facility-list li.checked i.sd-fill::before, .property-details .section-inner.rules .facility-list li.checked i.sd-fill::before {
  background-color: #000000;
}
.property-details .section-inner.shared .facility-list li i, .property-details .section-inner.private .facility-list li i, .property-details .section-inner.rules .facility-list li i {
  font-size: 22px;
  margin-right: 5px;
}
.property-details .section-inner.shared .facility-list li i.sd-fill, .property-details .section-inner.private .facility-list li i.sd-fill, .property-details .section-inner.rules .facility-list li i.sd-fill {
  width: 22px;
  height: 22px;
}
.property-details .section-inner.shared .facility-list li i.sd-fill.sd-desk::before, .property-details .section-inner.private .facility-list li i.sd-fill.sd-desk::before, .property-details .section-inner.rules .facility-list li i.sd-fill.sd-desk::before {
  -webkit-mask-image: url("assets/images/i-desk.svg");
          mask-image: url("assets/images/i-desk.svg");
}
.property-details .section-inner.shared .facility-list li i.sd-fill.sd-microwaves::before, .property-details .section-inner.private .facility-list li i.sd-fill.sd-microwaves::before, .property-details .section-inner.rules .facility-list li i.sd-fill.sd-microwaves::before {
  -webkit-mask-image: url("assets/images/i-microwaves.svg");
          mask-image: url("assets/images/i-microwaves.svg");
}
.property-details .section-inner.shared .facility-list li i.sd-fill.sd-fridge::before, .property-details .section-inner.private .facility-list li i.sd-fill.sd-fridge::before, .property-details .section-inner.rules .facility-list li i.sd-fill.sd-fridge::before {
  -webkit-mask-image: url("assets/images/i-fridge.svg");
          mask-image: url("assets/images/i-fridge.svg");
}
.property-details .section-inner.shared .facility-list li i.sd-fill.sd-no-pets::before, .property-details .section-inner.private .facility-list li i.sd-fill.sd-no-pets::before, .property-details .section-inner.rules .facility-list li i.sd-fill.sd-no-pets::before {
  -webkit-mask-image: url("assets/images/i-no-pets.svg");
          mask-image: url("assets/images/i-no-pets.svg");
}
.property-details .section-inner.shared .facility-list li i.sd-fill.sd-no-smoking::before, .property-details .section-inner.private .facility-list li i.sd-fill.sd-no-smoking::before, .property-details .section-inner.rules .facility-list li i.sd-fill.sd-no-smoking::before {
  -webkit-mask-image: url("assets/images/i-no-smoking.svg");
          mask-image: url("assets/images/i-no-smoking.svg");
}
.property-details .section-inner.shared .facility-list li i.sd-fill.sd-no-guest::before, .property-details .section-inner.private .facility-list li i.sd-fill.sd-no-guest::before, .property-details .section-inner.rules .facility-list li i.sd-fill.sd-no-guest::before {
  -webkit-mask-image: url("assets/images/i-no-guest.svg");
          mask-image: url("assets/images/i-no-guest.svg");
}
.property-details .section-inner.shared .facility-list li i.sd-fill.sd-no-alcohl::before, .property-details .section-inner.private .facility-list li i.sd-fill.sd-no-alcohl::before, .property-details .section-inner.rules .facility-list li i.sd-fill.sd-no-alcohl::before {
  -webkit-mask-image: url("assets/images/i-no-alcohl.svg");
          mask-image: url("assets/images/i-no-alcohl.svg");
}
.property-details .section-inner.shared .facility-list li i.sd-fill::before, .property-details .section-inner.private .facility-list li i.sd-fill::before, .property-details .section-inner.rules .facility-list li i.sd-fill::before {
  content: "";
  display: inline-block;
  width: 22px;
  height: 22px;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  background-color: #bbbbbb;
}

#map {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  height: 400px;
  background-color: #f2f2f2;
  padding: 0;
  margin: 0;
}
@media screen and (max-width: 768px) {
  #map {
    height: auto;
    aspect-ratio: 1/1;
  }
}
#map div #app4_root .map-container {
  padding: 0;
}
#map div #app4_root .map-container .map {
  height: 400px;
}
@media screen and (max-width: 768px) {
  #map div #app4_root .map-container .map {
    height: auto;
    aspect-ratio: 1/1;
  }
}
#map div #app4_root .map-container .language-select-wrapper {
  display: none;
}

.mypage {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 768px) {
  .mypage {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.mypage .favorites {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .mypage .favorites {
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
        -ms-flex-order: 2;
            order: 2;
    width: 100%;
  }
}
.mypage .favorites h3 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 15px;
}
.mypage .favorites h3 i {
  font-size: 22px;
  margin-right: 10px;
  color: rgb(221, 51, 51);
}
.mypage .favorites article {
  padding-left: 1.5em;
}
.mypage .mypage-nav {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .mypage .mypage-nav {
    width: 100%;
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
    margin-bottom: 30px;
  }
}
.mypage .mypage-nav #wpmem_reg,
.mypage .mypage-nav .wpmem_msg {
  margin-bottom: 30px;
}
.mypage .mypage-nav ul {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  list-style-type: none;
  margin: 0;
  padding: 30px;
  background: #f2f2f2;
}

.signup {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.signup .signup-nav {
  width: 470px;
}
@media screen and (max-width: 960px) {
  .signup .signup-nav {
    width: 60%;
  }
}
@media screen and (max-width: 768px) {
  .signup .signup-nav {
    width: 100%;
  }
}
.signup .signup-nav #wpmem_reg,
.signup .signup-nav #wpmem_login,
.signup .signup-nav .wpmem_msg {
  width: 100% !important;
  margin-bottom: 30px;
}
.signup .signup-nav ul {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 470px;
  list-style-type: none;
  margin: 0;
  padding: 30px;
  background: #f2f2f2;
}
@media screen and (max-width: 768px) {
  .signup .signup-nav ul {
    width: 100%;
  }
}
.signup .signup-nav .form-notice {
  font-size: 12px;
}

.overlay {
  position: relative;
  z-index: 1;
}
.overlay::after {
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 3px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.2);
  z-index: 2;
}

.color-theme {
  color: #fc6635;
}

.color-black {
  color: #333333;
}

.color-white {
  color: #ffffff;
}

.color-blue {
  color: #3c75c3;
}

.color-lightblue {
  color: #646db1;
}

.drop-shadow-lg {
  -webkit-filter: drop-shadow(0 2px 5px rgba(72, 34, 21, 0.3));
          filter: drop-shadow(0 2px 5px rgba(72, 34, 21, 0.3));
}

.drop-shadow-sm {
  -webkit-filter: drop-shadow(0 2px 3px rgba(72, 34, 21, 0.3));
          filter: drop-shadow(0 2px 3px rgba(72, 34, 21, 0.3));
}

.fs-xs {
  font-size: 12px;
}

.fs-sm {
  font-size: 13px;
}
@media screen and (max-width: 960px) {
  .fs-sm {
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  .fs-sm {
    font-size: 11px;
  }
}

.fs-md {
  font-size: 15px;
}
@media screen and (max-width: 960px) {
  .fs-md {
    font-size: 14px;
  }
}
@media screen and (max-width: 768px) {
  .fs-md {
    font-size: 13px;
  }
}

.fs-lg {
  font-size: 20px;
}
@media screen and (max-width: 960px) {
  .fs-lg {
    font-size: 18px;
  }
}
@media screen and (max-width: 768px) {
  .fs-lg {
    font-size: 15px;
  }
}

.fs-xl {
  font-size: 30px;
}
@media screen and (max-width: 960px) {
  .fs-xl {
    font-size: 25px;
  }
}
@media screen and (max-width: 768px) {
  .fs-xl {
    font-size: 18px;
  }
}

.fs-xxl {
  font-size: 40px;
}
@media screen and (max-width: 960px) {
  .fs-xxl {
    font-size: 30px;
  }
}
@media screen and (max-width: 768px) {
  .fs-xxl {
    font-size: 20px;
  }
}

.fs-icon {
  font-size: 40px;
}

.fw-500 {
  font-weight: 500;
}

.fw-700 {
  font-weight: 700;
}

.bold {
  font-weight: 700;
}

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

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

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

.d-inline {
  display: inline;
}

.d-inline-block {
  display: inline-block;
}

.d-block {
  display: block;
}

.d-flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.justify-content-start {
  -webkit-box-pack: start;
  -webkit-justify-content: start;
      -ms-flex-pack: start;
          justify-content: start;
}

.justify-content-end {
  -webkit-box-pack: end;
  -webkit-justify-content: end;
      -ms-flex-pack: end;
          justify-content: end;
}

.justify-content-center {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.justify-content-between {
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.justify-content-around {
  -webkit-justify-content: space-around;
      -ms-flex-pack: distribute;
          justify-content: space-around;
}

.align-items-start {
  -webkit-box-align: start;
  -webkit-align-items: start;
      -ms-flex-align: start;
          align-items: start;
}

.align-items-end {
  -webkit-box-align: end;
  -webkit-align-items: end;
      -ms-flex-align: end;
          align-items: end;
}

.align-items-center {
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.align-items-stretch {
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}

.flex-shrink0 {
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
}

.margin-0-auto {
  margin: 0 auto;
}

.margin-bottom-60 {
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .margin-bottom-60 {
    margin-bottom: 30px;
  }
}

.margin-bottom-30 {
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .margin-bottom-30 {
    margin-bottom: 15px;
  }
}

.margin-bottom-15 {
  margin-bottom: 15px;
}

.margin-bottom-10 {
  margin-bottom: 10px;
}

.margin-bottom-5 {
  margin-bottom: 5px;
}

.margin-left-5 {
  margin-left: 5px;
}

.lh-1em {
  line-height: 1em;
}

.lh-12em {
  line-height: 1.2em;
}

.lh-14em {
  line-height: 1.4em;
}

.a-hover {
  opacity: 1;
  -webkit-transition: opacity 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out;
}
.a-hover:hover {
  opacity: 0.6;
  -webkit-transition: opacity 0.1s ease-in-out;
  transition: opacity 0.1s ease-in-out;
}

.btn-active {
  opacity: 1;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.btn-active:hover {
  opacity: 0.8;
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-transition: all 0.1s ease;
  transition: all 0.1s ease;
}

.btn-hover {
  opacity: 1;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.btn-hover:hover {
  opacity: 0.8;
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-transition: all 0.1s ease;
  transition: all 0.1s ease;
}

.card-hover {
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.card-hover .overlay::after {
  -webkit-transition: opacity 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out;
  opacity: 1;
}
.card-hover:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  background-color: #ffe8e1;
  -webkit-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out;
}
.card-hover:hover .overlay::after {
  -webkit-transition: opacity 0.1s ease-in-out;
  transition: opacity 0.1s ease-in-out;
  opacity: 0;
}

.banner-hover {
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.banner-hover::after {
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.banner-hover:hover {
  -webkit-transform: scale(1.03);
          transform: scale(1.03);
  -webkit-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out;
}
.banner-hover:hover::after {
  opacity: 0;
  -webkit-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out;
}

.faq-hover {
  opacity: 1;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.faq-hover:hover {
  opacity: 0.8;
  -webkit-transform: scale(1.02);
          transform: scale(1.02);
  -webkit-transition: all 0.1s ease;
  transition: all 0.1s ease;
}

@-webkit-keyframes popUp {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-50%) scale(0.9);
            transform: translateX(-50%) scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(-50%) scale(1);
            transform: translateX(-50%) scale(1);
  }
}

@keyframes popUp {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-50%) scale(0.9);
            transform: translateX(-50%) scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(-50%) scale(1);
            transform: translateX(-50%) scale(1);
  }
}
@-webkit-keyframes mobileMenu {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes mobileMenu {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}/*# sourceMappingURL=style.css.map */