﻿@charset "utf-8";

/*==================================================
  GENERAL SETTINGS
==================================================*/
.indexWire {
  max-width: var(--width-content);
  width: 100%;
  margin: 0 auto;
}

.btn_archive {
  text-align: center;
}

.btn_archive a {
  display: block;
  width: 90%;
  max-width: 400px;
  margin: 0 auto;
  background: #fff;
  padding: 1.1em 0;
  font-size: clamp(1.6rem, 2vw, 2.2rem);
  font-weight: 700;
  letter-spacing: .05em;
  line-height: 1;
  text-decoration: none;
  border-radius: var(--rad-full);
  filter: drop-shadow(0 .2em .2em rgba(0, 0, 0, 0.15));
  position: relative;
}

.btn_archive a::after {
  position: absolute;
  content: '';
  width: 1.5em;
  height: 1.5em;
  background: var(--color-main) url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.33%22%20height%3D%2217.103%22%20viewBox%3D%220%200%209.33%2017.103%22%3E%3Cpath%20d%3D%22M56.871%2C81.1a.777.777%2C0%2C0%2C1-1.1%2C0l-7.224-7.225L41.323%2C81.1a.778.778%2C0%2C0%2C1-1.1-1.1L48%2C72.222a.777.777%2C0%2C0%2C1%2C1.1%2C0L56.871%2C80a.777.777%2C0%2C0%2C1%2C0%2C1.1Z%22%20transform%3D%22translate(81.323%20-39.996)%20rotate(90)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E') no-repeat left 53% center / auto 50%;
  border-radius: var(--rad-full);
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  transition: .3s;
}

@media (any-hover:hover) {
  .btn_archive a:hover {
    opacity: 1;
    background: var(--color-main);
    color: #fff;
  }

  .btn_archive a:hover::after {
    right: .25em
  }
}

/*==================================================
  TITLE COMMON
==================================================*/
.index__ttl {
  font-size: clamp(2.4rem, 5.4vw, 4.2rem);
  font-weight: 700;
  letter-spacing: .05em;
  position: relative;
  padding: 1.5em 0 .25em;
  text-align: center;
}

.index__ttl::after {
  content: "";
  display: block;
  width: 25px;
  height: 5px;
  background: url(../img/index/ttl_dot.svg) no-repeat center / contain;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}


/*
===== SLIDER ==========================================
*/
.indexmainBox {
  height: 42vw;
  max-height: 500px;
  margin-bottom: var(--gutter-narrow);
  overflow: hidden;
}

.indexmainBox:has(.slick-list) {
  height: calc(42vw + 30px);
  max-height: 530px;
  overflow: visible;
}

.indexmainBox .slick-list.draggable {
  width: 100%;
}

.indexmainBox__wrap {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: center;
  vertical-align: middle;
}

.indexmainSlider {
  height: 42vw;
  max-height: 500px;
  overflow: hidden;
}

/*dots*/
.indexmainBox .slick-dots {
  bottom: -8%;
}

.slick-dots li,
.slick-dots li button {
  width: 16px !important;
  height: 16px !important;
}

.slick-dots li button:before {
  content: "" !important;
  width: 13px !important;
  height: 13px !important;
  border-radius: 8px;
  opacity: 1 !important;
  border: 1px solid var(--color-main);
}

.slick-dots li.slick-active button:before {
  background: var(--color-main);
}

.slick-dots li button:before {
  background: #fff;
}

.slick-list.draggable {
  overflow: hidden;
  margin: 0 auto;
}

/*
===== BANNER ==========================================
*/
.bannerWrap {
  text-align: center;
  margin: var(--gutter) auto;
  max-width: var(--width-content);
}

.bannerBox {
  margin-bottom: 20px;
}


/*
===== PURPOSE ==========================================
*/
.purposeWrap {
  margin: var(--gutter) auto;
  display: flex;
  gap: clamp(5px, 1.8vw, 20px);
}

.purposeBox {
  border: 1px solid var(--color-main);
  border-radius: 5px;
  width: calc((100% - clamp(5px, 1.8vw, 20px)) / 4);
}

.purposeBox__head {
  background: var(--color-main);
  color: #fff;
  font-size: clamp(1.4rem, 1.6vw, 2rem);
  padding: 0.15em 0 0.25em;
  text-align: center;
}

.purposeBox__head__em {
  font-size: 1.4em;
}

.purposeBox__item {
  margin: 1em 0;
}

.purposeBox .btn_archive a {
  font-size: clamp(1.2rem, 1.4vw, 1.4rem);
  padding: 1.2em 0;
}

.purposeBox .btn_archive a[target="_blank"]::before {
  content: "";
  width: 1em;
  height: 1em;
  margin-right: .5em;
  margin-left: -.5em;
  display: inline-block;
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cg%20transform%3D%22translate(-13%20-11)%22%3E%3Cpath%20d%3D%22M27%2C12h9v9%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3Cpath%20d%3D%22M32%2C26v8H14V16h8%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3Cline%20y1%3D%2211%22%20x2%3D%2211%22%20transform%3D%22translate(24%2013)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat center / contain;
  opacity: .8;
}

.purposeBox .btn_archive a[target="_blank"]:hover::before {
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cg%20transform%3D%22translate(-13%20-11)%22%3E%3Cpath%20d%3D%22M27%2C12h9v9%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3Cpath%20d%3D%22M32%2C26v8H14V16h8%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3Cline%20y1%3D%2211%22%20x2%3D%2211%22%20transform%3D%22translate(24%2013)%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat center / contain;
}

/*売りたい*/
.purposeBox--sell {
  border-color: var(--color-orange);
}

.purposeBox--sell .purposeBox__head,
.purposeBox--sell .btn_archive a::after {
  background-color: var(--color-orange);
}

.purposeBox--sell .purposeBox__item {
  text-align: center;
}

.purposeBox--sell .purposeBox__fukidashi {
  display: inline-block;
  text-align: center;
  font-weight: 600;
  margin-bottom: 1em;
  position: relative;
}

.purposeBox--sell .purposeBox__fukidashi::before,
.purposeBox--sell .purposeBox__fukidashi::after {
  content: "";
  display: block;
  width: 1px;
  height: 60%;
  background: var(--color-black);
  position: absolute;
  bottom: 0;
}

.purposeBox--sell .purposeBox__fukidashi::before {
  left: -1em;
  transform: rotate(-30deg);
}

.purposeBox--sell .purposeBox__fukidashi::after {
  right: -1em;
  transform: rotate(30deg);
}

/*建てたい*/
.purposeBox--build {
  border-color: var(--color-purple);
}

.purposeBox--build .purposeBox__head,
.purposeBox--build .btn_archive a::after {
  background-color: var(--color-purple);
}

/*リノベしたい*/
.purposeBox--re {
  border-color: var(--color-green);
}

.purposeBox--re .purposeBox__head,
.purposeBox--re .btn_archive a::after {
  background-color: var(--color-green);
}

.purposeBox--re .purposeBox__logo {
  margin: 1.5em 1em;
}

@media (any-hover:hover) {
  .purposeBox--sell .btn_archive a:hover {
    background-color: var(--color-orange);
  }

  .purposeBox--build .btn_archive a:hover {
    background-color: var(--color-purple);
  }

  .purposeBox--re .btn_archive a:hover {
    background-color: var(--color-green);
  }
}

/*
===== EVENTBOX ==========================================
*/

.eventBox {
  margin: var(--gutter-wide) 0;
}

