@charset "utf-8";

img {
    image-rendering: -webkit-optimize-contrast;
}


.mainimg_area {
    margin-top: 0%;
    margin-bottom: 0%;
    margin-left: 0px;
    margin-right: 0px;
    /*position: relative;*/
}

/*========= スクロールダウンのためのCSS ===============*/
/*.arrow_area {    
    position: relative;
	padding-bottom: -25%;
}*/

/*スクロールダウン全体の場所*/
.scrolldown4{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:1%;
  right:50%;
    /*矢印の動き1秒かけて永遠にループ*/
  animation: arrowmove 1s ease-in-out infinite;
	z-index: 111;
}



/*下からの距離が変化して全体が下→上→下に動く*/
@keyframes arrowmove{
      0%{bottom:1%;}
      50%{bottom:3%;}
     100%{bottom:1%;}
 }

/*Scrollテキストの描写*/
.scrolldown4 span{
    /*描画位置*/
  position: absolute;
  left:-20px;
  bottom:10px;
    /*テキストの形状*/
  color: #000;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  /*縦書き設定*/
  -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
}

/* 矢印の描写 */
.scrolldown4:before {
    content: "";
    /*描画位置*/
    position: absolute;
    bottom: 0;
    right: -10px;
    /*矢印の形状*/
    width: 2px;
    height: 35px;
    background: #000;
    transform: skewX(-31deg);
}

.scrolldown4:after{
  content:"";
    /*描画位置*/
  position: absolute;
  bottom:0;
  right:0;
    /*矢印の形状*/
  width:2px;
  height: 120px;
  background:#000;
}

.top_main_ttl{
    font-size: 32px;
    margin-top: 5%;
    margin-bottom: 1%;
    padding-bottom: 10px;
    border-bottom: 1px solid #000000;
    text-align: center;
	line-height: 1.7;
	font-weight: 500;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
}
@media screen and (max-width:500px) {
.top_main_ttl{
    font-size: 24px;
	text-align: left;
	padding-left: 7%;
	}
	}
.top_main_read{
    font-size: 1.5rem;
    line-height: 1.8;
    margin-top: 3%;
    margin-bottom: 8%;
    color: #000;
    text-align: center;
}

@media screen and (max-width:500px) {
.top_main_read {
    font-size: 1.3rem;
    line-height: 1.6;
    padding-left: 8%;
    padding-right: 8%;
    text-align: left;
}
}

/* title_box
------------------------------------------------------------*/
.title_box {    
    padding-top: 0%;
    padding-bottom: 0%;
    margin-left: 0px;
    margin-right: 0px;  
	text-align: center;
    margin-right: auto;
    margin-left: auto;
}
@media screen and (max-width:575px) {
.title_box {    
    padding-bottom: 0%;
    margin-bottom: 5%;
    
}
}
.title_box img {
    text-align: center;
    margin-right: auto;
    margin-left: auto;  
	padding-bottom: 0%!important;
}
.title_box_tx {
    font-size: 1.7rem;
    line-height: 1.8;
    margin-top: 5px;
	margin-bottom: 3%;
    color: #4d4d4d;
	text-align: center;
	font-weight: 500;
}
@media screen and (max-width:575px) {
.title_box_tx {    
	font-size: 1.35rem;
	margin-bottom: 4%;
	/*text-align: left;*/
}
}

/* ttl
------------------------------------------------------------*/
.h2_ttl {    
    font-size: 40px;
    margin-top: 5px;
	margin-bottom: 0px;
    color: #333;
	text-align: center;
	font-weight: 500;
}
@media (max-width: 991px) {
.h2_ttl {
    font-size: 30px;
}
}

.h2_ttl span {
	font-size: 20px;
	display: block;
}
.h2_subttl {
	font-size: 18px;
	margin-top: 0px;
	margin-bottom: 5px;
	color: #333;
	text-align: center;
	font-weight: 500;
	letter-spacing: 0.2em;
}
.ttl_read {    
    font-size: 25px;
    margin-top: 5px;
	margin-bottom: 25px;
    color: #333;
	text-align: center;
	font-weight: 500;
}
@media (max-width: 991px) {
.ttl_read {
    font-size: 19px;
}
}
.ttl_tx {    
    font-size: 16px;
    margin-top: 5px;
	margin-bottom: 5px;
    color: #333;
	text-align: center;
	font-weight: 500;
}
@media (max-width: 575px) {
.ttl_tx {        
	text-align: left;
	font-size: 15px;
}
}
.h2_ttl_w {    
    font-size: 40px;
    margin-top: 5px;
	margin-bottom: 0px;
    color: #fff;
	text-align: center;
	font-weight: 500;
}
@media (max-width: 991px) {
.h2_ttl_w {
    font-size: 25px;
}
}
.h2_subttl_w {
	font-size: 18px;
	margin-top: 0px;
	margin-bottom: 5px;
	color: #fff;
	text-align: center;
	font-weight: 500;
	letter-spacing: 0.2em;
}
.ttl_read_w {    
    font-size: 25px;
    margin-top: 5px;
	margin-bottom: 25px;
    color: #fff;
	text-align: center;
	font-weight: 500;
}
@media (max-width: 991px) {
.ttl_read_w {
    font-size: 19px;
}
}

