@charset "UTF-8";
.property .property-btn a {
  text-decoration: none;
}
.property .property-btn a:hover {
  opacity: 0.8;
}
/* ========================================
  @media screen and (min-width: 768px), print
======================================== */
@media screen and (min-width: 768px), print {
/* common
-------------------------------------*/
.sec-ttl {
  background: #FBCEA3;
  font-weight: 800;
  font-size: clamp(1.375rem, 1.041rem + 0.7vw, 1.875rem);
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-align: center;
  display: flex;
  justify-content: center;
  padding: 22px 0;
  gap: 31px;
  margin-bottom: 100px;
}
.sec-ttl span {
  color: #FFFFFF;
  letter-spacing: 0.05em;
}

  /* mv
-------------------------------------*/
.mv .img-box {
  position: relative;
  margin-bottom: 70px;
}
.mv .ttl {
  position: absolute;
  bottom: -3%;
  left: 50%;
  transform: translateX(-50%);
  top: unset;
}
.mv .lead {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  color: #d61518;
  margin-bottom: 27px;
}
.mv .list {
  display: grid;
  gap: 16px;
  width: min(95%, 304px);
  margin-inline: auto;
  padding-bottom: 117px;
}
.mv .list li {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
  text-align: left;
}

/* property
-------------------------------------*/
.property {
  padding-bottom: 134px;
}
.property .list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 50px;
  width: min(95%, 1600px);
  margin-inline: auto;
  margin-bottom: 96px;
}
.property .list li .img {
  margin-bottom: 20px;
}
.property .list li .img img {
  width: 100%;
  height: 300px;
  object-fit: contain;
}
.property .list li table {
  background: #fff;
  border: 2px solid #999;
  width: 100%;
  margin-bottom: 49px;
}
.property .list li table tr {
  border-bottom: 2px solid #999;
}
.property .list li table th, .property .list li table td {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.2;
  height: 90px;
  vertical-align: middle;
}
.property .list li table th {
  background: #E0E0E0;
  border: 2px solid #999;
  width: 23.5%;
  text-align: center;
}
.property .list li table td {
  padding: 0 20px;
  font-weight: 700;
}
.property .list li table .price {
  color: #D40000;
}
.property .list li .btn {
  border-radius: 10px;
  background: #cfd7e4;
}
.property .list li .btn a{
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-align: center;
  display: block;
  padding: 16px 0;
}
.property .property-btn {
  width: min(95%, 500px);
  margin-inline: auto;
  border-radius: 10px;
  background: #006db2;
}
.property .property-btn a {
  font-weight: 700;
  font-size: 25px;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-align: center;
  color: #fff;
  display: block;
  padding: 30px 0;
}

/* greeting
-------------------------------------*/
.greeting {
  position: relative;
  margin-bottom: 146px;
}
.greeting::before {
  position: absolute;
  content: "";
  width: 78.125%;
  height: 1744px;
  top: 9.4%;
  right: 0;
  pointer-events: none;
  background: #cfd7e4;
  opacity: 0.5;
  border-radius: 10px;
}
.greeting .inner {
  position: relative;
  width: min(95%, 1304px);
  margin-inline: auto;
}
.greeting .content {
  display: grid;
  grid-template-columns: 28.3286% 73.0736%;
  gap: 96px;
  padding: 57px 0 0;
  margin: 0 0 118px -108px;
  align-items: center;
}
.greeting .content .img{
  margin-bottom: 22px;
}
.greeting .content .img img {
  width: 100%;
  height: auto;
}
.greeting .content .name{
  display: flex;
  font-weight: 500;
  font-size: 25px;
  letter-spacing: 0.1em;
  line-height: 1.2;
  gap: 17px;
  margin: 0 0 0 46px;
}
.greeting .content .name span {
  font-weight: 500;
  font-size: 15px;
  line-height: 1.2;
  letter-spacing: 0;
}
.greeting .content h3 {
  font-weight: 700;
  font-size: 25px;
  line-height: 1.2;
  margin-bottom: 60px;
}
.greeting .content h3 span {
  color: #2fa02c;
  font-size: 30px;
}
.greeting .content .txt {
  font-weight: 700;
  font-size: 20px;
  line-height: 2.45;
}
.greeting .ytArea {
  width: 1280px;
  margin-inline: auto;
}
.greeting .ytArea iframe {
  width: 100%;
  height: 720px;
  border: 14px solid #fff;
}