.eventBox__ttlWrap {
  background: var(--color-paleblue);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 400px;
  aspect-ratio: 2 / 1;
  border-radius: 100vh 100vh 0 0;
  margin: 0 auto;
  padding-bottom: 30px;
}

.eventBox__ttl {
  text-align: center;
}

.eventBox__ttl::before {
  content: "";
  display: block;
  width: .9em;
  height: .9em;
  background: url(../img/common/icon_flag.svg) no-repeat center / contain;
  position: absolute;
  top: .5em;
  left: 50%;
  transform: translateX(-50%);
}

.eventBox__inner {
  background: var(--color-paleblue);
  padding: var(--gutter) 0;
  margin-top: -30px;
}

.eventBox__inner .slick-initialized {
  min-height: 200px;
}

.eventBox__list {
  width: 100%;
  margin: 0 auto;
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-wrap: nowrap;
  /* Safari */
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  position: relative;
  gap: clamp(10px, 3vw, 30px);
}

.eventBox__item {
  width: calc((100% - 60px) / 3);
  max-width: 380px;
  position: relative;
  margin: 0 10px;
}

.eventBox__item a {
  display: block;
  width: 100%;
  height: calc(100% - 80px);
  text-decoration: none;
  background: #fff;
  border-radius: 5px;
  margin-top: 80px;
}

.eventBox__photo {
  aspect-ratio: 3/ 2;
  overflow: hidden;
  border-radius: 5px 5px 0 0;
}

.eventBox__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.eventBox__detail {
  padding: 10px;
}

.eventBox__iconWrap span {
  min-width: 50px;
  padding: .5em;
}

.eventBox .icon_reservable {
  display: inline-block;
  width: 124px;
  aspect-ratio: 248 / 126;
  position: absolute;
  top: 0;
  left: 48%;
  transform: translateX(-52%);
}

