@charset "utf-8";@charset "UTF-8";
/* mod-expansionPanelに統合されるまでの暫定処置 */
.mod-categorizedTheme + .mod-expansionPanel,
.mod-sortingLinkBox + .mod-expansionPanel {
  border-top-width: 0;
}

/* = mod-expansionPanel
----------------------------------------------- *
 * 開閉型パネル
----------------------------------------------- */
.mod-expansionPanel {
  font-size: 14px;
  border-top: 1px solid #d8d8d8;
  border-bottom: 1px solid #d8d8d8;
  background-color: #fff;
}

.mod-expansionPanel + .mod-expansionPanel {
  border-top-width: 0;
}

.mod-expansionPanel__trigger {
  -webkit-appearance: none;
  appearance: none;
  display: block;
  width: 100%;
  padding: 0;
  border-width: 0;
  background-color: transparent;
  font-size: inherit;
  color: inherit;
}

.mod-expansionPanel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 2.5em;
  padding: 6px 10px;
}

.mod-expansionPanel__header::after {
  content: "";
  width: 1em;
  height: 1em;
  margin-left: 10px;
  background: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22120%22%20height%3D%22120%22%20viewBox%3D%220%200%20120%20120%22%3E%3Cg%20fill%3D%22%236c6c6c%22%3E%3Cpath%20d%3D%22M99.6%2C46.9l-4.2-4.2c-1.6-1.6-4.1-1.6-5.7%2C0l-26.9%2C26.8c-1.6%2C1.6-4.1%2C1.6-5.7%2C0l-26.8-26.8c-1.6-1.6-4.1-1.6-5.7%2C0l-4.2%2C4.2c-1.6%2C1.6-1.6%2C4.1%2C0%2C5.7l36.8%2C36.8c.8.8%2C1.8%2C1.2%2C2.8%2C1.2%2C1%2C0%2C2.1-.4%2C2.8-1.2l36.8-36.8c1.6-1.6%2C1.6-4.1%2C0-5.7z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat 50% 50%;
  background-size: 1em;
}

.mod-expansionPanel__trigger[aria-expanded=true] .mod-expansionPanel__header::after {
  transform: rotate(180deg);
}

.mod-expansionPanel__header_title {
  line-height: 1.3;
  font-weight: bold;
  text-align: left;
}

.mod-expansionPanel__body {
  padding: 0 10px 10px;
}

.mod-expansionPanel__body[hidden] {
  display: none;
}
@charset "UTF-8";
/* = mod-inlineLinkList
----------------------------------------------- *
 * inline style link list
----------------------------------------------- */
.mod-inlineLinkList {
  font-size: 12px;
  overflow: hidden;
}

.mod-inlineLinkList:not(:first-child) {
  margin-top: 20px;
}

/* リスト */
.mod-inlineLinkList__list {
  line-height: 2;
  margin: 0 -8px;
  display: flex;
  flex-wrap: wrap;
}

.mod-inlineLinkList__listTitle {
  width: 100%;
  font-weight: bold;
  padding: 0 8px;
  box-sizing: border-box;
}

.mod-inlineLinkList__listItem {
  position: relative;
  padding: 0 8px;
}

.mod-inlineLinkList__listItem::before {
  content: "";
  display: block;
  width: 1px;
  height: 12px;
  background-color: #000;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto 0;
}

/* 全て見る的なリンク */
.mod-inlineLinkList__generalLink {
  line-height: 2;
}

/* anchor */
.mod-inlineLinkList__listItem_anchor,
.mod-inlineLinkList__generalLink_anchor {
  display: inline-block;
}

.mod-inlineLinkList__listItem_anchor:link,
.mod-inlineLinkList__listItem_anchor:visited,
.mod-inlineLinkList__generalLink_anchor:link,
.mod-inlineLinkList__generalLink_anchor:visited {
  text-decoration: none;
  color: inherit;
}

/* noAnchor */
.mod-inlineLinkList__listItem_noAnchor {
  display: inline-block;
  color: #a5a5a5;
}
@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-contentsHeader
----------------------------------------------- *
 * ページ見出し
----------------------------------------------- */
.mod-contentsHeader {
  font-size: 1rem;
}

.mod-contentsHeader .header {
  margin: 10px;
  line-height: 1.4;
}