/* blog-news
-------------------------------------*/
.blog-news {
  display: grid;
  grid-template-columns: 50% 50%;
  position: relative;
  padding-bottom: 201px;
}
.blog-news .sec-ttl {
  margin-bottom: 78px;
}
.blog-news .btn {
  border-radius: 10px;
  background: #cfd7e4;
  width: min(95%, 400px);
  margin-inline: auto;
}
.blog-news .btn a{
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-align: center;
  display: block;
  padding: 16px 0;
}

/* blog
-------------------------------------*/
.blog .blog-list {
  display: grid;
  gap: 80px;
  width: min(95%, 800px);
  margin-inline: auto;
  margin-bottom: 80px;
}
.blog .blog-item a {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 28px;
  align-items: center;
}
.blog .blog-thumb {
  text-align: center;
}
.blog .blog-thumb img {
  height: 200px;
  object-fit: contain;
}
.blog .blog-date {
  font-weight: 700;
  font-size: 15px;
  line-height: 1.2;
  color: #444;
  margin-bottom: 15px;
}
.blog .blog-ttl {
  font-weight: 700;
  font-size: 20px;
  line-height: 1.2;
}

/* news
-------------------------------------*/
.news {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 50%;
}
.news .news-list {
  width: min(95%, 380px);
  margin-inline: auto;
  display: grid;
  gap: 72px;
  margin-bottom: 77px;
  position: relative;
  left: 7px;
}
.news .news-item {
  position: relative;
  padding: 0 0 0 20px;
}
.news .news-item a {
  text-decoration: none;
}
.news .news-item::before {
  position: absolute;
  content: "◆";
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: 0;
  top: 50%;
  left: -20px;
  transform: translateY(-50%);
}
.news .news-ttl {
  font-weight: 700;
  font-size: 20px;
  line-height: 1.2;
  border-bottom: 1px solid #000000;
  padding: 0 0 5px;
  margin-bottom: 12px;
}
.news .news-date {
  font-weight: 700;
  font-size: 15px;
  line-height: 1.2;
  color: #444;
}

/* end-contact
-------------------------------------*/
.end-contact {
  background: url(../img/top/end-contact-bg.png) no-repeat center/100%;
  padding: 109px 0 94px;
  margin-top: 249px;
  margin-bottom: 40px;
}
.end-contact .logo {
  text-align: center;
  margin-bottom: 55px;
}
.end-contact .btn {
  width: min(95%, 500px);
  margin-inline: auto;
}
.end-contact .btn a{
  display: block;
  border-radius: 10px;
  background: #006db2;
  font-size: 30px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  position: relative;
  padding: 27px 41px;
  display: flex;
  gap: 31px;
}
.end-contact .btn a::after {
  position: absolute;
  content: "";
  background: url(../img/top/btn-arrow.png)no-repeat;
  background-size: contain;
  width: 10px;
  height: 18px;
  top: 50%;
  right: 39px;
  transform: translateY(-50%);
}
.end-contact .btn a span {
  color: #FFFFFF;
}

/* footer
-------------------------------------*/
.footer .map {
  width: 100%;
  margin: 0;
}

}


@media screen and (min-width:768px) and (max-width:1919px) {
/* mv
-------------------------------------*/
.mv .img-box {
  margin-bottom: 3.648vw;
}
.mv .img img {
  width: 100%;
  height: auto;
}
.mv .ttl {
  bottom: -3%;
  left: 50%;
  transform: translateX(-50%);
}
.mv .ttl img {
  width: 48.619vw;
}
.mv .lead {
  font-size: 1.563vw;
  margin-bottom: 1.407vw;
}
.mv .list {
  gap: 0.834vw;
  width: 15.842vw;
  padding-bottom: 6.097vw;
}
.mv .list li {
  font-size: 1.042vw;
}

}


