@charset "utf-8";@charset "UTF-8";
/* -------------------------------------------- *
 *  検索フロー
 * -------------------------------------------- */
.sec-contents {
  padding-top: 5px;
  color: #000; /* 部分的に新UIにしたカテゴリトップへの暫定対応 */
  background-color: #f5f5f5;
  border-bottom: 1px solid transparent;
}

/* 新UI対応 */
.mod-personalIdentity {
  margin-bottom: 0;
}

/* カテゴリトップLP一部新UI対応の調整 */
.temporaryWrap {
  background-color: #fff;
  overflow: hidden;
}

/* 戸建てトップLPの調整 */
.mod-companyLinkList + .temporaryWrap,
.mod-rankingLinkList + .temporaryWrap {
  margin-top: 1px;
}

.lifullFont {
  font-family: "LIFULLFONT", sans-serif;
}
/* = ui-modalcommon
----------------------------------------------- *
 * ui-modalcommon
----------------------------------------------- */
body.is-scrollLocked {
  overflow: hidden;
  width: 100%;
  height: 100%;
  position: fixed;
}

.ui-modal {
  position: fixed;
  user-select: none;
  pointer-events: none;
  z-index: 0;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(38, 38, 38, 0.4);
  transition: opacity 250ms 150ms, z-index 250ms 150ms ease-in-out;
  opacity: 0;
  overflow-y: scroll;
}
.ui-modal.is-open {
  user-select: auto;
  pointer-events: auto;
  opacity: 1;
  z-index: 100;
}
.ui-modal .bg {
  position: fixed;
  top: 0;
  z-index: 200;
  width: 100%;
  height: 100%;
}
.ui-modal .content {
  position: absolute;
  top: 48px;
  left: 50%;
  transform: translateX(-50%);
  margin-bottom: 48px;
  box-sizing: border-box;
  z-index: 300;
}
.ui-modal .content .closeButton {
  display: block;
  position: absolute;
  top: -15px;
  right: -15px;
  height: 30px;
  width: 30px;
  border-radius: 50%;
  background-color: #333;
}
.ui-modal .content .closeButton::before, .ui-modal .content .closeButton::after {
  content: "";
  display: block;
  width: 18px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  top: calc(50% - 1px);
  left: calc(50% - 9px);
  transform-origin: center;
}
.ui-modal .content .closeButton::before {
  transform: rotate(45deg);
}
.ui-modal .content .closeButton::after {
  transform: rotate(-45deg);
}
@charset "UTF-8";
/* = mod-themeTopicHeading
----------------------------------------------- *
 * テーマラベル・リード文箇所のcss
 * 賃貸・戸建・中古マンション・新築マンション
----------------------------------------------- */
.mod-themeTopicHeading {
  font-size: 16px;
  border-bottom: 1px solid #d8d8d8;
}
.mod-themeTopicHeading__title {
  padding: 8px 10px 10px;
  color: #000;
  background-color: #f5f5f5;
  font-weight: bold;
}
.mod-themeTopicHeading__areaCategory {
  display: block;
  line-height: 1.57;
  font-size: 0.875em;
}
.mod-themeTopicHeading__titleText {
  display: block;
  float: right;
  margin-top: 12px;
  width: calc(100% - 90px);
  box-sizing: border-box;
  transform: translateY(-5px);
}
.mod-themeTopicHeading__badge {
  position: relative;
  top: -1px;
  display: inline-block;
  padding: 3px 3px 3px 4px;
  color: #fff;
  background: #ed6103;
  margin-right: 5px;
  line-height: 1;
  font-size: 0.875em;
}
.mod-themeTopicHeading__badge::after {
  content: "";
  position: absolute;
  right: -5px;
  top: 0;
  bottom: 0;
  border-width: 10px 5px 10px 0;
  border-style: solid;
  border-color: #ed6103 transparent #ed6103 #ed6103;
}
.mod-themeTopicHeading__topic {
  line-height: 1.44;
  font-size: 1.125em;
  color: #ed6103;
}
.mod-themeTopicHeading__imageWrapper {
  display: inline-block;
  padding: 0 10px;
}
.mod-themeTopicHeading__titleImage {
  width: 80px;
  height: 60px;
}
.mod-themeTopicHeading__lead {
  padding: 12px 10px 20px;
  font-size: 0.875em;
  line-height: 1.43;
  clear: both;
}
@charset "UTF-8";
/* = mod-themeDescription
----------------------------------------------- *
 * テーマの説明文
----------------------------------------------- */
.mod-themeDescription {
  margin: 10px 0;
  padding: 10px 7px;
  font-size: 12px;
  line-height: 1.5;
}
@charset "UTF-8";
/* = mod-areaPrefSelector
----------------------------------------------- *
 * エリア・都道府県・検索方法選択
----------------------------------------------- */
.mod-areaPrefSelector {
  font-size: 16px;
  position: relative;
  width: 100%;
  overflow: hidden;
}