.mod-contentsHeader .header .heading {
  font-size: 1.125em;
  font-weight: bold;
}

.mod-contentsHeader .header .note {
  font-size: 0.75em;
  padding: 5px 0 10px;
}

/* theme,keyword等、headingTextがないときには上下にborderを挿入 */
.mod-contentsHeader .lead {
  margin: 0;
  padding: 0.857em 10px;
  font-size: 0.875em;
  border: solid #d8d8d8;
  border-width: 1px 0;
}

.mod-contentsHeader .header + .lead {
  margin: 0.5em 0;
  padding: 0 10px;
  border: none;
}
@charset "UTF-8";
/* = mod-stationSelector
----------------------------------------------- *
 * 駅選択チェックボックスリスト
----------------------------------------------- */
.mod-stationSelector {
  font-size: 16px;
  margin: 20px 0;
}

.mod-stationSelector .leadText {
  margin: 20px 10px;
  font-size: 0.875em;
}

.mod-stationSelector .stationGroup {
  margin: 20px 10px;
}

.mod-stationSelector .stationGroup .heading {
  margin: 10px 0;
  font-weight: bold;
}

.mod-stationSelector .stationGroup .heading .number {
  font-size: 0.8125em;
  font-weight: normal;
}

.mod-stationSelector .stationList {
  margin: 10px 0;
  border-radius: 4px;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  overflow: hidden;
}

.mod-stationSelector .stationList .stationItem:not(:first-child) {
  border-top: 1px solid #d8d8d8;
}

.mod-stationSelector .stationItem .station,
.mod-stationSelector .checkAllStation .station {
  display: table;
  table-layout: fixed;
  width: 100%;
}

.mod-stationSelector .stationItem:not(:first-child) .station,
.mod-stationSelector .checkAllStation:not(:first-child) .station {
  border-top: 1px solid #fff;
}

.mod-stationSelector .stationItem:not(:last-child) .station,
.mod-stationSelector .checkAllStation:not(:last-child) .station {
  border-bottom: 1px solid #fff;
}

.mod-stationSelector .stationItem .station.is-disabled {
  color: #a5a5a5;
}

.mod-stationSelector .stationItem .station .label,
.mod-stationSelector .checkAllStation .station .label {
  display: table-row;
}

.mod-stationSelector .stationItem .station .checkbox,
.mod-stationSelector .checkAllStation .station .checkbox {
  box-sizing: border-box; /* Android 4.2 Browser Bug 対策: 本来は `content-box` */
  display: table-cell;
  width: 3em; /* Android 4.2 Browser Bug 対策: `content-box` であれば `1.5em` */
  padding: 0.75em;
  background-color: #dedede;
}

.mod-stationSelector .stationItem .station .stationName,
.mod-stationSelector .checkAllStation .station .stationName {
  display: table-cell;
  padding: 0.5em 0.75em;
  vertical-align: middle;
  background-color: #fff;
}

.mod-stationSelector .checkAllStation .station .stationName {
  font-weight: bold;
}

.mod-stationSelector .stationItem .station .stationName .number,
.mod-stationSelector .checkAllStation .station .stationName .number {
  font-size: 0.8125em;
  font-weight: normal;
}

.mod-stationSelector .stationItem .station .stationStatus {
  box-sizing: border-box; /* Android 4.2 Browser Bug 対策: 本来は `content-box` */
  display: table-cell;
  width: 2.1em; /* Android 4.2 Browser Bug 対策: `content-box` であれば `1.6em` */
  padding-right: 5px;
  background-color: #fff;
  font-size: 0.75em;
  text-align: center;
  vertical-align: middle;
}

.mod-stationSelector .stationItem .station .stationStatus:last-child {
  width: 2.5em; /* Android 4.2 Browser Bug 対策: `content-box` であれば不要 */
  padding-right: 10px;
}

.mod-stationSelector .station .stationName a {
  text-decoration: none;
  color: inherit;
}

/* アイコン */
.mod-stationSelector .icon-express,
.mod-stationSelector .icon-terminus {
  display: inline-block;
  width: 1em;
  height: 1em;
  padding: 0.2em 0.2em 0.1em;
  border: 1px solid;
  background-color: #fff;
}

.mod-stationSelector .icon-express {
  color: #ed6103;
}