@media screen and (min-width:768px) and (max-width:1440px) {
/* property
-------------------------------------*/
.property {
  padding-bottom: 9.306vw;
}
.property .list {
  gap: 3.472vw;
  margin-bottom: 6.667vw;
}
.property .list li .img {
  margin-bottom: 1.389vw;
}
.property .list li .img img {
  width: 100%;
  height: 20.833vw;
}
.property .list li table {
  margin-bottom: 3.403vw;
}
.property .list li table th, .property .list li table td {
  font-size: 1.389vw;
  height: 6.25vw;
}
.property .list li table td {
  padding: 0 1.389vw;
}
.property .list li .btn {
  border-radius: 0.694vw;
}
.property .list li .btn a{
  font-size: 1.389vw;
  padding: 1.111vw 0;
}
.property .property-btn {
  border-radius: 0.694vw;
}
.property .property-btn a {
  font-size: 1.736vw;
  padding: 2.083vw 0;
}
 
}


@media screen and (min-width:768px) and (max-width:1600px) {
 /* greeting
-------------------------------------*/
.greeting {
  margin-bottom: 14vw;
}
.greeting::before {
  width: 78.125%;
  height: 109vw;
  border-radius: 0.625vw;
}
.greeting .inner {
  width: 81.5vw;
}
.greeting .content {
  grid-template-columns: 28.3286% 73.0736%;
  gap: 6vw;
  padding: 3.562vw 0 0;
  margin: 0 0 7.375vw -6.75vw;
}
.greeting .content .img{
  margin-bottom: 1.375vw;
}
.greeting .content .img img {
  width: 100%;
  height: auto;
}
.greeting .content .name{
  font-size: 1.563vw;
  gap: 1.063vw;
  margin: 0 0 0 2.875vw;
}
.greeting .content .name span {
  font-size: 0.938vw;
}
.greeting .content h3 {
  font-size: 1.563vw;
  margin-bottom: 3.75vw;
}
.greeting .content h3 span {
  font-size: 1.875vw;
}
.greeting .content .txt {
  font-size: 1.25vw;
}
.greeting .ytArea {
  width: 80vw;
}
.greeting .ytArea iframe {
  width: 100%;
  height: 45vw;
}   
}


@media screen and (min-width:768px) and (max-width:1280px) {
/* blog-news
-------------------------------------*/
.blog-news {
  grid-template-columns: 50% 50%;
  padding-bottom: 11.719vw;
}
.blog-news .sec-ttl {
  margin-bottom: 6.094vw;
}
.blog-news .btn {
  border-radius: 0.781vw;
  width: 31.25vw;
}
.blog-news .btn a{
  font-size: 1.563vw;
  padding: 1.25vw 0;
}

/* blog
-------------------------------------*/
.blog .blog-list {
  /* gap: 6.25vw; */
  /* width: 35.781vw; */
  margin-bottom: 6.25vw;
}
.blog .blog-item a {
  grid-template-columns: 23.438vw 1fr;
  gap: 2.188vw;
  padding: 0 0 0 1.141vw;
}
.blog .blog-thumb img {
  height: 15.625vw;
  width: 100%;
}
.blog .blog-date {
  font-size: 1.172vw;
  margin-bottom: 1.172vw;
}
.blog .blog-ttl {
  font-size: 1.563vw;
}

/* news
-------------------------------------*/
.news .news-list {
  width: 29.688vw;
  gap: 5.625vw;
  margin-bottom: 6.016vw;
  left: 0.547vw;
}
.news .news-item {
  padding: 0 0 0 1.563vw;
}
.news .news-item::before {
  font-size: 1.563vw;
  top: 50%;
  left: -1.562vw;
}
.news .news-ttl {
  font-size: 1.563vw;
  padding: 0 0 0.391vw;
  margin-bottom: 0.938vw;
}
.news .news-date {
  font-size: 1.172vw;
}

/* end-contact
-------------------------------------*/
.end-contact {
  padding: 8.516vw 0 8.344vw;
  margin-top: 19.453vw;
  margin-bottom: 3.125vw;
}
.end-contact .logo {
  margin-bottom: 4.297vw;
}
.end-contact .logo img{
  width: 39.063vw;
}
.end-contact .btn {
  width: 39.063vw;
}
.end-contact .btn a{
  border-radius: 0.781vw;
  font-size: 2.344vw;
  padding: 2.109vw 3.203vw;
  gap: 2.422vw;
}
.end-contact .btn a::after {
  width: 0.781vw;
  height: 1.406vw;
  top: 50%;
  right: 3.047vw;
  transform: translateY(-50%);
}

}