.mod-areaPrefSelector.noMarginBottom {
  margin-bottom: 0;
}

.mod-areaPrefSelector .lead {
  margin: 20px 0;
  font-size: 0.875em;
}

.mod-areaPrefSelector .lead.textLarge {
  font-size: 18px;
  font-weight: bold;
}

@media screen and (max-width: 374px) {
  .mod-areaPrefSelector .lead.textLarge {
    font-size: 16px;
  }
}
.mod-areaPrefSelector .lead.other {
  font-size: 14px;
  font-weight: bold;
  border-top: 1px solid #d8d8d8;
  padding: 13px 10px;
  width: 100vw;
  margin: 20px calc(50% - 50vw) 0;
}

/* 戻る */
.mod-areaPrefSelector .backToArea,
.mod-areaPrefSelector .backToPref {
  /* ここから ui-btn の打ち消し */
  border: 0;
  background: none;
  font-weight: normal;
  /* ここまで ui-btn の打ち消し */
  display: inline-block;
  margin: -7px 5px -7px 0;
  padding: 7px 10px;
  border-radius: 4px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  color: inherit;
  background-color: #fff;
  text-decoration: none;
  font-size: 14px;
}

.mod-areaPrefSelector .backToArea::before,
.mod-areaPrefSelector .backToPref::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%22120%22%20height%3D%22120%22%20viewBox%3D%220%200%20120%20120%22%3E%3Cpath%20fill%3D%22%236c6c6c%22%20d%3D%22M89.3%2056.6l-44.7-44.7c-1.9-1.9-4.9-1.9-6.8%200l-7.1%207.1c-1.9%201.9-1.9%204.9%200%206.8l30.8%2030.8c1.9%201.9%201.9%204.9%200%206.8l-30.8%2030.8c-1.9%201.9-1.9%204.9%200%206.8l7.1%207.1c1.9%201.9%204.9%201.9%206.8%200l44.7-44.7c1.9-1.9%201.9-4.9%200-6.8z%22/%3E%3C/svg%3E') no-repeat 50% 50%;
  background-size: 1em;
  font-size: 12px;
  vertical-align: -1px;
  transform: rotate(180deg);
}

/* 新UIに完全移行してHTML側も改修したら不要 */
.mod-areaPrefSelector .backToArea .ui-icon,
.mod-areaPrefSelector .backToPref .ui-icon {
  display: none;
}

/* = areaSelector
----------------------------------------------- */
.mod-areaPrefSelector .areaSelector {
  margin: 10px;
}

.mod-areaPrefSelector .areaSelector .areaList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.mod-areaPrefSelector .areaSelector .areaList .listItem {
  width: calc(50% - 5px);
}

.mod-areaPrefSelector .areaSelector .areaList .listItem:nth-child(n+3) {
  margin-top: 10px;
}

.mod-areaPrefSelector .areaSelector .areaList .item {
  display: block;
  padding: 16px 10px;
  border-radius: 4px;
  font-weight: bold;
  text-align: center;
}

.mod-areaPrefSelector .areaSelector .areaList .item:not(.zero) {
  color: #ed6103;
  background-color: #fff;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  text-decoration: none;
}

.mod-areaPrefSelector .areaSelector .areaList .item.zero {
  color: #a5a5a5;
  background-color: #ebebeb;
}

