@charset "utf-8";
/* 共通 */
* {
  box-sizing: border-box;
}
.middle_main01 {
  background: url("images/bg.png") repeat center center;
}

.pc-img {
  display: block !important;
}
.sp-img {
  display: none !important;
}
.font-family: 'Noto Sans JP', sans-serif;

@media screen and (max-width: 750px) {
  .pc-img {
    display: none !important;
  }
  .sp-img {
    display: block !important;
	}
}
/* ▼トップページ */

.fvwrap {
  position: relative;
  background-color: #F8F7D9; /* スライダー外側の背景色 */
  padding-bottom: 10px; /* 下余白 */
}


.fvwrap .bx-wrapper {
  background: transparent;
  border-radius: 0 0 30px 30px;
  overflow: hidden;
  margin: 0 auto; /* 中央揃え */
  box-shadow: none;
  border: none;
}


.fv {
  max-width: 100%;
  margin: 0 auto;
}


.fv > ul {
  padding: 0;
  margin: 0;
  list-style: none;
}


.fv li {
  overflow: hidden;
  border-radius: 0 0 30px 30px;
}


.fv li img {
  width: 100%;
  height: 700px;
  object-fit: cover;
  display: block;
  border-radius: 0 0 30px 30px;
}


.areaname {
  position: absolute;
  bottom: -150px;
  z-index: 2;
}
.section-curve {
  background: transparent;
  text-align: center;
  overflow: visible;
}
.section-curve .inner {
  padding: 100px 20px 20px;
  background-color: #F8F7D9; /* 背景色も指定する */
  position: relative;
  z-index: 1;
}
.curve {
  width: 100%;
  height: auto;
  line-height: 0;
  z-index: 0;
}
.curve svg {
  width: 100%;
  height: 50px;
  display: block;
}
.area-lead {
  display: flex;
  align-items: center;
  margin-top: -50px;
}
.area-lead h2 {
  font-size: 40px;
  font-weight: 700;
  color: #689D4C;
  width: 30%;
  text-align: left;
}
.map-space { /* width:35%; */ min-width: 480px;
}
.lead-txt {
  width: calc(30% + 20px);
  text-align: left;
}
.lead-txt h3 {
  font-size: 20px;
  font-weight: bold
}
.wrap-map {
  display: flex;
  gap: 20px
}
.iruma-map {
  position: relative;
  margin-top: -150px;
  margin-left: -150px !important;
  z-index: 2;
}
.responsive-map {
  /* width: 100%; */
  max-width: 800px;
  height: auto;
  display: block;
}
.area-select {
  margin-top: 30px;
  z-index: 2
}

.area-select.select02{
  margin-top: 0px !important;
}
.area-select h3 {
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 20px;
}
.area-list {
  border: 2px solid #000000;
  width: 314px;
  background: #FFFFFF;
  border-radius: 15px;
  padding: 20px 15px 20px 15px;
}
.area-list li {
  text-align: left;
  margin-left: 30px;
  margin-bottom: 10px;
  font-size: 20px;
}
.area-list li a,.area-list li span {
  color: #000;
  text-decoration: none;
  padding-left: 20px;
  letter-spacing: 0.05em;
}
.area-list li a:hover,.area-list li.current span {
  color: #000000;
  text-decoration: underline;
  display: inline-block;
  position: relative;
}
.area-list li a:hover::before, .area-list li a:focus::before,
.area-list li.current span::before{
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 17px; /* ▶画像の幅 */
  height: 12px; /* ▶画像の高さ */
  background-image: url('images/arrow.png');
  background-size: contain;
  background-repeat: no-repeat;
}