/* ========================================
  @media screen and (min-width: 768px), print
======================================== */
@media (max-width: 767px) {
  .sec-ttl {
    background: #FBCEA3;
    font-weight: 800;
    font-size: clamp(1.375rem, 1.041rem + 0.7vw, 1.875rem);
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-align: center;
    display: flex;
    justify-content: center;
    padding: 2.868vw 0;
    gap: 4.042vw;
    margin-bottom: 13.038vw;
  }
  .sec-ttl span {
    color: #FFFFFF;
    letter-spacing: 0.05em;
  }

/* mv
-------------------------------------*/
.mv .img-box {
  position: relative;
  margin-bottom: 9.126vw;
}
.mv .img img {
  width: 100%;
  height: 39vw;
  object-fit: cover;
}
.mv .ttl {
  position: absolute;
  bottom: -3%;
  left: 50%;
  transform: translateX(-50%);
}
.mv .ttl img {
  width: 99.619vw;
}
.mv .lead {
  font-size: 5.246vw;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #d61518;
  margin-bottom: 3.52vw;
}
.mv .list {
  display: grid;
  gap: 2.086vw;
  width: 44.635vw;
  margin-inline: auto;
  padding-bottom: 15.254vw;
}
.mv .list li {
  font-size: 2.908vw;
  font-weight: 700;
  line-height: 1.2;
  text-align: left;
}

/* property
-------------------------------------*/
.property {
  padding-bottom: 17.471vw;
}
.property .list {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 6.519vw;
  width: 95vw;
  margin-inline: auto;
  margin-bottom: 12.516vw;
}
.property .list li .img {
  margin-bottom: 2.608vw;
}
.property .list li .img img {
  width: 100%;
  height: 39.113vw;
  object-fit: contain;
}
.property .list li table {
  background: #fff;
  border: 2px solid #999;
  width: 100%;
  margin-bottom: 6.389vw;
}
.property .list li table tr {
  border-bottom: 2px solid #999;
}
.property .list li table th, .property .list li table td {
  font-size: 3.608vw;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.5;
  height: 11.734vw;
  vertical-align: middle;
}
.property .list li table th {
  background: #E0E0E0;
  border: 2px solid #999;
  width: 23.5%;
  text-align: center;
}
.property .list li table td {
  padding: 0 2.608vw;
  font-weight: 700;
}
.property .list li table .price {
  color: #D40000;
}
.property .list li .btn {
  border-radius: 1.304vw;
  background: #cfd7e4;
}
.property .list li .btn a{
  font-weight: 700;
  font-size: 3.608vw;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-align: center;
  display: block;
  padding: 5.086vw 0;
}
.property .property-btn {
  width: 85vw;
  margin-inline: auto;
  border-radius: 1.304vw;
  background: #006db2;
}
.property .property-btn a {
  font-weight: 700;
  font-size: 3.259vw;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-align: center;
  color: #fff;
  display: block;
  padding: 5.911vw 0;
}

/* greeting
-------------------------------------*/
.greeting {
  position: relative;
  margin-bottom: 29.205vw;
}
.greeting .inner {
  position: relative;
  margin-inline: auto;
}
.greeting .content {
  display: grid;
  gap: 12.516vw;
  padding: 7.432vw 0 0;
  margin: 0 0 15.385vw;
  align-items: center;
}
.greeting .content .img-box {
  text-align: center;
}
.greeting .content .img{
  margin-bottom: 2.868vw;
}
.greeting .content .img img {
  width: 100%;
  height: auto;
}
.greeting .content .name{
  display: flex;
  font-weight: 500;
  font-size: 5.259vw;
  letter-spacing: 0.1em;
  line-height: 1.2;
  gap: 2.216vw;
  margin: 0 0 0 5.997vw;
}
.greeting .content .name span {
  font-weight: 500;
  font-size: 2.956vw;
  line-height: 1.2;
  letter-spacing: 0;
}
.greeting .content .txt-box {
  position: relative;
  padding: 4vw;
}
.greeting .content .txt-box::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 241.379vw;
  top: 0;
  right: 0;
  pointer-events: none;
  background: #cfd7e4;
  opacity: 0.5;
  border-radius: 3.304vw;
}
.greeting .content h3 {
  position: relative;
  font-weight: 700;
  font-size: 5.259vw;
  line-height: 1.5;
  margin-bottom: 7.823vw;
}
.greeting .content h3 span {
  color: #2fa02c;
  font-size: 3.911vw;
}
.greeting .content .txt {
  font-weight: 700;
  font-size: 3.608vw;
  line-height: 2.45;
  position: relative;
}
.greeting .ytArea {
  width: 95vw;
  margin-inline: auto;
}
.greeting .ytArea iframe {
  width: 100%;
  height: 60.872vw;
  border: 4vw solid #fff;
}