/* 新UIに完全移行してHTML側も改修したら不要 */
.mod-areaPrefSelector .areaSelector .areaList .icon {
  display: none;
}

/* = currentPoint
----------------------------------------------- */
.mod-areaPrefSelector .currentPoint {
  margin-top: 10px;
  margin-bottom: 16px;
}

.mod-areaPrefSelector .currentPoint .anchor {
  display: table;
  table-layout: fixed;
  width: 100%;
  border-radius: 4px;
  color: #ed6103;
  background-color: #fff;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  font-weight: bold;
  text-decoration: none;
}

.mod-areaPrefSelector .currentPoint .anchor .name {
  display: table-cell;
  padding: 1em 10px;
}

.mod-areaPrefSelector .currentPoint .anchor .currentPointIcon {
  display: table-cell;
  vertical-align: middle;
  width: 32px;
  padding-left: 10px;
}

/* = prefSelector
----------------------------------------------- */
.mod-areaPrefSelector .prefSelector {
  margin: 20px 10px 10px;
}

.mod-areaPrefSelector:not(.pref) .prefSelector {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  visibility: hidden;
  margin: 10px 10px 16px;
  height: 0;
  transform: translateX(100%);
  transition: transform 0.2s;
}

.mod-areaPrefSelector:not(.pref) .prefSelector.is-selected {
  position: static;
  visibility: visible;
  height: auto;
  transform: none;
}

.mod-areaPrefSelector .prefSelector .prefList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.mod-areaPrefSelector .prefSelector .prefList .listItem {
  width: calc(50% - 5px);
}

.mod-areaPrefSelector .prefSelector .prefList .listItem:nth-child(n+3) {
  margin-top: 10px;
}

.mod-areaPrefSelector .prefSelector .prefList .item {
  display: block;
  padding: 16px 10px;
  border-radius: 4px;
  font-weight: bold;
  text-align: center;
}

.mod-areaPrefSelector .prefSelector .prefList .item:not(.zero) {
  color: #ed6103;
  background-color: #fff;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  text-decoration: none;
}

.mod-areaPrefSelector .prefSelector .prefList .item.zero {
  color: #a5a5a5;
  background-color: #ebebeb;
}

/* 新UIに完全移行してHTML側も改修したら不要 */
.mod-areaPrefSelector .prefSelector .prefList .icon {
  display: none;
}

/* = searchTypeSelector
----------------------------------------------- */
.mod-areaPrefSelector .searchTypeSelector {
  margin: 20px 10px 16px;
}

.mod-areaPrefSelector:not(.searchtype) .searchTypeSelector {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  visibility: hidden;
  height: 0;
  margin: 10px 10px 16px;
  transform: translateX(100%);
  transition: transform 0.2s;
}

.mod-areaPrefSelector:not(.searchtype) .searchTypeSelector.is-selected {
  position: static;
  visibility: visible;
  height: auto;
  transform: none;
}

/* list表示 */
.mod-areaPrefSelector .searchTypeSelector .searchTypeList {
  margin-top: 10px;
}

.mod-areaPrefSelector .searchTypeSelector .searchTypeList .listItem {
  margin-top: 10px;
}

/* table表示 */
.mod-areaPrefSelector .searchTypeSelector .searchTypeTable {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.mod-areaPrefSelector .searchTypeSelector .searchTypeTable .listItem {
  width: calc(50% - 5px);
}

.mod-areaPrefSelector .searchTypeSelector .searchTypeTable .listItem:nth-child(n+3) {
  margin-top: 10px;
}

.mod-areaPrefSelector .searchTypeSelector .searchTypeTable .listItem.Col2 {
  width: 100%;
}

/* 検索方法リンクボタン */
.mod-areaPrefSelector .searchTypeSelector .anchor {
  /* ここから ui-btn の打ち消し */
  padding: 0;
  border: 0;
  background: none;
  text-shadow: none;
  /* ここまで ui-btn の打ち消し */
  display: flex;
  align-items: center;
  border-radius: 4px;
  color: #ed6103;
  background-color: #fff;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  font-weight: bold;
  text-decoration: none;
}

.mod-areaPrefSelector .searchTypeSelector .anchor::before {
  content: "";
  display: block;
  flex: 0 0 50px;
  min-height: 60px;
  border-radius: 4px 0 0 4px;
  background: no-repeat 50% 50%/50px;
}

.mod-areaPrefSelector .searchTypeSelector .anchor--line::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_line.png?v=8f3f5bd87838dd84d2c23056c4d426eb');
}
.mod-areaPrefSelector .searchTypeSelector .anchor--line_newIcon::before {
  min-height: 62px;
  background-color: #fff8eb;
  background-image: url('https://icon.lifull.com/lh/train-twotone');
  background-size: 32px;
}