/*@media (max-width: 767px) {
.ttl_img {
    max-width: 280px;
}
}*/



/* mapimg_area
------------------------------------------------------------*/
.mapimg_area {
    position: relative;
    padding-top: 1%;
    padding-bottom: 1%;
    margin-left: 0px;
    margin-right: 0px;    
}

.mapimg_area img {
    text-align: center;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 5%;
}

/*Googlemap風地図*/
.maps_box {
  width: 100%;
  height: 450px;
  overflow: hidden;
  position: relative;
  touch-action: none;
}

.map-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: max-content;
  height: max-content;
  transform-origin: 0 0;
}


.map-inner img {
  width: auto;     /* ← ここが命 */
  height: auto;    /* ← ここが命 */
  max-width: none; /* ← 制限解除 */
  max-height: none;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}
/*Googlemap風地図END*/


/* access
------------------------------------------------------------*/
.access_area {
    border-bottom: 5px solid #F08300;
	padding-bottom:4%;
	margin-bottom:2%;
}
@media (max-width: 575px) {
.access_area {
	margin-top: 10%;
	padding-left: 10px;
	padding-right: 10px;
}
}
@media (max-width: 575px) {
.access_area img {
	margin-bottom: 30px;
}
}
.access_box {    
    padding-bottom: 5%;
}
/*.access_box img {    
    padding-top: 5%;
}*/
.access_tx {
    font-size: 25px;
    margin-top: 5px;
	margin-bottom: 5px;
    color: #333;
}
@media (max-width: 991px) {
.access_tx {
    font-size: 18px;
}
}
.access_tx span {
    font-size: 40px;
}
@media (max-width: 991px) {
.access_tx span {
    font-size: 25px;
}
}
.access_tx2 {
	font-size: 18px;
	margin-top: 5px;
	margin-bottom: 5px;
	color: #333;
	line-height: 1.2;
}
@media (max-width: 991px) {
.access_tx2 {
    font-size: 15px;
}
}
.access_read {
    font-size: 25px;
    margin-top: 0px;
	margin-bottom: 0px;
    color: #333;
	line-height: 1.2;
}
@media (max-width: 991px) {
.access_read {
    font-size: 18px;
}
}
@media (max-width: 575px) {
.access_read {
    text-align: center;
}
}
.access_read2 {
    font-size: 40px;
    margin-top: 5px;
	margin-bottom: 0px;
	line-height: 1.2;
    color: #333;
}
@media (max-width: 991px) {
.access_read2 {
    font-size: 25px;
}
}
@media (max-width: 575px) {
.access_read2 {
    text-align: center;
}
}
.access_read2 span {
    font-size: 25px;
    
}
@media (max-width: 991px) {
.access_read2 span {
    font-size: 18px;
}
}
.access_read3 {
    font-size: 16px;
    margin-top: 25px;
	margin-bottom: 5px;
    color: #333;
}
@media (max-width: 991px) {
.access_read3 {
    font-size: 14px;
}
}
.line {
	margin-top: 5%;
	margin-bottom: 5%;
	border-top: 1px solid rgba(0,0,0,1.00);
}