@media print and (max-width: 750px), screen and (max-width: 750px) {
	.fv li img {
    max-width: auto !important;
    height: 300px !important;
    object-fit: cover;
  }
	.areaname{width:292px;height:auto;bottom: -70px;}
	.area-lead {
    display: block;
	}
	.area-lead h2{width:100%;font-size:26px;margin-bottom:40px;}
	.lead-txt {
    width: 100%;
    padding-bottom: 100px;
}
	.map-space {
    width: 100%;
}
	.iruma-map{    width: 100vw; /* ビューポート幅いっぱいにする */
    margin-left: -20px !important; /* .wrap-area の padding を相殺 */
    margin-right: -20px;}
	.responsive-map {
    width: 100%;
    max-width: 100%;
}
	.area-select {
	margin-top: 0;
	}
	.wrap-map{flex-direction: column;}
	.area-list{margin:10px auto;background: #F8F7D9; padding-top: 30px;}
	.area-select h3 {
    font-size: 18px;
}
	.area-list li {
	font-size: 16px;
    border: solid 2px;
    border-radius: 8px;
    margin-left: 0px;
    padding: 3px 15px 05px 5px;
    text-align: center;
	background: #fff;
}
	
}

/*	---------------------------
   		display control
	--------------------------- */

.spDisplayNone {}
.tbDisplayNone {}
.pcDisplayNone {}


/* for SP */
@media screen and (max-width: 767px) {
		.spDisplayNone {display:none;}
		.smartContainer {margin: 0 15px;color: #111;}
		/*.wrap {margin: 0 20px}*/
}

/* for TB  */
@media screen and (max-width: 1024px) and (min-width: 768px){
		.tbDisplayNone {display:none;}
		.smartContainer {margin: 0 20px;}
}

/* for PC */
@media screen and (min-width: 1025px) {
		.container { width:1024px;}
		.pcDisplayNone {display:none;}
}
/* ============================
	accessSection
 ============================ */



.accessSection .container {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
@media screen and (min-width: 1025px) {
.accessSection .container {
        width: 1024px;
    }
}

.accessSection {position: relative;color: #111111;margin-top: 80px;}

.accesstitle {
    font-size: 18px;
    font-weight: bold;
}

.accessSection img {
width: 100%;
}

.accessSection h1 {
width: 180px;
}

.accessSection h3 {
font-size: 14px;
line-height: 1.75em;
margin-top: 40px;
font-weight: bold;
letter-spacing: 0.03em;
}

.accessSection .route_box {box-sizing: border-box;}

.accessSection .routeMap {width: auto;overflow: auto;margin-top: 5px;border: none;padding: 30px;border-radius: 10px;box-shadow: 0px 0px 5px 3px #ccc inset;height: 420px;box-sizing: content-box;background: #fff;}

.accessSection .routeMap img {width: auto;max-width: inherit;}

.accessSection .route_box .title {
text-align: center;
}

.accessSection .note {
font-size: 10px;
font-weight: normal;
margin-top: 10px;
line-height: 1.25em;
}

.accessSection .commute {
margin-top: 40px;
position: relative;
}

.accessSection .commute .train {
position: relative;
z-index: 1;
margin: 0 20px 30px 20px;
}

.accessSection .commute .laview{
position: absolute;
top: 10px;
left: 20px;
width: 240px;
}

.accessSection .sim {background-color: #689D4C;padding: 60px 25px;margin-top: 60px;}

.accessSection .sim .image {

}

.accessSection .sim .note02 {
font-size: 10px;
color: #fff;
line-height: 1.25em;
margin-top: 20px;
}


/* for PC */
@media screen and (min-width: 1025px) {
	
	.accessSection {
	/* margin-top: 150px; */
	}
	
.accesstitle {
    font-size: 28px;
    font-weight: bold;
}

	.accessSection .route_box {
	
	}
	
	.accessSection .route_box .title {
	width: auto;
	}

	.accessSection .routeMap {
	width: 100%;
    overflow: visible;
    margin-top: 55px;
    border: none;
    padding: 0;
    border-radius: 0;
    box-shadow: none;
    height: auto;
	}

	.accessSection .routeMap img {
	width: 100%;
	}

	.accessSection .commute {
	position: relative;
	margin-top: -40px;
	}

	.accessSection .commute .train {
	margin-bottom: 60px;
	margin-top: 10px;
	}

	.accessSection .commute .laview{
    top: 20px;
    left: -150px;
    width: 260px;
	}
	
	.accessSection .sim {
	padding: 100px 0;
	margin-top: 100px;
	}
}

/* for SP */
@media print and (max-width: 750px), screen and (max-width: 750px) {	
	.accessSection {margin-top: 50px;}
	}



/* ▼エリアページ */
@media print, screen and (min-width: 1000px) {
  .wrap-area {
    width: 90% !important;
  }
}
.wrap-area {
  display: flex !important;
  justify-content: space-between;
  gap: 20px;
  width: 100%;
  box-sizing: border-box;
  padding-top: 60px;
  padding-bottom: 20px;
}
@media print and (max-width: 750px), screen and (max-width: 750px) {
	.wrap-area {
  padding-top: 20px;
}
}
.area-map, .area-intro {
  width: 48%;
  box-sizing: border-box;
}
.responsive-map2 {
    width: 100%;
    height: auto;
    display: block;
}


.area-intro h3 {
  font-size: 35px;
  letter-spacing: 0.1em;
  padding: 5px;
  margin-bottom: 20px;
  font-weight: bold;
  color: #FFFFFF;
  border-radius: 10px;
}
.area-intro h3.seibu{  background: #FFB115;}
.area-intro h3.kaneko{  background: #ff877e;}
.area-intro h3.higashi-kaneko{  background: #7cbff6;}
.area-intro h3.miyadera{  background: #d16dad;}
.area-intro h3.toyooka{  background: #bcd85f;}
.area-intro h3.fujisawa{  background: #f0e42f;}
.area-intro p {
  text-align: left;
  margin-bottom: 20px;
}
#slider img {
  border-radius: 16px;
  object-fit: cover;
}


/* 共通スタイル */
.select02 .area-list {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.select02 .area-list ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 30px; /* アイテム間の余白 */
  padding: 0;
  margin: 0;
  list-style: none;
  justify-content: center;
}

.select02 .area-list li {
  /* width: 160px; */ /* 先頭文字を揃えるため固定幅 */
  font-size: 20px;
  text-align: left;
	margin-left: 0px;
	margin-bottom: 0px;
	letter-spacing: 0.05em;
	font-weight: 600;
}


.select02 .area-list li a,
.select02 .area-list li span {
  display: block;
  padding: 5px 10px;
  border-radius: 15px;
}

/* hover・active 状態 */
.select02 .area-list li a:hover::before,
.select02 .area-list li a:focus::before,
.select02 .area-list li.current span::before {
  display: none;
}

.select02 .area-list li.current:nth-child(1) span,
.select02 .area-list li:nth-child(1) a:hover {
  background: #FFB115;
  font-weight: bold;
}
.select02 .area-list li.current:nth-child(2) span,
.select02 .area-list li:nth-child(2) a:hover {
  background: #ff877e;
  font-weight: bold;
}
.select02 .area-list li.current:nth-child(3) span,
.select02 .area-list li:nth-child(3) a:hover {
  background: #7cbff6;
  font-weight: bold;
}
.select02 .area-list li.current:nth-child(4) span,
.select02 .area-list li:nth-child(4) a:hover {
  background: #bcd85f;
  font-weight: bold;
}
.select02 .area-list li.current:nth-child(5) span,
.select02 .area-list li:nth-child(5) a:hover {
  background: #d16dad;
  font-weight: bold;
}
.select02 .area-list li.current:nth-child(6) span,
.select02 .area-list li:nth-child(6) a:hover {
  background: #f0e42f;
  font-weight: bold;
}

.select02 .area-list li a:hover,
.select02 .area-list li.current span {
  color: #fff;
  text-decoration: none;
  position: relative;
  border-radius: 10px;
}

.select02 h4 {
  font-size: 20px;
  padding: 40px;
}

/* スマホ（750px以下） */
@media screen and (max-width: 750px) {
	.select02 .area-list {
	background-color: #fff;
	padding: 15px 10px;
	}

  .select02 .area-list ul {
    display: grid;
    grid-template-columns: 1fr 1fr; /* 2カラム */
    gap: 10px;
  }

  .select02 .area-list li {
    width: auto; /* 自動幅に戻す */
	font-size: 16px;
	text-align: center;
	letter-spacing: 0;
	border: none;
	padding: 0;
  }

  .select02 h4 {
    font-size: 17px;
    padding: 20px;
  }
}


.area-miryoku {
  width: 100% !important;
  background: #FAE5BC;
  border-radius: 16px;
  padding: 60px 0;
}
.area-miryoku h2 {
  font-size: 30px;
  padding: 5px 30px;
  display: inline-block;
  margin: 0 auto 30px;
  background: #ffffff;
  border-radius: 10px;
  font-weight: bold;
  color: #ff8c00;
  letter-spacing: 0.05em;
}
.flex-miryoku {
  width: 90%;
  display: flex;
  justify-content: space-between;
  gap: 40px;
  margin: 0 auto;
}
.item-miryoku {
  width: 25%
}
.item-miryoku .num {
  position: relative;
  display: inline-block;
  font-size: 24px;
  margin-bottom: 20px;
  font-weight: 600;
}
.item-miryoku .num::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -5px; /* 下線の距離を調整（ここを変更） */
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: #000; /* 線の色 */
}
.item-miryoku .num h3 {
  height: auto!important;
}
.item-miryoku h3 {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 20px;
}
.miryoku-img img {
  max-width: 100%;
  height: auto;
  display: block;
  margin-bottom: 20px;
  border-radius: 10px;
}
.miryoku-txt {
  text-align: left;
  margin-bottom: 20px;
}


@media screen and (min-width: 751px) {
	.item-miryoku{
padding: 20px;
border-radius: 15px;}
}


/* ▼ 各テーマの背景色 */
.item-miryoku.theme-access {
  background-color: #fcfbe6;
}
.item-miryoku.theme-child {
  background-color: #D9EAF6;
}
.item-miryoku.theme-shop {
  background-color: #F6D9E8;
}
.item-miryoku.theme-leisure {
  background-color: #E8F6D9;
}


/* ▼ 非アクティブ時でも枠線が出るように */
.tab-buttons button.theme-access {
  border: 2px solid #fcfbe6;
}
.tab-buttons button.theme-child {
  border: 2px solid #D9EAF6;
}
.tab-buttons button.theme-shop {
  border: 2px solid #F6D9E8;
}
.tab-buttons button.theme-leisure {
  border: 2px solid #E8F6D9;
}


/* ▼ スマホのアクティブタブボタンの色も同様に */
.tab-buttons button.theme-access.active {
  background-color: #fcfbe6;
}
.tab-buttons button.theme-child.active {
  background-color: #D9EAF6;
}
.tab-buttons button.theme-shop.active {
  background-color: #F6D9E8;
}
.tab-buttons button.theme-leisure.active {
  background-color: #E8F6D9;
}

/* ▼ タブボタンの枠線（active時） */
.tab-buttons button.theme-access.active {
  border-color: #fcfbe6;
}
.tab-buttons button.theme-child.active {
  border-color: #D9EAF6;
}
.tab-buttons button.theme-shop.active {
  border-color: #F6D9E8;
}
.tab-buttons button.theme-leisure.active {
  border-color: #E8F6D9;
}

/* ▼ コンテンツ（item-miryoku）の枠線色 */
.item-miryoku.theme-access {
  border: 2px solid #fcfbe6;
}
.item-miryoku.theme-child {
  border: 2px solid #D9EAF6;
}
.item-miryoku.theme-shop {
  border: 2px solid #F6D9E8;
}
.item-miryoku.theme-leisure {
  border: 2px solid #E8F6D9;
}
@media screen and (max-width: 750px) {
  .item-miryoku {
    display: none;
  }

  .item-miryoku.active {
    display: block;
  }
}

/* ▼ タブボタン表示（スマホのみ） */



@media screen and (min-width: 751px) {
  .tab-buttons {
    display: none;
  }
}
@media screen and (max-width: 750px) {
  .tab-buttons {
    display: flex;
    justify-content: space-around;
    margin: 0 auto 0px;
    width: 100%;
    gap: 5px;
  }

  .tab-buttons button {
    flex: 1;
    padding: 10px 6px;
    font-size: 16px;
    border-bottom: none;
    background: #fff;
    border-radius: 10px 10px 0 0;
    font-weight: normal;
    cursor: pointer;
	  color: #000; /* ← 黒に統一 */
  text-decoration: none; /* 念のため下線も消す */
	font-weight: 600;
  }

  .tab-buttons button.active {
    background: #fff;
    font-weight: bold;
    border-bottom: 1px solid #fff;
  }

  .flex-miryoku {
	  width:100%;
    flex-direction: column;
    gap: 0;
  }

  .item-miryoku {
    width: 100% !important;
    display: none;
    background: #fff;
    border: 1px solid #ccc;
    border-top: none;
    border-radius: 0 0 10px 10px;
    padding: 20px;
    box-sizing: border-box;
  }

  .item-miryoku.active {
    display: block;
  }

  /* スマホ用のh3やテキスト微調整（任意） */
  .item-miryoku h3 {
    font-size: 16px;
  }

  .item-miryoku .num {
    font-size: 28px;
  }
}

.remap{padding:40px;background: #ffffff;border-radius:16px;box-shadow: 0 0 5px rgba(0,0,0,0.2);margin:40px 0;width: 1440px !important;max-width: 100%;}
.remap h3{font-size:40px;color:#689D4C;font-weight:bold;text-align:left;padding: 0 40px;}
#REMapframe{margin:0 auto;padding:0 40px;max-width: 1440px !important;}

.area_bukken{background:#76C74B;margin-top:40px;width:100% !important;padding: 40px 0;}
.area_bukken {
  overflow-x: hidden;
}
.area_bukken h3{font-size:40px;text-align:center;color:#ffffff;padding: 20px;font-weight: bold;}

.bukken_img {
      width: 100%;
      aspect-ratio: 3 / 2; /* ←ここで3:2比率に固定 */
      overflow: hidden;
      background: #eee; /* 画像読み込み前にグレー背景でもつけとくとよい */
    }

    .bukken_img a {
      display: block;
      width: 100%;
      height: 100%;
    }

    .bukken_img img {
      width: 100%;
      height: 100%;
      object-fit: cover; /* ←トリミングして隙間なく敷き詰め */
      display: block;
    }
.area_bukken .bx-wrapper {
  background-color: #76C74B;
  padding: 20px 0;
  overflow: visible !important;	
}
#bukken_slider .bx-wrapper, 
#bukken_slider .bx-viewport {
  position: relative;
  z-index: 1;
  overflow: visible !important; /* はみ出しOK */
}

#bukken_slider li {
  position: relative;
  z-index: 2;
}

#bukken_slider li {
  overflow: visible !important;
}
.property-box {
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 0 5px rgba(0,0,0,0.2);
  height: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

.property-box a {
  pointer-events: auto !important;
  z-index: 10;
  position: relative;
  display: inline-block;
　color: #006400 !important;
  text-decoration: none;
}

.property-box a:link {
　color: #006400!important;	
}

.property-box h4{text-align:center;font-size:18px;font-weight:bold;margin-bottom:20px;}

.bukken_img img{margin:0 auto}
.info-box {
  font-family: sans-serif;
  text-align: center;
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  padding: 0 20px;
}

.info-section {
  padding: 20px 0 0;
}

.info-label {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 8px;
  gap: 0.5em;
  font-size: 12px;
  color: #666;
}
.info-label span{display: inline-block;width:5em;}

.info-label .line {
  flex-grow: 1;
  height: 1px;
  background-color: #000;
}

.info-content {
  font-size: 14px;
  line-height: 1.6;
	text-align: left;
	margin-left:1em;
}

@media print and (max-width: 750px), screen and (max-width: 750px) {
  .wrap-area {
    flex-direction: column;
	margin-bottom: 30px;
  }
  .area-map {
	width: 100vw;
    margin-left: -20px;
    margin-right: -20px;
  }

	
	
.area-intro {
    width: 100%;
  }
  .area-intro h3 {
    font-size: 20px;
  }
  .area-miryoku h2 {
    font-size: 18px;
  }
  .flex-miryoku {
    flex-direction: column
  }
  .item-miryoku {
    width: 100%;
  }
	.item-miryoku .num{display:none}
	.area_bukken h3{font-size:20px;}
	#REMapframe{margin:0 auto;padding:0 0px}
	.remap{margin:20px 0;}
.remap h3{font-size:20px;text-align:center;}
}

.area_bukken .bx-controls.bx-has-pager {
    height:20px;
}

.area_bukken .bx-viewport {
  pointer-events: auto !important; /* ← これが最重要 */
  overflow: visible !important;
  position: relative;
  z-index: 1;
}