.mod-areaPrefSelector .searchTypeSelector .anchor--city::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_city.png?v=6b177c8fb0079cc0539c906393ac555e');
}
.mod-areaPrefSelector .searchTypeSelector .anchor--city_newIcon::before {
  min-height: 62px;
  background-color: #fff8eb;
  background-image: url('https://icon.lifull.com/lh/japan-map-twotone');
  background-size: 32px;
}

.mod-areaPrefSelector .searchTypeSelector .anchor--map::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_map.png?v=5a0b8c44860f511a0a2f9740dc29cb30');
}
.mod-areaPrefSelector .searchTypeSelector .anchor--map_newIcon::before {
  min-height: 62px;
  background-color: #fff8eb;
  background-image: url('https://icon.lifull.com/lh/paper-map-pin-twotone');
  background-size: 32px;
}

.mod-areaPrefSelector .searchTypeSelector .anchor--commute::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_commute.png?v=9e65763f858083db703ec1268eeed780');
}
.mod-areaPrefSelector .searchTypeSelector .anchor--commute_newIcon::before {
  min-height: 62px;
  background-color: #fff8eb;
  background-image: url('https://icon.lifull.com/lh/clock-3-oclock-twotone');
  background-size: 32px;
}

.mod-areaPrefSelector .searchTypeSelector .anchor--loan::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_loan.png?v=de252fd72aa8cc98481e524d99c1f14b');
}

.mod-areaPrefSelector .searchTypeSelector .anchor--ltagflow::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_ltagflow.png?v=aa12bbe333c751e9777bc738698217be');
}

.mod-areaPrefSelector .searchTypeSelector .anchor--imayoriflow::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_imayoriFlow.png?v=2b1d6f7087efdd652d83e77108e0ef71');
}

.mod-areaPrefSelector .searchTypeSelector .anchor--imayoriArchiveflow::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_imayoriArchiveFlow.png?v=bb01ebc7fda39da1229ff120eff12bbb');
}

.mod-areaPrefSelector .searchTypeSelector .anchor--schoolDistrict::before {
  background-image: url('/smp/assets/img/smartphone/module/areaPrefSelector/thumb_schoolDistrict.png?v=d6d6e915cd0222f2bcdd081704b74429');
}

.mod-areaPrefSelector .searchTypeSelector .anchor .text {
  flex: 0 1 100%;
  padding: 10px;
  line-height: 1.3;
  font-size: 0.875em;
}

@media only screen and (max-width: 339px) {
  .mod-areaPrefSelector .searchTypeSelector .anchor .text {
    font-size: 0.75em;
  }
}
/* 新UIに完全移行してHTML側も改修したら不要 */
.mod-areaPrefSelector .searchTypeSelector .anchor .icon {
  display: none;
}

.mod-areaPrefSelector:has(div.is-hide) ~ .kodateBannerBottom .mod-kodateAdviserBanner {
  padding-top: 8px;
}
@charset "UTF-8";
/* = mod-themeList
----------------------------------------------- *
 *
----------------------------------------------- */
.mod-themeList {
  background-color: #fff;
  overflow: hidden;
}

.mod-themeList .heading {
  font-size: 16px;
  color: #ed6103;
  margin-top: 24px;
  margin-left: 10px;
  margin-bottom: 12px;
}

.mod-themeList .themeList {
  margin-bottom: -1px;
  border-bottom: 1px solid #c4c4c4;
}

.mod-themeList .themeList:first-of-type:not(:only-of-type) {
  margin-bottom: 0;
}