.mod-stationSelector .icon-terminus {
  color: #397db2;
}

.mod-stationSelector .icon-express abbr,
.mod-stationSelector .icon-terminus abbr {
  text-decoration: none;
}

/* 注釈 */
.mod-stationSelector .annotation {
  margin: 20px 10px;
}

.mod-stationSelector .annotation dl {
  margin-bottom: 0.5em;
  font-size: 0.875em;
}

.mod-stationSelector .annotation dt,
.mod-stationSelector .annotation dd {
  display: inline;
}

.mod-stationSelector .annotation dd + dt {
  margin-left: 1em;
}

.mod-stationSelector .annotation dd {
  font-weight: bold;
}

.mod-stationSelector .annotation .caution {
  line-height: 1.5;
  font-size: 0.75em;
}

/* checkbox */
.mod-stationSelector input[type=checkbox] {
  /* ui-checkboxの上書き */
  box-shadow: none;
  /* 設定 */
  -webkit-appearance: none;
  appearance: none;
  width: 1.5em;
  height: 1.5em;
  margin: 0;
  border: 2px solid #a5a5a5;
  border-radius: 2px;
  background: #fff;
  font-size: 1em;
  vertical-align: bottom;
  cursor: pointer;
}

.mod-stationSelector input[type=checkbox]:checked {
  border-color: #ed6103;
  background: #ed6103 url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22120%22%20height%3D%22120%22%20viewBox%3D%220%200%20120%20120%22%3E%3Cpath%20fill%3D%22%23fff%22%20d%3D%22M110.8%2C8.6c-31.6%2C16.2-54%2C67.7-54%2C67.7l-20.9-19-25.5%2C15.4c10.8%2C3.9%2C34.8%2C16.2%2C47.9%2C32.4%2C9.3-17%2C39.2-52.1%2C53.1-55.2.1-16%2C0-27.9-.6-41.3z%22%2F%3E%3C%2Fsvg%3E') no-repeat 50% 50%;
  background-size: 1.35em; /* 0.75 * 1.8em */
}

.mod-stationSelector input[type=checkbox]:disabled {
  border-color: #d8d8d8;
  background: #ebebeb;
  cursor: default;
}
@charset "UTF-8";
/* = mod-fixedButtonArea
----------------------------------------------- *
 * 下部固定ボタン
----------------------------------------------- */
.mod-fixedButtonArea {
  font-size: 0.62rem;
  margin: 20px 0;
  background-color: rgba(204, 204, 204, 0.85);
  text-align: center;
}

/* 下部固定用class */
.mod-fixedButtonArea.is-fixed {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 1;
  margin: 0;
}

/* inactive時は非表示 */
.mod-fixedButtonArea.is-fixed.is-inactive {
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
}

/* active時animationで表示 */
.mod-fixedButtonArea.is-fixed.is-active {
  -webkit-transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

.mod-fixedButtonArea .itemGroup {
  font-size: 16px;
  display: table;
  table-layout: fixed;
  border-spacing: 10px;
  width: 100%;
}

.mod-fixedButtonArea .itemGroup .itemTxt {
  display: table-cell;
  font-size: 0.875em;
  text-align: left;
  vertical-align: middle;
}

.mod-fixedButtonArea .itemTxt .num {
  display: inline-block;
  padding: 0.25em 0.25em 0 0;
  font-size: 1.5em;
}

.mod-fixedButtonArea .itemGroup .itemBtn {
  display: table-cell;
  padding: 0;
}

.mod-fixedButtonArea .itemGroup .itemTxt + .itemBtn {
  width: 60%;
}

.mod-fixedButtonArea .itemBtn .button {
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
  display: block;
  width: 100%;
  padding: 0.75em 10px;
  border: 0;
  border-radius: 4px;
  line-height: 1;
  color: #ed6103;
  background: #fff;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  font-size: 1.25em;
  font-weight: bold;
  text-decoration: none;
}

.mod-fixedButtonArea .itemBtn .button.disabled {
  color: #a5a5a5;
  background-color: #ebebeb;
  box-shadow: none;
  pointer-events: none;
}

@media only screen and (max-width: 349px) {
  .mod-fixedButtonArea .itemBtn .button {
    font-size: 1em;
  }
}
@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%;
}