/* location_area
------------------------------------------------------------*/
.location_area {
    position: relative;
    padding-top: 5%;
    padding-bottom: 0%;    
}
@media (max-width: 575px) {
.location_area {
	padding-left: 10px;
	padding-right: 10px;
}
}
.location_box {    
    padding-bottom: 5%;
	position: relative;
	width: 100%;
	line-height: 0;
}
@media (max-width: 575px) {
.location_box {	
    margin-bottom: 30px; 
}
}
.loca_button_box {
	position: absolute;
    z-index: 1;
    bottom: 25%; /* 50%から数値を上げると下に下がります */
left: 53vw;    
    text-align: center;
}
@media (max-width: 991px) {
.loca_button_box {	
    bottom: 20%; /* 50%から数値を上げると下に下がります */
}
}
@media (max-width: 575px) {
.loca_button_box {	
    bottom: 8%; /* 50%から数値を上げると下に下がります */
left: 15vw;    
}
}
.loca_button a {
    background: #f08300;
    border-radius: 9999px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0 auto;
    max-width: 350px;
    padding: 10px 55px;
    font-family: "Noto Sans Japanese";
    color: #fff;
    line-height: 1.8;
    text-decoration: none;
    transition: 0.3s ease-in-out;
    font-weight: 500;
}
@media (max-width: 991px) {
.loca_button a {
    margin: 0 auto;
    max-width: 250px;
    padding: 5px 25px;
}
}
@media (max-width: 576px) {
.loca_button a {
    margin: 0 auto;
    max-width: 450px;
    padding: 10px 55px;
}
}
.loca_button a:hover {
    background: #333333;
    color: #FFF;
}
.loca_button a:after {
    content: '';
    width: 5px;
    height: 5px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: rotate(45deg) translateY(-50%);
    position: absolute;
    top: 50%;
    right: 20px;
    border-radius: 1px;
    transition: 0.3s ease-in-out;
}
.loca_button a:hover:after {
    border-color: #FFF;
}

/* ================================
   モーダルの背景（暗くなる部分）
================================ */
.modal-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.85);
  z-index: 9999;

  display: flex;
  justify-content: center;
  align-items: flex-start;      /* ★ 中央寄せをやめて上基準 */

  padding: 20px;                /* 上下左右の余白 */
  box-sizing: border-box;

  /* 初期状態 */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s cubic-bezier(0.25, 1, 0.5, 1),
              visibility 0.4s;
}

/* 表示中 */
.modal-overlay.is-active {
  opacity: 1;
  visibility: visible;
}

/* ================================
   モーダル本体
================================ */
.modal-content {
  position: relative;
  width: 100%;
  max-width: 800px;

  /* ★ 画面高さ − overlay の上下padding分 */
  max-height: calc(100vh - 40px);

  display: flex;
  flex-direction: column;

  transform: translateY(20px);
  transition: transform 0.4s ease;
}

.modal-overlay.is-active .modal-content {
  transform: translateY(0);
}

/* ================================
   中身スクロール領域
================================ */
.modal-body {
  overflow-y: auto;
  background: #fff;
  -webkit-overflow-scrolling: touch;
}

.modal-body img {
  width: 100%;
  display: block;
}

/* ================================
   閉じるボタン
================================ */
.close-button {
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: 38px;
  font-weight:700;
  color: #333;
  cursor: pointer;
  line-height: 1;
  z-index: 10;
}

/* ================================
   背景固定
================================ */
html.modal-open,
body.modal-open {
  overflow: hidden;
  /*height: 100%;*/
}


.location_box2 {    
    padding-bottom: 1%;
}
/*.location_box2 img {    
    padding-top: 5%;
}*/
.location_lpp_box {    
    padding-left: 5%;
}
@media (max-width: 767px) {
.location_lpp_box {    
    padding-left: 0%;
	padding-top: 30px;
}
}
.location_rpp_box {    
    padding-right: 5%;
}
@media (max-width: 767px) {
.location_lpp_box {    
    padding-right: 0%;
	padding-top: 30px;
}
}
.location_tx {
    font-size: 25px;
    margin-top: 5px;
	margin-bottom: 0px;
    color: #333;
}
@media (max-width: 991px) {
.location_tx {
    font-size: 18px;
}
}

.location_tx2 {
	font-size: 18px;
	margin-top: 5px;
	margin-bottom: 5px;
	color: #333;
	line-height: 1.2;
}
@media (max-width: 991px) {
.location_tx2 {
    font-size: 15px;
}
}
.location_read {
    font-size: 25px;
    margin-top: 0px;
	margin-bottom: 0px;
    color: #333;
	line-height: 1.2;
}
@media (max-width: 991px) {
.location_read {
    font-size: 18px;
}
}
.location_read2 {
    font-size: 40px;
    margin-top: 5px;
	margin-bottom: 0px;
	line-height: 1.2;
    color: #333;
}
@media (max-width: 991px) {
.location_read2 {
    font-size: 25px;
}
}
.location_read2 span {
    font-size: 25px;
    
}
@media (max-width: 991px) {
.location_read2 span {
    font-size: 18px;
}
}
.location_read3 {
    font-size: 16px;
    margin-top: 15px;
	margin-bottom: 5px;
    color: #333;
}
@media (max-width: 991px) {
.location_read3 {
    font-size: 14px;
}
}
@media (max-width: 767px) {
.location_read3 {    
	margin-bottom: 25px;
	margin-top: 10px;
    color: #333;
}
}
.location_read4 {
    font-size: 16px;
    margin-top: 0px;
	margin-bottom: 5px;
    color: #333;
}
@media (max-width: 991px) {
.location_read4 {
    font-size: 14px;
}
}