.mod-themeList .listItem:not(:first-child) {
  border-top: 1px solid #c4c4c4;
}

.mod-themeList .listItem .title {
  font-weight: normal;
}

/* もっと見る：開閉 */
.mod-themeList .more {
  -webkit-appearance: none;
  box-sizing: border-box;
  display: block;
  width: calc(100% - 14px);
  margin: 7px;
  padding: 14px;
  border: 1px dotted #c4c4c4;
  line-height: 1;
  color: inherit;
  background-color: #fff;
  font-size: 1em;
  text-align: center;
  text-decoration: none;
}

/* もっと見る：遷移 */
.mod-themeList .goto {
  border-top: 1px solid #c4c4c4;
  text-align: right;
}

.mod-themeList .goto .anchor {
  display: block;
  padding: 0.87rem 0.43rem;
  color: inherit;
  background-color: #fff;
  text-decoration: none;
  font-size: 1rem;
}

/* もっと見る：遷移の追加　（賃貸LPのみの対応） */
.mod-themeList .hidelist {
  border-top: 1px solid #c4c4c4;
}

.mod-themeList .listItem.goto {
  border-bottom: none;
  border-top: 1px solid #c4c4c4;
}
@charset "UTF-8";
/* = mod-banner
----------------------------------------------- *
 * バナー
 *
 * 使用箇所：マドリームバナー（LP、reTop（前回検索条件で賃貸の時のみ）、賃流会社詳細）
 *             L mod-bannerMadream.html.twig
 *             L mod-bannerMadreamRealtor.html.twig
 *         Gomezバナー（賃貸　各LP　※賃貸TOP、物件種別、広域、都道府県、政令指定都市、市区、駅のみ）
 *             L mod-bannerGomez.html.twig
 *         マンスリーサイトバナー（賃貸TOP、マンスリーマンションテーマTOPのみ）
 *             L mod-bannerMonthly.html.twig
 *             L mod-bannerMonthlyPr.html.twig
----------------------------------------------- */
.mod-banner {
  margin: 0.87rem 0.43rem;
  text-align: center;
}

/* = mod-banner-madoguchi
----------------------------------------------- *
 * Madoguchi banner styling
 *
 * Usage: Madoguchi consultation banner
----------------------------------------------- */
.mod-banner.mod-banner-madoguchi {
  margin: 0 10px 20px 10px;
}

.mod-banner.mod-banner-madoguchi img {
  width: 100%;
}

/*
----------------------------------------------- *
 * レビュー投稿キャンペーン
 *
 * 使用箇所：新築マンション広域エリアTOP, 都道府県TOP
----------------------------------------------- */
.visitorBannerText {
  text-align: right;
  margin-top: 10px;
}

/* = banner-daily3updatesFlow
----------------------------------------------- *
 * CTUXUV5DE-10569 繁忙期対応（埋まっちゃうかも訴求）
 *
 * 使用箇所：賃貸トップ、賃貸都道府県トップ
----------------------------------------------- */
.banner-daily3updatesFlow {
  margin: 16px 10px;
  margin-top: 0px;
  text-align: center;
}

.banner-daily3updatesFlow img {
  width: 100%;
  height: auto;
  max-width: 414px;
  max-height: 70px;
}
.mod-topicRelatedArticles {
  margin: 10px 10px 25px 10px;
}

.mod-topicRelatedArticles > .heading {
  margin: -2px 0 13px 0;
  font-size: 14px;
  line-height: 20px;
  font-weight: bold;
}

.mod-topicRelatedArticles .listItem {
  margin-top: 8px;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.3019607843);
  border-radius: 4px;
}

.mod-topicRelatedArticles .listItem a {
  border-radius: 4px;
}

.mod-topicRelatedArticles .listItem .photo {
  border-radius: 4px 0px 0px 4px;
}

.mod-topicRelatedArticles .listItem .photo img {
  object-fit: cover;
  border-radius: 4px 0px 0px 4px;
  box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.3019607843);
}

.mod-topicRelatedArticles .listItem .title {
  line-height: 20px;
  display: table-cell;
  padding: 8px 10px 12px 10px;
  vertical-align: middle;
  font-size: 14px;
  width: 100%;
}