.eventBox__itemTtl {
  text-align: left;
  font-size: 1.2em;
  font-weight: bold;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.eventBox__date {
  margin: 5px 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.eventBox__intro {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.eventBox__btn {
  margin-top: 50px;
}

/*Slider*/
.eventBox .slick-dots {
  bottom: -40px;
}

.eventBox:has(.slick-dots) .eventBox__btn {
  margin-top: 80px;
}

/*
===== SEARCHBOX ==========================================
*/
.searchBox__ttl {
  text-align: center;
  margin-bottom: 30px;
}

.searchBox__ttl::before {
  content: "";
  display: block;
  width: .9em;
  height: .9em;
  background: url(../img/common/icon_search.svg) no-repeat center / contain;
  position: absolute;
  top: .5em;
  left: 50%;
  transform: translateX(-50%);
}

.estateCountBox {
  background: rgba(255, 255, 255, .8);
}

.estateCountBox__totalBox {
  padding: 0 40px 20px;
}

.estateCountBox__totalWrap {
  display: flex;
  justify-content: center;
  align-items: center;
}

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

.estateCountBox__totalTtl {
  font-size: 16px;
  margin-right: 8px;
}

.estateCountBox__totalNumBox {
  font-size: 20px;
  font-weight: bold;
}

.estateCountBox__num {
  line-height: 1;
  font-family: var(--font-num);
  font-weight: 700;
}

.estateCountBox__totalNumBox .estateCountBox__num {
  font-size: clamp(50px, 10vw, 72px);
  color: var(--color-main);
}

.estateCountBox__detailBox {
  border-top: 1px solid var(--color-black);
  margin: 0 18px;
  padding: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.estateCountBox__detailWrap {
  display: flex;
  justify-content: space-between;
  -webkit-align-items: center;
  align-items: center;
  margin-bottom: 10px;
}

.estateCountBox__detailWrap:not(:first-child) {
  margin-left: 20px;
}

.estateCountBox__detailNumBox {
  font-weight: 500;
}

.estateCountBox__detailNumBox .estateCountBox__num {
  font-size: 24px;
  margin: 0 5px;
}

.estateCountBox__detailWrap--member .estateCountBox__num {
  color: var(--color-main);
}

.estateCountBox__detailWrap--shop .estateCountBox__num {
  color: var(--color-green);
}

.estateCountBox__btn {
  max-width: 480px;
  margin: 0 auto;
  color: #fff;
  display: flex;
  align-items: stretch;
  text-align: center;
  font-weight: 500;
  line-height: 1.2;
  border-radius: 3px;
  position: relative;
  border: 2px solid var(--color-main);
  background: var(--color-main);
  border-radius: var(--rad-full);
  overflow: hidden;
  position: relative;
}

.estateCountBox__btn__txt01 {
  background: #fff;
  color: var(--color-black);
  font-size: 16px;
  min-width: 84px;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: .3s;
}

.estateCountBox__btn__txt02 {
  font-size: clamp(1.6rem, 4.8vw, 2rem);
  width: calc(100% - 84px);
  padding: 1em 3em 1em 1em;
  font-weight: bold;
}

.estateCountBox__btn__txt02 span {
  display: block;
  font-size: .75em;
  font-weight: normal;
  margin-bottom: 4px;
}

.estateCountBox__btn::after {
  position: absolute;
  content: '';
  width: 2.5em;
  height: 2.5em;
  background: #fff url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.33%22%20height%3D%2217.103%22%20viewBox%3D%220%200%209.33%2017.103%22%3E%3Cpath%20d%3D%22M56.871%2C81.1a.777.777%2C0%2C0%2C1-1.1%2C0l-7.224-7.225L41.323%2C81.1a.778.778%2C0%2C0%2C1-1.1-1.1L48%2C72.222a.777.777%2C0%2C0%2C1%2C1.1%2C0L56.871%2C80a.777.777%2C0%2C0%2C1%2C0%2C1.1Z%22%20transform%3D%22translate(81.323%20-39.996)%20rotate(90)%22%20fill%3D%22%23014099%22%2F%3E%3C%2Fsvg%3E') no-repeat left 53% center / auto 50%;
  border-radius: var(--rad-full);
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  transition: .3s;
}

@media (any-hover:hover) {
  .estateCountBox__btn:hover {
    opacity: 1;
    background: #fff;
    color: var(--color-main);
  }

  .estateCountBox__btn:hover::after {
    right: .25em;
  }

  .estateCountBox__btn:hover .estateCountBox__btn__txt01 {
    background: var(--color-main);
    color: #fff;
  }
}

/*ログイン・会員メニュー*/
.infoBox__loginBox__ttlBox {
  text-align: center;
}

.infoBox__loginBox__ttlBox__ttl {
  font-weight: bold;
  font-size: clamp(1.4rem, 1.6vw, 2rem);
  margin-bottom: 1em;
}

.infoBox__loginBox__ttlBox__txt {
  background: var(--color-palegray);
  padding: 1em;
}

.infoBox__loginBox__input {
  display: flex;
  align-items: center;
  width: 80%;
  margin: 10px auto;
}

.infoBox__loginBox__label {
  width: 6em;
  font-weight: bold;
  font-family: var(--font-en);
}

.infoBox__loginBox__btn {
  background-color: var(--color-orange);
  border: 2px solid var(--color-orange);
  border-radius: var(--rad-full);
  color: #fff;
  width: 100%;
  max-width: 310px;
  height: 70px;
  position: relative;
  margin: 2% auto;
  transition: .3s;
}

.infoBox__loginBox__btn::after {
  position: absolute;
  content: '';
  width: 2.2em;
  height: 2.2em;
  background: #fff url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.33%22%20height%3D%2217.103%22%20viewBox%3D%220%200%209.33%2017.103%22%3E%3Cpath%20d%3D%22M56.871%2C81.1a.777.777%2C0%2C0%2C1-1.1%2C0l-7.224-7.225L41.323%2C81.1a.778.778%2C0%2C0%2C1-1.1-1.1L48%2C72.222a.777.777%2C0%2C0%2C1%2C1.1%2C0L56.871%2C80a.777.777%2C0%2C0%2C1%2C0%2C1.1Z%22%20transform%3D%22translate(81.323%20-39.996)%20rotate(90)%22%20fill%3D%22%23ED6D00%22%2F%3E%3C%2Fsvg%3E') no-repeat left 53% center / auto 50%;
  border-radius: var(--rad-full);
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  z-index: 0;
  transition: .3s;
}

input[type="submit"].infoBox__loginBox__btn__input {
  width: 100%;
  height: 100%;
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  padding: 18px 0 16px;
  z-index: 1;
  position: relative;
}

@media (any-hover:hover) {
  .infoBox__loginBox__btn:hover {
    background: #fff;
    color: var(--color-orange);
  }

  .infoBox__loginBox__btn:hover::after {
    right: .25em;
  }
}

/*会員メニュー */
.infoBox__memberBox {
  width: 100%;
}

.infoBox__memberBox__ttl {
  font-weight: bold;
  text-align: center;
  margin-bottom: 0.5em;
  font-size: 2.4rem;
  color: var(--color-main);
}

.infoBox__memberBox__input {
  border-radius: 0;
  padding: 1em;
  transition: 0.3s;
  width: auto;
}

.infoBox__memberBox__input:hover {
  opacity: 0.7;
}

.infoBox__memberBox__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.infoBox__memberBox__name {
  margin-bottom: 15px;
  text-align: center;
}

.infoBox__memberBox__nameTxt {
  display: inline-block;
}

.infoBox__memberBox__menuList {
  width: 100%;
}

.infoBox__memberBox__btn {
  margin: 0 auto 15px;
}

.infoBox__memberBox__btn a {
  font-size: clamp(1.3rem, 1.6vw, 1.7rem);
  padding: 1.5em 1em 1.5em 0;
  background: var(--color-main);
  color: #fff;
}

.infoBox__memberBox__btn .btn_logout {
  width: 60%;
  border-radius: var(--rad-full);
}


@media (any-hover:hover) {}

/*
----- 検索条件BOX・地図 --------------------
*/
/*検索条件BOX*/
.searchBox__searchWrap {
  margin: var(--gutter-wide) auto;
  display: flex;
  justify-content: space-between;
}

.searchBox__option {
  width: 32%;
  max-width: 450px;
}

.searchBox__option__ttl {
  text-align: center;
  font-size: clamp(1.4rem, 1.6vw, 2rem);
  font-weight: bold;
  margin-bottom: 1em;
}

.searchBox__option .formWrap dl {
  display: flex;
  align-items: center;
  margin-bottom: 1em;
}

.searchBox__option .formWrap dl dt {
  width: 5em;
}

.searchBox__option .formWrap dl dd {
  width: calc(100% - 5em);
  padding-left: 10px;
}

.searchBox__option .formWrap dl dd input,
.searchBox__option .formWrap dl dd select {
  width: 100%;
  padding: 1em .5em;
}

.searchBox__option .formWrap dl dd select#price_to,
.searchBox__option .formWrap dl dd select#price_from {
  width: calc(50% - .5em);
}

.searchBox__option .formWrap .btnWrap {
  display: block;
  width: 90%;
  height: 70px;
  max-width: 400px;
  margin: var(--gutter-narrow) auto;
  background: #fff;
  font-size: clamp(1.6rem, 1.8vw, 2rem);
  font-weight: 700;
  letter-spacing: .05em;
  line-height: 1;
  text-decoration: none;
  border-radius: var(--rad-full);
  filter: drop-shadow(0 .2em .2em rgba(0, 0, 0, 0.15));
  color: var(--color-black);
  text-align: center;
  position: relative;
  transition: .3s;
}

.searchBox__option .formWrap .btnWrap::after {
  position: absolute;
  content: '';
  width: 1.5em;
  height: 1.5em;
  background: var(--color-main) url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.33%22%20height%3D%2217.103%22%20viewBox%3D%220%200%209.33%2017.103%22%3E%3Cpath%20d%3D%22M56.871%2C81.1a.777.777%2C0%2C0%2C1-1.1%2C0l-7.224-7.225L41.323%2C81.1a.778.778%2C0%2C0%2C1-1.1-1.1L48%2C72.222a.777.777%2C0%2C0%2C1%2C1.1%2C0L56.871%2C80a.777.777%2C0%2C0%2C1%2C0%2C1.1Z%22%20transform%3D%22translate(81.323%20-39.996)%20rotate(90)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E') no-repeat left 53% center / auto 50%;
  border-radius: var(--rad-full);
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  transition: .3s;
}

.searchBox__option .formWrap .btnWrap input {
  width: 100%;
  height: 100%;
  text-align: center;
  font-size: 20px;
  z-index: 1;
  position: relative;
  background: transparent;
  color: var(--color-black);
  transition: .3s;
}

@media (any-hover:hover) {
  .searchBox__option .formWrap .btnWrap:hover {
    background: var(--color-main);
    color: #fff;
  }

  .searchBox__option .formWrap .btnWrap:hover::after {
    right: .25em;
  }

  .searchBox__option .formWrap .btnWrap:hover input {
    color: #fff;
  }
}

/*地図*/
.searchBox__mapWrap {
  width: calc(68% - 40px);
  max-width: 750px;
}

.areasearchBox__tabList {
  width: 100%;
  height: 50px;
  overflow: hidden;
  display: flex;
  -webkit-flex-wrap: nowrap;
  /* Safari */
  flex-wrap: nowrap;
  -webkit-justify-content: flex-end;
  /* Safari */
  justify-content: flex-end;
  gap: 5px;
  padding: 0 20px;
}

.areasearchBox__tabItem {
  max-width: 200px;
  width: 25%;
  background-color: var(--color-palegray);
  color: var(--color-darkgray);
  font-size: 1.4rem;
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 1.25em 5px;
  border-radius: 1rem 1rem 0 0;
  transition: .3s;
  position: relative;
  top: 5px;
}

@media (any-hover:hover) {
  .areasearchBox__tabItem:hover {
    background-color: var(--color-main);
    color: #fff;
    cursor: pointer;
    opacity: 0.7;
    top: 0;
  }
}

.areasearchBox__tabItem.active {
  background-color: var(--color-main);
  color: #fff;
  top: 0;
}

.areasearchBox__tabTxt {
  line-height: 1.1;
}

.areasearchBox__mapBox {
  width: 750px;
  height: 550px;
  background: url(../img/index/areasearchBox_map1.webp) no-repeat center / contain;
  position: relative;
}

.areasearchBox__mapBox::after {
  content: "";
  display: block;
  width: 165px;
  aspect-ratio: 331 / 284;
  background: url(../img/index/areasearchBox_character.webp) no-repeat center / contain;
  position: absolute;
  bottom: -20px;
  left: -30px;
}

.areasearchBox__mapItem {
  text-decoration: none;
  display: block;
}

.areasearchBox__mapItem:hover {
  opacity: 1;
  transform: translateY(-5px);
  filter: drop-shadow(0 0 4px rgba(255, 255, 255, .8));
}

.areasearchBox__mapItemTtl,
.areasearchBox__mapItemNumBox {
  text-align: center;
  line-height: 1;
  font-weight: 600;
  filter: drop-shadow(0 0 2px rgba(255, 255, 255, 0.7));
}

.areasearchBox__mapItemTtl {
  margin-bottom: 5px;
  font-size: 20px;
  white-space: pre-wrap;
}

.areasearchBox__mapItemNumBox {
  font-size: 18px;
}

.areasearchBox__mapItemNum {
  font-family: var(--font-num);
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
}

@media screen and (min-width: 768px) {

  .areasearchBox__mapItem {
    position: absolute;
  }

  /*強調エリア*/
  .areasearchBox__mapBox .c-08220,
  .areasearchBox__mapBox .c-08203,
  .areasearchBox__mapBox .c-08219,
  .areasearchBox__mapBox .c-08443,
  .areasearchBox__mapBox .c-08224,
  .areasearchBox__mapBox .c-08217,
  .areasearchBox__mapBox .c-08235 {
    background: #fff;
    border-radius: 100%;
    padding: 5px;
    width: 100px;
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

  /*つくば市*/
  .areasearchBox__mapBox .c-08220 {
    top: 185px;
    left: 244px;
  }

  /*土浦市*/
  .areasearchBox__mapBox .c-08203 {
    top: 127px;
    left: 362px;
  }

  /*牛久市*/
  .areasearchBox__mapBox .c-08219 {
    top: 320px;
    left: 348px;
  }

  /*稲敷郡阿見町*/
  .areasearchBox__mapBox .c-08443 {
    top: 240px;
    left: 441px;
  }

  /*取手市*/
  .areasearchBox__mapBox .c-08217 {
    top: 431px;
    left: 336px;
  }

  /*石岡市*/
  .areasearchBox__mapBox .c-08205 {
    top: 31px;
    left: 311px;
  }

  /*龍ケ崎市*/
  .areasearchBox__mapBox .c-08208 {
    top: 406px;
    left: 464px;
  }

  /*下妻市*/
  .areasearchBox__mapBox .c-08210 {
    top: 161px;
    left: 103px;
  }

  /*常総市*/
  .areasearchBox__mapBox .c-08211 {
    top: 299px;
    left: 148px;
  }

  /*守谷市*/
  .areasearchBox__mapBox .c-08224 {
    top: 444px;
    left: 189px;
  }

  /*筑西市*/
  .areasearchBox__mapBox .c-08227 {
    top: 35px;
    left: 67px;
  }

  /*坂東市*/
  .areasearchBox__mapBox .c-08228 {
    top: 353px;
    left: 68px;
  }

  /*稲敷市*/
  .areasearchBox__mapBox .c-08229 {
    top: 311px;
    left: 629px;
  }

  /*かすみがうら市*/
  .areasearchBox__mapBox .c-08230 {
    top: 127px;
    left: 493px;
  }

  /*つくばみらい市*/
  .areasearchBox__mapBox .c-08235 {
    top: 343px;
    left: 227px;
  }

  /*小美玉市*/
  .areasearchBox__mapBox .c-08236 {
    top: 8px;
    left: 558px;
  }

  /*稲敷郡美浦村*/
  .areasearchBox__mapBox .c-08442 {
    top: 232px;
    left: 567px;
  }

  /*稲敷郡河内町*/
  .areasearchBox__mapBox .c-08447 {
    top: 434px;
    left: 581px;
  }

  /*北相馬郡利根町*/
  .areasearchBox__mapBox .c-08564 {
    top: 489px;
    left: 483px;
  }
}

/*物件検索へのボタン*/
.searchBox__linkBtnWrap {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: center;
  margin-top: 40px;
}

.searchBox__linkBtnWrap .btn_archive {
  width: 100%;
}

.searchBox__linkBtnWrap .btn_archive a {
  font-size: 1.8rem;
}


.searchBox__linkBtnTxt {
  font-size: 14px;
}

.searchBox__linkBtn--station {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

/*
===== RECOMBOX 注目物件／リフォーム済みおすすめ物件 ==========================================
*/

.pickupBox,
.recomBox,
.newArrivalsBox {
  padding: var(--gutter-narrow) 0;
}

.pickupBox__ttl,
.recomBox__ttl,
.newArrivalsBox__ttl {
  text-align: center;
  margin-bottom: 30px;
}

.pickupBox__ttl::before,
.recomBox__ttl::before,
.newArrivalsBox__ttl::before {
  content: "";
  display: block;
  width: .9em;
  height: .9em;
  background: url(../img/common/icon_house_new.svg) no-repeat center / contain;
  position: absolute;
  top: .5em;
  left: 50%;
  transform: translateX(-50%);
}

.pickupBox__ttl::before {
  background: url(../img/common/icon_look.svg) no-repeat center / contain;
  width: 1.6em;
  height: 1.6em;
  top: 0;
}

.recom .wrap {
  margin: 0 auto;
  width: 100%;
}

.recom .itemList {
  position: relative;
  display: flex;
  justify-content: center;
}

.recom .item {
  width: 300px;
  min-height: 190px;
  background: #FFF;
  border: solid 1px var(--color-black);
  position: relative;
  margin: 0 10px;
  border-radius: 5px;
  overflow: hidden;
}

/*-------------------------▲*/
.recom .item:not(.emember) a {
  width: 100%;
  height: 100%;
  display: block;
  padding-bottom: 50px;
}

.recom .item .inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}

.recom .item .box01 {
  width: 100%;
  height: 40px;
  display: flex;
  justify-content: space-between;
  padding: 5px 0 5px 50px;
}

.recom .item .icon img {
  width: 50px;
  aspect-ratio: 5 / 2;
  display: inline-block !important;
  margin-right: 3px;
}

.recom .item .icon .icon_type {
  position: absolute;
  top: 0;
  left: 10px;
}

.recom .item .icon img.icon_type {
  width: 34px;
  aspect-ratio: 1;
}

.recom .item .price {
  font-weight: bold;
  font-size: 12px;
  flex-shrink: 0;
  padding-right: 10px;
}

.recom .item .price span {
  color: var(--color-orange);
  font-size: 18px;
  font-family: var(--font-en);
  line-height: 1.3;
}

.recom .item .box02 {
  width: calc(40% - 20px);
  margin: 0 10px;
}

.recom .item .photo {
  text-align: center;
}

.recom .item .photo img {
  aspect-ratio: 270 / 185;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.recom .item .box03 {
  width: 60%;
}

.recom .item .info {
  flex-grow: 1;
  font-size: 11px;
  padding-right: 10px;
}

.recom .item .info h3.ttl {
  font-size: 14px;
  font-weight: bold;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
  line-height: 1.5;
}

.recom .item .info .details {
  min-height: 60px;
}

.recom .item .box04 {
  width: 100%;
  position: absolute;
  bottom: 0;
}

.recom .item .payment_pay {
  background: var(--color-palegray);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  padding: 10px 10px 10px 5px;
  height: 40px;
}

.recom .item .payment_pay dl {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.recom .item .payment_pay dt,
.recom .item .payment_pay dd {
  font-weight: bold;
  line-height: 1;
}

.recom .item .payment_pay dd span {
  font-size: 16px;
  line-height: 11px;
  margin: 0 3px;
}

.recom .item .payment_pay .payment_txt {
  font-size: 9.5px;
  text-align: center;
  line-height: 1;
  flex-shrink: 0;
}

/* スタッフコメント */
.recom .item .staffComment {
  width: 100%;
  display: flex;
  justify-content: space-between;
  padding: 10px;
  border-top: 1px dotted #ccc;
  font-size: 11px;
}

.recom .item .staffComment_img {
  width: 50px;
  height: 50px;
  aspect-ratio: 1 / 1;
}

.recom .item .staffComment_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.recom .item .staffComment_txtBox {
  width: calc(100% - 50px);
  text-align: left;
  padding-left: 5px;
}

.recom .item .staffComment_name {
  font-weight: bold;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.recom .item .staffComment_txt {
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}


/* 会員限定物件 アニメーション*/
.recom .memberItem {
  display: flex;
  align-items: center;
  justify-content: center;
  background: url(../img/basic/recom_member_bg.webp) no-repeat center top / 100% auto;
  width: 100%;
  height: 100%;
  position: relative;
  border-radius: 5px;
}

.recom .memberItem__ttl {
  color: var(--color-main);
  font-family: var(--font-en);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: .1em;
  margin-bottom: 0;
}

.recom .memberItem__ttl::before,
.recom .memberItem__ttl::after {
  content: "";
  display: inline-block;
  width: .25em;
  height: 1em;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background: currentColor;
}

.recom .memberItem__ttl::before {
  margin-right: .5em;
  transform: translateY(20%) rotate(-20deg);
}

.recom .memberItem__ttl::after {
  margin-left: .5em;
  transform: translateY(20%) rotate(20deg);
}

.recom .memberItem__body {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: none;
}

.recom .memberItem__txt {
  text-align: center;
  font-size: 13px;
  color: var(--color-black);
}

.recom .memberItem_Btn {
  padding: 0.8em 2.5em;
  margin-top: 10px;
  background-color: var(--color-main);
  color: #fff;
  font-weight: bold;
  display: flex !important;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  font-size: clamp(12px, 1.6vw, 14px);
  line-height: 1.3;
  letter-spacing: 0.1em;
  animation: 1.4s fuwafuwa infinite ease-in-out;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  border-radius: var(--rad-full);
}

.recom .memberItem_Btn::before {
  position: absolute;
  content: '';
  width: 10px;
  height: 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  top: 50%;
  right: 1em;
  transform: translateY(-50%) rotate(45deg);
}

.recom .memberItem_Btn_main {
  display: inline-block;
  font-size: 1.6em;
  position: relative;
}


/*
===== OFFERBOX ==========================================
*/
.offerBox {
  margin: var(--gutter-wide) 0;
  padding: var(--gutter-wide) 0;
  background: url(../img/index/offerBox_bg.webp) no-repeat center / cover;
  text-align: center;
}

.offerBox__ttl {
  text-align: center;
  display: inline-block;
  position: relative;
  font-size: clamp(2rem, 7.2vw, 6rem);
  line-height: 1;
  padding: 0 2em;
}

.offerBox__ttl__badge {
  display: inline-block;
  background: var(--color-yellow);
  border-radius: var(--rad-full);
  padding: .5em 1em;
  font-weight: 700;
  letter-spacing: .1em;
  font-size: clamp(1.5rem, 1.5vw, 2rem);
  margin-bottom: 1em;
}

.offerBox__ttl__badge .font_num {
  font-size: 1.6em;
  font-family: var(--font-num);
  font-weight: 700;
}

.offerBox__ttl__main {
  display: inline-block;
  color: var(--color-main);
  font-weight: 900;
  letter-spacing: .125em;
}

.offerBox__ttl::before,
.offerBox__ttl::after {
  content: "";
  width: 20%;
  height: 100%;
  background: url(../img/index/offerBox_ttl_bg.svg) no-repeat center bottom / contain;
  position: absolute;
  bottom: 0;
}

.offerBox__ttl::before {
  left: -5%;
  transform: translateY(.25em);
}

.offerBox__ttl::after {
  right: -5%;
  transform: translateY(.25em) scale(-1, 1);
}

.offerBox__itemList {
  display: inline-flex;
  flex-direction: column;
  text-align: left;
  margin-top: var(--gutter);
  padding: 0 1em;
}

.offerBox__item {
  font-size: clamp(1.8rem, 2vw, 2.2rem);
  margin-bottom: 1em;
  display: flex;
  align-items: center;
  font-weight: 700;
}

.offerBox__item__num {
  font-size: 1.2em;
  background: var(--color-yellow);
  border-radius: var(--rad-full);
  font-family: var(--font-en);
  font-weight: 700;
  line-height: 1;
  width: 2em;
  height: 2em;
  padding: .5em 0;
  text-align: center;
  margin-right: .75em;
  flex-shrink: 0;
}

.offerBox__item__em {
  color: var(--color-orange);
}

.offerBox__countBox {
  margin: var(--gutter-narrow) auto;
  display: inline-flex;
  justify-content: center;
  background: #fff;
  border-radius: 5px;
  padding: var(--gutter-narrow);
}

.offerBox__countWrap {
  padding: 0 var(--gutter-narrow);
  font-size: clamp(1.4rem, 1.6vw, 1.8rem);
}

.offerBox__countWrap--member {
  border-left: 1px dashed var(--color-black);
}

.offerBox__count__numBox {
  font-weight: 700;
}

.offerBox__count__num {
  font-size: 1.8em;
  font-family: var(--font-en);
  margin-right: .25em;
}

.offerBox__countWrap--member .offerBox__count__num {
  color: var(--color-main);
}

.offerBox__btnWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 80%;
  max-width: 700px;
  padding: 0 80px;
  margin: 0 auto;
}

.offerBox__btn__ttl {
  display: inline-block;
  margin: 1em 0;
  padding: 0 2em;
  font-size: clamp(1.2rem, 1.4vw, 1.6rem);
  font-weight: 500;
  position: relative;
}

.offerBox__btn__ttl::before,
.offerBox__btn__ttl::after {
  content: "";
  display: block;
  width: 1px;
  height: 80%;
  background: var(--color-black);
  position: absolute;
  bottom: 0;
}

.offerBox__btn__ttl::before {
  left: 1em;
  transform: rotate(-30deg);
}

.offerBox__btn__ttl::after {
  right: 1em;
  transform: rotate(30deg);
}

.offerBox__btnWrap .btn_archive {
  width: 100%;
  max-width: 400px;
  position: relative;
}

.offerBox__btnWrap .btn_archive::before {
  content: "";
  display: block;
  width: 64px;
  aspect-ratio: 64 / 113;
  background: url(../img/common/character01.webp) no-repeat center / contain;
  position: absolute;
  bottom: 0;
  left: -64px;
}

.offerBox__btnWrap .btn_archive::after {
  content: "";
  display: block;
  width: 64px;
  aspect-ratio: 64 / 113;
  background: url(../img/common/character02.webp) no-repeat center / contain;
  position: absolute;
  bottom: 0;
  right: -64px;
}

/*
===== GALLERYBOX ==========================================
*/
.galleryBox {
  background:
    linear-gradient(rgba(255, 255, 255, 0), rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 1) 100%),
    url(../img/index/galleryBox_bg.webp);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  padding: var(--gutter) 0;
}

.galleryBox__ttl {
  text-align: center;
  margin-bottom: 30px;
  font-weight: 700;
  color: #fff;
}

.galleryBox__ttl--en {
  font-family: var(--font-en);
  font-size: clamp(3.2rem, 10vw, 6rem);
  display: block;
  letter-spacing: .1em;
}

.galleryBox__ttl--ja {
  font-size: clamp(1.4rem, 2.4vw, 2.4rem);
  letter-spacing: .1em;
}

.galleryBox__inner {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

.galleryBox__inner .slick-initialized {
  min-height: 200px;
}

.galleryBox__list {
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-wrap: nowrap;
  /* Safari */
  flex-wrap: nowrap;
  -webkit-justify-content: center;
  /* Safari */
  justify-content: center;
  position: relative;
}

.galleryBox__item {
  max-width: 380px;
  width: calc((100% - 40px)/ 3);
  position: relative;
  margin: 0 10px;
  background: #fff;
  border-radius: 5px;
}

.galleryBox__item a {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.galleryBox__photo {
  aspect-ratio: 3 / 2;
  border-radius: 5px;
}

.galleryBox__detail {
  padding: 10px;
  border-top: none;
}

.galleryBox__detailTtl {
  margin: .5em;
  font-weight: bold;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
  line-height: 1.5;
}

.galleryBox__detailDataWrap {
  margin: 5px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.galleryBox__iconWrap {
  display: block;
  text-align: center;
  position: absolute;
  top: 5px;
  left: 5px;
}

.galleryBox__btn {
  margin-top: 50px;
}


/*Slider*/
.galleryBox .slick-dots {
  bottom: -40px;
}

.galleryBox:has(.slick-dots) .galleryBox__btn {
  margin-top: 80px;
}



/*
===== ABOUTBOX ==========================================
*/
.aboutBox {
  margin: var(--gutter-wide) 0;
}

.aboutBox__ttl {
  text-align: center;
  margin-bottom: 30px;
  font-weight: 700;
}

.aboutBox__ttl--en {
  font-family: var(--font-en);
  font-size: clamp(2rem, 10vw, 8rem);
  display: block;
  letter-spacing: .1em;
}

.aboutBox__ttl--ja {
  font-size: clamp(1.4rem, 2.4vw, 2.4rem);
  letter-spacing: .1em;
}

.aboutBox__subTtl {
  text-align: center;
  font-size: clamp(1.6rem, 3vw, 3.2rem);
  font-weight: bold;
  letter-spacing: .1em;
}

.aboutBox__movie .aboutBox__subTtl::before {
  content: "―";
  margin-right: 1em;
}

.aboutBox__movie .aboutBox__subTtl::after {
  content: "―";
  margin-left: 1em;
}

.aboutBox__movie__inner {
  background: #ccc;
  margin: 30px auto 50px;
  width: 85%;
  aspect-ratio: 16/9;
}

.aboutBox__message p {
  text-align: center;
  font-size: clamp(1.4rem, 1.6vw, 1.8rem);
  margin: 1em 0;
  line-height: 1.8;
}

.aboutBox__btnList {
  max-width: 800px;
  margin: var(--gutter) auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2%;
}

.aboutBox__btn {
  width: 49%;
  max-width: 380px;
  margin-bottom: var(--gutter);
}

.aboutBox__btn a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 380px;
  margin: 0 auto;
  background: #fff;
  padding: 1.1em 0;
  letter-spacing: .05em;
  line-height: 1;
  text-decoration: none;
  border-radius: var(--rad-full);
  border: 1px solid currentColor;
  position: relative;
}

.aboutBox__btn a::after {
  position: absolute;
  content: '';
  width: 2em;
  height: 2em;
  background: var(--color-orange) url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.33%22%20height%3D%2217.103%22%20viewBox%3D%220%200%209.33%2017.103%22%3E%3Cpath%20d%3D%22M56.871%2C81.1a.777.777%2C0%2C0%2C1-1.1%2C0l-7.224-7.225L41.323%2C81.1a.778.778%2C0%2C0%2C1-1.1-1.1L48%2C72.222a.777.777%2C0%2C0%2C1%2C1.1%2C0L56.871%2C80a.777.777%2C0%2C0%2C1%2C0%2C1.1Z%22%20transform%3D%22translate(81.323%20-39.996)%20rotate(90)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E') no-repeat left 53% center / auto 50%;
  border-radius: var(--rad-full);
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  transition: .3s;
}

.aboutBox__btn__sub {
  font-size: 1.2rem;
  margin-bottom: 5px;
}

.aboutBox__btn__main {
  font-family: var(--font-en);
  font-size: clamp(1.6rem, 3vw, 3.2rem);
  font-weight: 500;
  letter-spacing: .125em;
}

@media (any-hover:hover) {
  .aboutBox__btn a:hover {
    opacity: 1;
    background: var(--color-orange);
    border-color: var(--color-orange);
    color: #fff;
  }

  .aboutBox__btn a:hover::after {
    right: .25em;
  }
}


.aboutBox__review {
  max-width: 1000px;
  margin: 0 auto;
}

/*
===== SHOPINFOBOX ==========================================
*/
.indexPage .shopInfoBox {
  background: var(--color-paleblue) url(../img/index/shopinfoBox_bg.webp);
  background-size: 82px auto;
  padding: var(--gutter) 0 0;
}

.shopInfoBox__ttl {
  margin-bottom: var(--gutter);
}

.shopInfoBox__ttl::before {
  content: "";
  display: block;
  width: .9em;
  height: .9em;
  background: url(../img/common/icon_store.svg) no-repeat center / contain;
  position: absolute;
  top: .5em;
  left: 50%;
  transform: translateX(-50%);
}

.indexPage .shopInfoBox__itemList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 2%;
}

.indexPage .shopInfoBox__inner {
  width: 49%;
  background: transparent;
  flex-direction: column;
  justify-content: flex-start;
  padding: 0;
}

.indexPage .shopInfoBox__imgBox,
.indexPage .shopInfoBox__dataBox {
  width: 100%;
  max-width: none;
}

.indexPage .shopInfoBox__dataBox {
  margin: 2em 0;
}

.indexPage .shopInfoBox__dataTtl,
.indexPage .shopInfoBox__data {
  padding: .5em;
}


/*
===== NOTICEBOX ==========================================
*/
.noticeBox {
  margin: var(--gutter) 0;
}

.noticeBox__inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding-bottom: 1em;
}

.topicsBox__item {
  border-bottom: 1px solid currentColor;
}

.topicsBox__item a {
  display: block;
  position: relative;
  padding: 1.2em 0;
}

.topicsBox__item a::after {
  content: "";
  display: block;
  width: 1em;
  height: 1em;
  border-top: 1px solid currentColor;
  border-right: 1px solid currentColor;
  position: absolute;
  top: 50%;
  right: 1em;
  transform: translateY(-50%) rotate(45deg);
}

.topicsBox__date {
  font-weight: bold;
}

.topicsBox__itemTtl {
  margin-top: .5em;
  padding-right: 2.5em;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.noticeBox .cate_new,
.noticeBox .cate_popular {
  font-size: .9em;
  padding: 2px 5px;
}

.topicsBox,
.columnBox {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.columnBox__inner>ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.columnBox__item {
  display: block;
  width: calc((100% - 20px) / 2);
  margin-bottom: 1em;
}

.columnBox__item a {
  display: block;
  text-decoration: none;
}

.columnBox__photo {
  aspect-ratio: 270 / 150;
  border-radius: 5px;
}

.columnBox__detail {
  margin-top: 10px;
}

.columnBox__iconWrap {
  font-weight: bold;
}

.columnBox__infoItem {
  margin-right: 5px;
  display: inline-block;
  font-weight: normal;
}

.columnBox__date {
  font-weight: bold;
}

.columnBox__itemTtl {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.topicsBox__inner {
  margin: 10px 0 auto;
}

.columnBox__inner {
  margin: 25px 0 auto;
}

.noticeBox__btn {
  margin-top: 30px;
}

/*
===== PRODUCTSBOX ==========================================
*/
.productsBox {
  margin: var(--gutter-wide) 0;
}

.productsBox__ttl {
  padding-top: 0;
  white-space: nowrap;
}

.productsBox__itemList {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px;
  margin: var(--gutter) 0;
}

.productsBox__item {
  width: calc((100% - 60px) / 3);
  border-radius: 5px;
  overflow: hidden;
  filter: drop-shadow(0 5px 5px rgba(0, 0, 0, 0.15));
  background: #fff;
}

.productsBox__item a {
  display: block;
}

/*
===== SNSBOX ==========================================
*/
.SNSBox__itemWrap {
  padding: var(--gutter);
}

.SNSBox__fbBox {
  background: var(--color-paleblue);
}

.SNSBox__igBox {
  background: var(--color-paleorange);
}

.SNSBox__ttl {
  text-align: center;
}

.SNSBox__ttl__main {
  display: block;
  font-size: 20px;
  font-family: var(--font-en);
  font-weight: 600;
  letter-spacing: .15em;
}

.SNSBox__ttl__icon {
  display: block;
  text-align: center;
  position: relative;
  margin-top: 5px;
}

.SNSBox__ttl__icon img {
  width: 50px;
  height: auto;
}

.SNSBox__ttl__icon::before,
.SNSBox__ttl__icon::after {
  content: "";
  display: block;
  width: 35%;
  height: 1px;
  background: var(--color-black);
  position: absolute;
  top: 25px;
}

.SNSBox__ttl__icon::before {
  left: 0;
}

.SNSBox__ttl__icon::after {
  right: 0;
}

.SNSBox__contents {
  margin: var(--gutter-narrow) auto;
  max-width: 500px;
  height: 350px;
}

/*Facebook Widget*/
.fb_iframe_widget {
  width: 100% !important;
  height: 100% !important;
}

.fb_iframe_widget span {
  width: 100% !important;
}

.fb_iframe_widget span iframe {
  width: 100% !important;
  max-width: 500px;
  margin: 0 auto;
}

.SNSBox__fbBox .SNSBox__contents {
  padding: 11px 0;
}

/*==================================================
  PC SETTINGS : Min768px Max1200px
==================================================*/
@media screen and (min-width: 768px) {

  /*
===== BANNER ==========================================
*/

  /*col2*/
  .bannerWrap--col2 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2%;
  }

  .bannerWrap--col2 .bannerBox {
    width: 49%;
  }


  /*
===== SEARCHBOX ==========================================
*/

  /*
----- 物件数リスト・ログインBOX --------------------
*/
  .searchBox__countWrap {
    display: flex;
    justify-content: space-between;
  }

  .estateCountBox {
    width: 65%;
    padding: 40px 6% 20px 0;
    border-right: 1px dashed var(--color-black);
  }

  /*ログイン・会員メニュー*/
  .estateMemberBox {
    width: 35%;
    padding-left: 5%;
  }


  /*
===== NOTICEBOX ==========================================
*/

  .topicsBox,
  .columnBox {
    width: calc((100% - 20px)/2);
    padding: 0 20px;
  }

  .columnBox {
    border-left: 1px solid var(--color-palegray);
  }

  /*
===== SNSBOX ==========================================
*/
  .SNSBox {
    display: flex;
  }

  .SNSBox__itemWrap {
    width: 50%;
  }

  .SNSBox__fbBox {
    padding-left: max(var(--gutter), calc((100vw - var(--width-content))/2));

  }

  .SNSBox__igBox {
    padding-right: max(var(--gutter), calc((100vw - var(--width-content))/2));
  }

}

/*==================================================
  tablet SETTINGS : Min768px Max1200px
==================================================*/
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .indexWire {
    width: 98%;
    margin: 0 auto;
    overflow: hidden;
  }

  .indexmainSlider__item {
    width: 100%;
    height: 46.3vw !important;
  }

  .bannerWrap {
    margin: 30px auto;
    width: 96%;
  }

  /*イベント情報*/
  .eventBox__list {
    gap: 0;
  }

  /*
----- 物件数リスト・ログインBOX --------------------
*/
  .estateCountBox {
    padding: 4% 2% 4% 0;
    width: 55%;
  }

  .estateMemberBox {
    width: 45%;
    padding-left: 2%;
  }

  .estateCountBox__detailBox {
    padding: 7%;
  }

  .estateCountBox__detailWrap {
    flex-direction: column;
  }

  .estateCountBox__btn {}

  .estateCountBox__btn--member {
    padding: 18px 0;
  }

  .estateCountBox__btnTxt {
    font-size: clamp(10px, 1vw, 14px);
  }

  /*
----- 検索条件BOX・地図 --------------------
*/
  /*検索条件BOX*/
  .searchBox__searchWrap {
    display: block;
  }

  .searchBox__option {
    margin: 0 auto var(--gutter);
    width: 96%;
    max-width: 760px;
    max-width: none;
    background: var(--color-paleblue);
    padding: var(--gutter-narrow)
  }

  .searchBox__option__ttl {
    font-size: 2.4rem;
  }

  .searchBox__option .itemWrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .searchBox__option .itemWrap dl {
    width: calc(50% - 30px);
  }

  .searchBox__option .formWrap .btnWrap {
    margin: var(--gutter-narrow) auto;
  }

  /* 地図 */
  .searchBox__mapWrap {
    margin: 0 auto;
    width: 100%;
  }

  .areasearchBox__mapBox {
    background-size: cover;
  }

  .areasearchBox__mapBox::after {
    left: 5px;
  }

  /*名古屋市千種区*/
  .areasearchBox__mapBox .c-23101 {
    top: 241px;
  }

  /*名古屋市中川区*/
  .areasearchBox__mapBox .c-23102 {
    top: 327px;
  }

  /*名古屋市港区*/
  .areasearchBox__mapBox .c-23103 {
    top: 416px;
  }

}

/*==================================================
  SP SETTINGS : Max767px
==================================================*/

@media screen and (max-width: 767px) {
  .indexWire {
    width: 98%;
    margin: 0 auto;
    overflow: hidden;
  }

  .btn_archive {
    margin-bottom: 1rem;
  }

  .btn_archive a {
    border: 1px solid rgba(0, 0, 0, .1);
  }

  .index__ttl {
    padding-bottom: .5em;
  }

  .indexmainBox:has(.slick-list) {
    height: calc(42vw + 30px);
    max-height: 530px;
  }

  .indexmainBox .slick-dots {
    bottom: -30px;
  }

  .slick-list.draggable {
    width: calc(100% - 60px);
    overflow: visible;
  }

  .slick-dots li button:before {
    width: 10px !important;
    height: 10px !important;
  }

  .bannerWrap {
    width: 96%;
  }

  /*
===== FV_BtnBox SP ==========================================
*/
  .estateCountBox__spBtnBox {
    width: 96%;
    margin: 5% auto 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 3%;
    font-weight: bold;
  }

  .estateCountBox__spBtn {
    width: 48.5%;
    padding: 1em 0;
    text-align: center;
    font-size: 1.3rem;
    background-color: var(--color-main);
    color: #fff;
    position: relative;
    border-radius: var(--rad-full);
    margin-bottom: 3%;
  }

  .estateCountBox__spBtn::after {
    position: absolute;
    content: '';
    width: .8em;
    height: .8em;
    background: url(../img/common/arrow_right_white.svg) no-repeat center / contain;
    top: 50%;
    right: .5em;
    transform: translateY(-50%);
  }

  .estateCountBox__spBtn.kodate {
    background-color: var(--color-main);
  }

  .estateCountBox__spBtn__balloon {
    position: absolute;
    font-size: 0.75em;
    display: block;
    top: -15px;
    white-space: nowrap;
    padding: 0.3em 0.5em;
    background-color: var(--color-yellow);
    color: var(--color-black);
    left: 50%;
    transform: translateX(-50%);
    font-feature-settings: "palt";
    letter-spacing: 0.05em;
    transform-origin: center;
    animation: balloon ease-in-out 1s infinite alternate;
  }

  @keyframes balloon {
    0% {
      transform: translateX(-50%) rotate(2deg);
    }

    10% {
      transform: translateX(-50%) rotate(-2deg);
    }

    20% {
      transform: translateX(-50%) rotate(2deg);
    }

    30% {
      transform: translateX(-50%) rotate(-2deg);
    }

    35% {
      transform: translateX(-50%) rotate(0deg);
    }

    100% {
      transform: translateX(-50%) rotate(0deg);
    }
  }

  .estateCountBox__spBtn__balloon::after {
    content: "";
    border-top: 4px solid var(--color-yellow);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    position: absolute;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
  }

  /*
===== PURPOSE ==========================================
*/
  .purposeWrap {
    flex-wrap: wrap;
    justify-content: center;
  }

  .purposeBox {
    width: calc((100% - clamp(5px, 1.8vw, 20px)) / 2);
    margin: 0;
  }

  .purposeBox .btn_archive a {
    font-size: 1.2rem;
    padding-right: 1.2em;
  }

  /*
  ===== SEARCHBOX - SP ==========================================
  */

  .searchBox__ttl {
    margin-bottom: 20px;
  }

  .searchBox__ttl img {
    width: 45%;
  }

  .searchBox__container {
    flex-direction: column-reverse;
  }

  /*物件数リスト*/
  .estateCountBox {
    width: 100%;
    max-width: unset;
    padding: 1em 0;
  }

  .estateCountBox__totalBox {
    padding: 0 15px 20px;
  }

  .estateCountBox__totalTtl {
    font-size: clamp(14px, 4.6vw, 18px);
  }

  .estateCountBox__detailBox {
    padding: 15px;
  }

  .estateCountBox__detailWrap {
    flex-direction: column;
  }

  .estateCountBox__detailWrap--shop {
    flex-direction: column;
  }

  .estateCountBox__btn__txt01 {
    font-size: 14px;
  }

  /*エリア別物件一覧*/
  .searchBox__rightCont {
    width: 100%;
    max-width: unset;
  }

  .areasearchBox__tabList {
    background: none;
    flex-wrap: wrap;
    justify-content: center;
  }

  .areasearchBox__tabItem {
    width: 32%;
    max-width: unset;
    flex-grow: 1;
  }

  .areasearchBox__tabItem:nth-of-type(1),
  .areasearchBox__tabItem:nth-of-type(2) {
    width: 49%;
  }

  .areasearchBox__mapBox {
    background: none;
    height: unset;
  }

  .areasearchBox__mapInner {
    display: flex;
    flex-wrap: wrap;
  }

  .areasearchBox__mapItem {
    border: 1px solid #ccc;
    width: 48%;
    margin: 5px 1% 0;
    position: static;
    background-color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .areasearchBox__mapItemInner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 5px;
    width: 100%;
  }

  .areasearchBox__mapItemTtl,
  .areasearchBox__mapItemNumBox {
    font-size: 13px;
    text-shadow: none;
    color: var(--color-black);
  }

  .areasearchBox__mapItemNum {
    font-size: 17px;
  }

  /*物件検索へのリンク*/
  .searchBox__linkBtnWrap {
    flex-direction: column;
    align-items: center;
  }

  .searchBox__linkBtn {
    font-size: 18px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 0.7;
  }

  .searchBox__linkBtnTxt {
    font-size: 12px;
  }

  /*
  ===== EVENTBOX - SP ==========================================
  */
  .eventBox {
    overflow: hidden;
  }

  .eventBox__inner .slick-initialized {
    min-height: 100px;
  }

  .eventBox__ttlWrap {
    width: 80%;
    max-width: 300px;
  }

  .eventBox__item {
    width: 300px;
  }

  .eventBox__detail {
    padding: 10px;
    display: inline-block;
    width: 100%;
  }

  .eventBox__iconWrap {
    margin-bottom: 5px;
  }

  .eventBox__iconWrap span {
    padding: 5px;
    font-size: 11px;
    margin-right: 5px;
  }

  .eventBox__detail dt,
  .eventBox__detail dd {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    font-size: 1.4rem;
  }

  /*
  ===== PICKUPBOX・RECOMBOX ==========================================
  */

  .pickupBox,
  .recomBox,
  .newArrivalsBox {
    overflow: hidden;
  }

  .pickupBox {
    padding: 5% 0;
  }

  .pickupBox::before,
  .pickupBox::after {
    height: 10vw;
  }

  /*
  ===== OFFERBOX ==========================================
  */
  .offerBox__countBox {
    width: 96%;
    max-width: 480px;
  }

  .offerBox__btnWrap {
    padding: 0;
  }

  .offerBox__btnWrap .btn_archive::before {
    width: clamp(40px, 10vw, 64px);
    left: -5%;
    bottom: -10px;
    z-index: 1;
  }

  .offerBox__btnWrap .btn_archive::after {
    width: clamp(40px, 10vw, 64px);
    right: -5%;
    bottom: -10px;
  }

  /*
  ===== GALLERYBOX ==========================================
  */
  .galleryBox {
    overflow: hidden;
  }

  .galleryBox__ttl {
    margin-bottom: 5%;
  }

  .galleryBox__item {
    width: 300px;
  }

  /*
  ===== ABOUTBOX SP ==========================================
  */
  .aboutBox__btn a {
    padding-right: 1em;
  }

  /*
  ===== noticeBox SP ==========================================
  */
  .noticeBox {
    padding: 0;
  }

  .noticeBox__inner {
    flex-direction: column;
    padding: 0;
    width: 96%;
  }

  .topicsBox,
  .columnBox {
    width: 100%;
    max-width: unset;
  }

  .topicsBox__inner,
  .columnBox__inner {
    min-height: unset;
  }

  .topicsBox__item a {
    flex-direction: column;
    align-items: baseline;
  }

  .topicsBox__date,
  .topicsBox__itemTtl {
    width: 100%;
    margin: 0;
  }

  .topicsBox__item {
    padding: 5px 10px;
  }

  /*
  ===== PRODUCTSBOX SP ==========================================
  */

  .productsBox__itemList {
    position: relative;
    padding-bottom: 30px;
    flex-wrap: nowrap;
  }

  .productsBox__item {
    width: 80%;
    max-width: 280px;
    margin: 0 20px;
  }

  .SNSBox__contents {
    height: auto;
  }

}