/* land_area
------------------------------------------------------------*/
.land_area {
	position: relative;
	padding-top: 5%;
	padding-bottom: 5%;
	background-image: url("../images/home/bg.jpg");	
	background-size: cover;
	background-position: center center;
}
.land_area img {
    padding-bottom: 5%;
}
.land_box{
	margin-bottom:10px;
}
/*.land_photo {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-template-rows: auto;
	column-gap: 20px;
	row-gap: 20px;
	margin-left: 30px;
	margin-right: 30px;
}
@media (max-width: 575px) {
.land_photo {
	grid-template-columns: repeat(2, 1fr);	
}
}*/
.local_ttl{
    font-size:28px;
	border-bottom: 2px dashed #008d98;
	padding-bottom:10px;
	margin-top:2%;
	text-align:center;
}
.local_read{
    font-size:20px;
	margin-top:10px;
	margin-bottom:3%;
	text-align:center;
}
@media (max-width: 991px) {
.local_ttl{
    font-size:24px;
	margin-top:8%;
}
.local_read{
    font-size:18px;
	margin-bottom:8%;
}
}
/* plan_area
------------------------------------------------------------*/
.plan_area {
	position: relative;
	padding-top: 5%;
	padding-bottom: 5%;	
}
.plan_box {
    position: relative;
    padding-top: 5%;
    padding-bottom: 5%;
    /*background-image: url("../images/home/bg.jpg");	
    background-size: cover;
    background-position: center center;*/
    border-bottom-width: 1px;
    border-bottom-style: dashed;
	/*margin-bottom:5%;*/
}
.plan_box2 {
	position: relative;
	padding-top: 5%;
	padding-bottom: 5%;
	/*margin-bottom:5%;*/
}

/* model_area
------------------------------------------------------------*/
.model_area {
	position: relative;
	padding-top: 5%;
	padding-bottom: 5%;	
}
.model_box {
	position: relative;
	padding-top: 5%;
	padding-bottom: 5%;
	
}

/* structure_area
------------------------------------------------------------*/
.structure_area {
	position: relative;
	padding-top: 5%;
	padding-bottom: 0%;
}
@media (max-width: 575px) {
.structure_area {
	padding-left: 10px;
	padding-right: 10px;
}
}
.structure_box {    
    padding-top: 5%;
}
.structure_box img {	
	padding-bottom: 20px;
}
.structure_area2 {
	position: relative;
	padding-top: 0%;
	padding-bottom: 0%;
}
@media (max-width: 575px) {
.structure_area2 {
	padding-left: 10px;
	padding-right: 10px;
}
}

/* map_area
------------------------------------------------------------*/
.map_area {
    position: relative;
    padding-top: 5%;
    padding-bottom: 5%;
    margin-left: 0px;
    margin-right: 0px; 
	background-image: url("../images/home/bg.jpg");	
	background-size: cover;
	background-position: center center;
}

.map_box {
  margin-bottom: 5%;
}
.map_box iframe {
  width: 100%;
}

/* outline_area
------------------------------------------------------------*/

.outline_area {
	position: relative;
	padding-top: 5%;
	padding-bottom: 5%;
	background-image: url(../images/home/bg.jpg);
	background-size: cover;
	background-position: center center;
}
@media (max-width: 575px) {
.outline_area {
	padding-left: 10px;
	padding-right: 10px;
}
}
.s_table {
  clear: both;
  width: 100%;
  margin-top: 5%;
  margin-bottom: 15px;
  margin-right: auto;
  margin-left: auto;
  color: #000;
  padding-top: 3%;
  padding-right: 3%;
  padding-bottom: 3%;
  padding-left: 3%;
}
.s_table th {
	font-weight: bold;
	width: 20%;
	font-size: 1.5rem;
	background-color: rgba(228,228,228,0.1);
}
.s_table td {
  font-size: 1.5rem;
}
@media (max-width: 576px) {
  .s_table th {
    width: 30%;
    font-size: 1.3rem;
  }
  .s_table td {
    font-size: 1.3rem;
  }
}
.s_table th, .s_table td {
  padding: 2%;
  line-height: 1.4;
  border-bottom: 1px solid #C3C3C3;
}
.outline_tx {
    font-size: 1.4rem;
    line-height: 1.9;
    margin-top: 3%;
	margin-bottom: 3%;
}
[id] {
  scroll-margin-top: 100px; /* ヘッダーの高さ分＋αを指定 */
}