/* blog-news
-------------------------------------*/
.blog-news {
  display: grid;
  position: relative;
  padding-bottom: 19.557vw;
  gap: 14vw;
}
.blog-news .sec-ttl {
  margin-bottom: 10.169vw;
}
.blog-news .btn {
  border-radius: 1.304vw;
  background: #cfd7e4;
  width: 85vw;
  margin-inline: auto;
}
.blog-news .btn a{
  font-weight: 700;
  font-size: 3.608vw;
  letter-spacing: 0.05em;
  line-height: 1.2;
  text-align: center;
  display: block;
  padding: 5.086vw 0;
}

/* blog
-------------------------------------*/
.blog .blog-list {
  display: grid;
  gap: 10.43vw;
  width: 95vw;
  margin-inline: auto;
  margin-bottom: 10.43vw;
}
.blog .blog-item a {
  display: grid;
  grid-template-columns: 40vw 1fr;
  gap: 3.651vw;
  align-items: center;
}
.blog .blog-thumb {
  text-align: center;
}
.blog .blog-thumb img {
  height: 26.076vw;
  object-fit: contain;
  width: 100%;
}
.blog .blog-date {
  font-weight: 700;
  font-size: 2.956vw;
  line-height: 1.2;
  color: #444;
  margin-bottom: 1.956vw;
}
.blog .blog-ttl {
  font-weight: 700;
  font-size: 3.608vw;
  line-height: 1.2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* news
-------------------------------------*/
.news {
  /* position: absolute; */
  /* bottom: 0; */
  /* right: 0; */
  /* width: 50%; */
}
.news .news-list {
  width: 90vw;
  margin-inline: auto;
  display: grid;
  gap: 9.387vw;
  margin-bottom: 10.039vw;
  position: relative;
  left: 0;
}
.news .news-item {
  position: relative;
  padding: 0 0 0 2.608vw;
}
.news .news-item a {
  text-decoration: none;
}
.news .news-item::before {
  position: absolute;
  content: "◆";
  font-size: 2.608vw;
  line-height: 1.2;
  letter-spacing: 0;
  top: 50%;
  left: -2.608vw;
  transform: translateY(-50%);
}
.news .news-ttl {
  font-weight: 700;
  font-size: 3.608vw;
  line-height: 1.2;
  border-bottom: 1px solid #000000;
  padding: 0 0 0.652vw;
  margin-bottom: 1.565vw;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news .news-date {
  font-weight: 700;
  font-size: 2.956vw;
  line-height: 1.2;
  color: #444;
}

/* end-contact
-------------------------------------*/
.end-contact {
  background: url(../img/top/end-contact-bg.png) no-repeat center/cover;
  padding: 14.211vw 0 12.256vw;
  margin-top: 31.421vw;
  margin-bottom: 5.215vw;
}
.end-contact .logo {
  text-align: center;
  margin-bottom: 7.171vw;
}
.end-contact .logo img {
  width: 60.937vw;
  height: auto;
}
.end-contact .btn {
  width: 85vw;
  margin-inline: auto;
}
.end-contact .btn a{
  display: block;
  border-radius: 1.304vw;
  background: #006db2;
  font-size: 3.911vw;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  position: relative;
  padding: 3.52vw 5.346vw;
  display: flex;
  gap: 4.042vw;
}
.end-contact .btn a::after {
  position: absolute;
  content: "";
  background: url(../img/top/btn-arrow.png)no-repeat;
  background-size: contain;
  width: 1.304vw;
  height: 2.347vw;
  top: 50%;
  right: 5.085vw;
  transform: translateY(-50%);
}
.end-contact .btn a span {
  color: #FFFFFF;
}


}