@charset "UTF-8";
/*====================================
PC
====================================*/
html, body {
  font-size: 62.5%; }

body {
  font-size: 1.4rem;
  line-height: 1.7;
  color: #282828;
  font-weight: 400;
  font-family: 'Roboto Flex', sans-serif;
  letter-spacing: 0px;
  font-feature-settings: "palt";
  background: url("/assets/img/common/bg_pc.webp") repeat-y top center;
  background-size: 100%; }

a {
  color: #282828;
  text-decoration: none;
  transition: 0.3s; }

a:hover {
  transition: 0.3s; }

img {
  width: 100%; }

.sp {
  display: none; }

header {
  background: #282828;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 75px;
  z-index: 3; }
  header h1 {
    position: absolute;
    left: 3%;
    top: 20px; }
    header h1 img {
      width: 220px; }
  header ul {
    display: flex;
    justify-content: space-between;
    width: 20px;
    position: absolute;
    right: 3%;
    top: 20px; }
    header ul li {
      width: 20px; }
      header ul li a {
        font-size: 2.0rem;
        color: #fff; }
      header ul li a:hover {
        opacity: 0.8; }

nav {
  background: white;
  width: 100px;
  box-sizing: border-box;
  height: 100vh;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 2;
  box-shadow: 5px 0px 4px -4px rgba(0, 0, 0, 0.1); }
  nav ul {
    position: absolute;
    left: 15px;
    bottom: 3%; }
    nav ul li {
      text-align: center;
      margin-bottom: 20px; }
      nav ul li a {
        display: block; }
      nav ul li a:hover {
        opacity: 0.8; }
      nav ul li img {
        width: 40px;
        margin-bottom: 5px; }
      nav ul li p {
        font-size: 1.2rem;
        letter-spacing: 0; }

main {
  padding-top: 75px; }
  main #mainVisual {
    background: url("/assets/img/index/mv_pht.webp") no-repeat left top;
    background-size: cover;
    height: 700px;
    position: relative;
    margin-left: 100px;
    color: #fff;
    animation: img_anime 16s ease infinite; }
    main #mainVisual .warpArea {
      position: absolute;
      top: 30%;
      left: 80px; }
    main #mainVisual h2 {
      position: relative;
      font-size: 1.7rem;
      margin-bottom: 40px; }
    main #mainVisual h2::after {
      content: '';
      display: block;
      position: absolute;
      bottom: -15px;
      width: 12px;
      height: 1px;
      background-color: #fff; }
    main #mainVisual dl dt {
      font-size: 2.8rem;
      font-weight: 500; }
    main #mainVisual dl dd {
      width: 740px;
      margin-bottom: 30px; }
      main #mainVisual dl dd a {
        font-weight: 500;
        background: #fff;
        border-radius: 30px;
        padding: 15px 20px;
        line-height: 1;
        border: 1px solid #fff; }
      main #mainVisual dl dd a:hover {
        background: #282828;
        color: #fff;
        box-sizing: border-box;
        border: 1px solid #fff; }
@keyframes img_anime {
  0% {
    background-image: url(/assets/img/index/mv_pht.webp);
    /* 背景画像1を指定 */ }
  20% {
    background-image: url(/assets/img/index/mv_pht.webp);
    /* 背景画像1を指定 */ }
  35% {
    background-image: url(/assets/img/index/mv_pht2.webp);
    /* 背景画像2を指定 */ }
  53% {
    background-image: url(/assets/img/index/mv_pht2.webp);
    /* 背景画像2を指定 */ }
  68% {
    background-image: url(/assets/img/index/mv_pht3.webp);
    /* 背景画像3を指定 */ }
  85% {
    background-image: url(/assets/img/index/mv_pht3.webp);
    /* 背景画像3を指定 */ }
  100% {
    background-image: url(/assets/img/index/mv_pht.webp);
    /* 背景画像1を指定 */ } }
section h2 {
  font-size: 2.8rem;
  font-weight: 400;
  line-height: 1.0;
  margin-bottom: 30px; }
  section h2 span {
    border-bottom: 3px solid #282828; }

#headmv {
  margin-left: 100px;
  position: relative; }
  #headmv h2 {
    color: #fff;
    position: absolute;
    top: 45%;
    left: 50%;
    transform: translateY(-45%) translateX(-50%); }
  #headmv .about {
    background: url("/assets/img/index/mv_pht3.webp") no-repeat center center;
    background-size: cover;
    height: 300px;
    position: relative; }
  #headmv .privacy {
    background: url("/assets/img/index/mv_pht2.webp") no-repeat center center;
    background-size: cover;
    height: 300px;
    position: relative; }
  #headmv .terms {
    background: url("/assets/img/index/mv_pht9.webp") no-repeat center center;
    background-size: cover;
    height: 300px;
    position: relative; }
  #headmv .faq {
    background: url("/assets/img/index/mv_pht5.webp") no-repeat center center;
    background-size: cover;
    height: 300px;
    position: relative; }
  #headmv .company {
    background: url("/assets/img/index/mv_pht8.webp") no-repeat center center;
    background-size: cover;
    height: 300px;
    position: relative; }
  #headmv .howto {
    background: url("/assets/img/index/mv_pht9.webp") no-repeat center center;
    background-size: cover;
    height: 300px;
    position: relative; }

#contentsArea {
  padding: 80px 80px 50px 180px;
  overflow: hidden; }
  #contentsArea .root {
    overflow: hidden;
    margin-bottom: 20px; }
    #contentsArea .root li {
      float: left;
      margin-right: 10px; }
  #contentsArea .sold {
    background: #b9b9b9;
    color: #fff;
    line-height: 1;
    font-size: 1.1rem;
    width: 50px;
    padding: 4px 0;
    text-align: center; }
  #contentsArea .icn {
    display: flex; }
    #contentsArea .icn span {
      padding: 6px 10px;
      border-radius: 2px;
      margin-right: 5px;
      line-height: 1; }
  #contentsArea .new {
    background: #bf0000;
    color: #fff;
    line-height: 1;
    font-size: 1.1rem;
    text-align: center; }
  #contentsArea .guesthouse {
    background: #408947;
    color: #fff;
    line-height: 1;
    font-size: 1.1rem;
    text-align: center; }
  #contentsArea .residence {
    background: #ce7c29;
    color: #fff;
    line-height: 1;
    font-size: 1.1rem;
    text-align: center; }
  #contentsArea .investment {
    background: #387496;
    color: #fff;
    line-height: 1;
    font-size: 1.1rem;
    text-align: center; }
  #contentsArea .land {
    background: #736357;
    color: #fff;
    line-height: 1;
    font-size: 1.1rem;
    text-align: center; }
  #contentsArea #propety .warArea {
    padding-bottom: 40px;
    border-bottom: 1px solid #282828;
    margin-bottom: 80px; }
  #contentsArea #propety a {
    display: block;
    transition: 0.3s; }
  #contentsArea #propety a:hover {
    opacity: 0.8;
    cursor: pointer;
    transition: 0.3s; }
  #contentsArea #propety .pht {
    margin-bottom: 15px; }
  #contentsArea #propety .area {
    border: 1px solid #282828;
    background: #fff;
    padding: 5px 10px;
    line-height: 1;
    font-size: 1.2rem;
    font-weight: 400;
    border-radius: 4px;
    margin-right: 5px; }
  #contentsArea #propety .newi {
    border: 1px solid #bf0000;
    background: #bf0000;
    color: #fff;
    padding: 5px 10px;
    line-height: 1;
    font-size: 1.2rem;
    font-weight: 400;
    border-radius: 4px;
    margin-right: 5px; }
  #contentsArea #propety .soldout {
    border: 1px solid #c9c9c9;
    background: #c9c9c9;
    padding: 5px 10px;
    line-height: 1;
    font-size: 1.2rem;
    font-weight: 400;
    border-radius: 4px;
    margin-right: 5px; }
  #contentsArea #propety dl {
    padding-top: 5px; }
    #contentsArea #propety dl dt {
      font-weight: 500;
      font-size: 1.6rem; }
    #contentsArea #propety dl dd.price {
      font-size: 1.8rem; }
  #contentsArea #propety ul {
    overflow: hidden; }
  #contentsArea #propety .pickup {
    margin-bottom: 30px; }
    #contentsArea #propety .pickup li {
      width: 48%;
      float: left;
      margin-bottom: 30px; }
    #contentsArea #propety .pickup li:nth-child(2n) {
      float: right; }
  #contentsArea #propety .listing li {
    width: 32%;
    float: left;
    margin-bottom: 30px;
    margin-right: 2%; }
  #contentsArea #propety .listing li:nth-child(3n) {
    float: right;
    margin-right: 0%; }
  #contentsArea #propety .detal {
    position: relative; }
    #contentsArea #propety .detal h2 {
      line-height: 1.5;
      width: 80%; }
    #contentsArea #propety .detal h3 {
      font-weight: 500;
      font-size: 3.0rem;
      letter-spacing: 1px;
      margin-bottom: 1%; }
    #contentsArea #propety .detal .price {
      position: absolute;
      right: 0;
      top: 0;
      font-size: 2.8rem; }
    #contentsArea #propety .detal .mv {
      margin-bottom: 15%; }
    #contentsArea #propety .detal .readTxt {
      padding: 3% 10% 3% 10%;
      font-size: 1.8rem; }
    #contentsArea #propety .detal .pointArea {
      overflow: hidden;
      margin-bottom: 15%; }
      #contentsArea #propety .detal .pointArea .pht {
        width: 50%; }
      #contentsArea #propety .detal .pointArea dl {
        width: 40%; }
        #contentsArea #propety .detal .pointArea dl dt {
          font-size: 3.0rem; }
      #contentsArea #propety .detal .pointArea .l-block {
        overflow: hidden;
        margin-bottom: 10%; }
        #contentsArea #propety .detal .pointArea .l-block dl {
          float: left; }
        #contentsArea #propety .detal .pointArea .l-block .pht {
          float: right; }
        #contentsArea #propety .detal .pointArea .l-block p {
          float: left;
          font-size: 1.8rem;
          width: 40%; }
      #contentsArea #propety .detal .pointArea .r-block {
        overflow: hidden;
        margin-bottom: 0%; }
        #contentsArea #propety .detal .pointArea .r-block dl {
          float: right; }
        #contentsArea #propety .detal .pointArea .r-block .pht {
          float: left; }
        #contentsArea #propety .detal .pointArea .r-block p {
          float: right;
          font-size: 1.8rem;
          width: 40%; }
    #contentsArea #propety .detal .floorPlan {
      margin-bottom: 15%; }
      #contentsArea #propety .detal .floorPlan .pht {
        margin: 0 10%;
        background: #fff;
        padding: 10%; }
    #contentsArea #propety .detal .virtualTour {
      margin-bottom: 15%; }
      #contentsArea #propety .detal .virtualTour p {
        margin-bottom: 3%; }
      #contentsArea #propety .detal .virtualTour .pht {
        margin: 0 10%; }
      #contentsArea #propety .detal .virtualTour .coming {
        margin: 0 10%;
        background: #282828;
        display: block;
        width: 80%;
        padding: 200px 0;
        text-align: center;
        vertical-align: middle;
        color: #fff;
        font-weight: 400;
        font-size: 2.4rem; }
      #contentsArea #propety .detal .virtualTour .ricoh-theta-tour-image {
        margin: 0 auto; }
    #contentsArea #propety .detal .photoArea {
      margin-bottom: 15%;
      position: relative; }
      #contentsArea #propety .detal .photoArea .prev-arrow {
        position: absolute;
        z-index: 5;
        width: 30px;
        left: 0%;
        top: 50%; }
      #contentsArea #propety .detal .photoArea .next-arrow {
        position: absolute;
        z-index: 5;
        width: 30px;
        right: 0%;
        top: 50%; }
    #contentsArea #propety .detal .mapArea {
      margin-bottom: 15%; }
      #contentsArea #propety .detal .mapArea p {
        text-align: right;
        padding: 5px 0; }
    #contentsArea #propety .detal .outline {
      margin-bottom: 10%; }
      #contentsArea #propety .detal .outline dl {
        display: table;
        width: 60%;
        border-bottom: 0.5px solid #666;
        padding-bottom: 2%;
        margin: 0 20% 2% 20%; }
        #contentsArea #propety .detal .outline dl dt {
          display: table-cell;
          width: 200px;
          font-weight: 500;
          font-size: 1.4rem; }
        #contentsArea #propety .detal .outline dl dd {
          display: table-cell; }
    #contentsArea #propety .detal .btnArea {
      margin-bottom: 5%; }
      #contentsArea #propety .detal .btnArea a {
        display: block;
        font-weight: 500;
        ackground: #282828;
        border: 1px solid #282828;
        padding: 15px 20px;
        border-radius: 30px;
        text-align: center;
        width: 300px;
        line-height: 1;
        box-sizing: border-box;
        margin: 0 auto; }
      #contentsArea #propety .detal .btnArea a:hover {
        bcolor: #fff;
        border: 1px solid #282828; }
  #contentsArea .contact {
    background: rgba(250, 250, 250, 0.9);
    position: fixed;
    bottom: 20%;
    right: 0;
    z-index: 5;
    padding: 15px 25px;
    text-align: center;
    border-radius: 4px 0px 0px 4px; }
    #contentsArea .contact dt {
      font-size: 1.7rem;
      font-weight: 600;
      margin-bottom: 10px; }
    #contentsArea .contact dd ul {
      display: flex;
      justify-content: space-between;
      width: 200px; }
      #contentsArea .contact dd ul li {
        text-align: center;
        width: 60px; }
        #contentsArea .contact dd ul li a {
          display: block; }
        #contentsArea .contact dd ul li a:hover {
          opacity: 0.8; }
        #contentsArea .contact dd ul li img {
          width: 40px;
          margin-bottom: 5px; }
        #contentsArea .contact dd ul li p {
          font-size: 1.2rem; }
  #contentsArea #news {
    margin-bottom: 50px;
    overflow: hidden; }
    #contentsArea #news h2 {
      float: left; }
    #contentsArea #news ul {
      width: 80%;
      float: right; }
      #contentsArea #news ul li {
        margin-bottom: 30px; }
        #contentsArea #news ul li a {
          display: block;
          text-decoration: underline; }
        #contentsArea #news ul li a:hover {
          text-decoration: none; }
        #contentsArea #news ul li dl dt {
          vertical-align: middle;
          line-height: 1;
          margin-bottom: 10px;
          overflow: hidden; }
          #contentsArea #news ul li dl dt b {
            display: block;
            font-size: 1.4rem;
            font-weight: 500;
            float: left;
            padding: 4px 0; }
          #contentsArea #news ul li dl dt span {
            float: left;
            margin-left: 5px; }
        #contentsArea #news ul li dl dd {
          clear: both;
          overflow: hidden; }
          #contentsArea #news ul li dl dd img {
            width: 25%;
            float: right; }
          #contentsArea #news ul li dl dd p {
            float: left;
            width: 60%; }
            #contentsArea #news ul li dl dd p b {
              font-size: 1.8rem; }
      #contentsArea #news ul li:last-child {
        margin-bottom: 0; }
  #contentsArea #about {
    font-size: 1.5rem; }
    #contentsArea #about h3 {
      font-size: 2.2rem;
      font-weight: 500;
      margin-bottom: 10px; }
    #contentsArea #about h4 {
      font-size: 1.6rem;
      font-weight: 500; }
    #contentsArea #about p {
      margin-bottom: 20px; }
    #contentsArea #about dl {
      margin-bottom: 30px; }
      #contentsArea #about dl dt {
        font-weight: 500;
        margin-bottom: 5px;
        font-size: 1.8rem; }
      #contentsArea #about dl dd {
        margin-bottom: 10px; }
    #contentsArea #about ol li {
      list-style: decimal;
      margin-left: 25px;
      margin-bottom: 10px; }
    #contentsArea #about .btnArea {
      padding-top: 20px; }
      #contentsArea #about .btnArea a {
        display: block;
        font-weight: 500;
        ackground: #282828;
        border: 1px solid #282828;
        padding: 15px 20px;
        border-radius: 30px;
        text-align: center;
        width: 300px;
        line-height: 1;
        box-sizing: border-box;
        margin: 0 auto; }
      #contentsArea #about .btnArea a:hover {
        bcolor: #fff;
        border: 1px solid #282828; }
  #contentsArea #faq {
    font-size: 1.5rem; }
    #contentsArea #faq p {
      margin-bottom: 30px; }
    #contentsArea #faq h3 {
      font-size: 2.4rem;
      margin-bottom: 15px;
      font-weight: 500; }
    #contentsArea #faq ul {
      padding-top: 30px;
      border-top: 0.5px solid #282828;
      margin-bottom: 60px; }
      #contentsArea #faq ul li {
        border-bottom: 0.51px solid #282828;
        margin-bottom: 30px; }
        #contentsArea #faq ul li h4 {
          font-size: 1.8rem;
          font-weight: 400;
          position: relative;
          padding: 0 0 0 25px; }
        #contentsArea #faq ul li h4:before {
          content: 'Q.';
          position: absolute;
          top: 0px;
          left: 0; }
        #contentsArea #faq ul li p {
          position: relative;
          padding: 6px 0 0 25px; }
        #contentsArea #faq ul li p:before {
          content: 'A.';
          position: absolute;
          top: 0px;
          left: 0;
          font-size: 2.0rem; }
    #contentsArea #faq .btnArea {
      padding-top: 20px; }
      #contentsArea #faq .btnArea a {
        display: block;
        font-weight: 500;
        ackground: #282828;
        border: 1px solid #282828;
        padding: 15px 20px;
        border-radius: 30px;
        text-align: center;
        width: 300px;
        line-height: 1;
        box-sizing: border-box;
        margin: 0 auto; }
      #contentsArea #faq .btnArea a:hover {
        bcolor: #fff;
        border: 1px solid #282828; }
  #contentsArea #comapny h3 {
    font-size: 2.4rem;
    margin-bottom: 15px;
    font-weight: 500; }
  #contentsArea #comapny .profile {
    border-bottom: 0.5px solid #282828;
    margin-bottom: 60px; }
    #contentsArea #comapny .profile dl {
      display: table;
      width: 100%;
      text-align: left;
      border-top: 0.5px solid #282828; }
      #contentsArea #comapny .profile dl dt {
        display: table-cell;
        padding: 30px 0px;
        width: 20%; }
      #contentsArea #comapny .profile dl dd {
        display: table-cell;
        padding: 30px 0px; }
        #contentsArea #comapny .profile dl dd a {
          text-decoration: underline; }
  #contentsArea #comapny .greeting {
    overflow: hidden; }
    #contentsArea #comapny .greeting .readArea {
      width: 70%;
      float: left; }
      #contentsArea #comapny .greeting .readArea p {
        margin-bottom: 15px; }
    #contentsArea #comapny .greeting .pht {
      width: 25%;
      float: right; }
    #contentsArea #comapny .greeting p.name {
      font-size: 1.6rem;
      text-align: right; }
  #contentsArea #howto h3 {
    font-size: 2.4rem;
    margin-bottom: 15px;
    font-weight: 500; }
  #contentsArea #howto ul li {
    list-style: decimal;
    margin-left: 25px;
    font-size: 2.0rem;
    margin-bottom: 10px; }
  #contentsArea #howto .btnArea {
    padding-top: 20px; }
    #contentsArea #howto .btnArea a {
      display: block;
      font-weight: 500;
      ackground: #282828;
      border: 1px solid #282828;
      padding: 15px 20px;
      border-radius: 30px;
      text-align: center;
      width: 300px;
      line-height: 1;
      box-sizing: border-box;
      margin: 0 auto; }
    #contentsArea #howto .btnArea a:hover {
      bcolor: #fff;
      border: 1px solid #282828; }
  #contentsArea #terms dl {
    margin-bottom: 40px; }
    #contentsArea #terms dl dt {
      line-height: 1.5;
      font-size: 2.2rem;
      font-weight: 500;
      margin-bottom: 10px; }
    #contentsArea #terms dl dd p {
      margin-bottom: 15px; }
    #contentsArea #terms dl dd ol {
      list-style: disc;
      margin-left: 25px; }
      #contentsArea #terms dl dd ol li {
        margin-bottom: 10px; }
        #contentsArea #terms dl dd ol li a {
          text-decoration: underline; }

#qr {
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%); }
  #qr img {
    width: 200px;
    margin-bottom: 10px; }

#footLink {
  margin: 0 80px 0 180px;
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  padding: 50px 0;
  border-top: 1px solid #282828; }
  #footLink div {
    position: relative;
    width: 45%;
    padding-bottom: 30px; }
  #footLink .how::after {
    content: '';
    display: block;
    position: absolute;
    left: 110%;
    bottom: -0px;
    width: 1px;
    height: 100%;
    background-color: #282828; }
  #footLink p {
    margin-bottom: 30px; }
  #footLink a {
    display: block;
    font-weight: 500;
    border: 1px solid #282828;
    padding: 15px 20px;
    border-radius: 30px;
    text-align: center;
    width: 200px;
    line-height: 1;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%);
    box-sizing: border-box; }
  #footLink a:hover {
    background: #282828;
    color: #fff;
    border: 1px solid #282828; }

#aboutus {
  margin: 0 80px 0 180px;
  overflow: hidden;
  padding: 50px 0;
  border-top: 1px solid #282828; }

footer {
  background: #282828;
  color: #fff;
  position: relative;
  padding: 30px;
  font-weight: 300; }
  footer h2 {
    width: 100px;
    position: absolute;
    left: 12%; }
  footer ul {
    display: flex;
    justify-content: space-between;
    width: 300px;
    margin: 0 auto; }
    footer ul li {
      font-size: 1.2rem; }
  footer a {
    color: #fff; }
  footer .copy {
    padding-top: 20px;
    font-size: 1.2rem;
    text-align: center; }

#page-top {
  width: 60px;
  position: fixed;
  right: 30px;
  bottom: 30px;
  z-index: 2;
  opacity: 0;
  transform: translateX(100px); }
  #page-top img {
    width: 100%; }

#page-top.LeftMove {
  animation: LeftAnime 0.5s forwards; }

#page-top.RightMove {
  animation: RightAnime 0.5s forwards; }

@keyframes LeftAnime {
  from {
    opacity: 0;
    transform: translateX(100px); }
  to {
    opacity: 1;
    transform: translateX(0); } }
@keyframes RightAnime {
  from {
    opacity: 1;
    transform: translateX(0); }
  to {
    opacity: 1;
    transform: translateX(100px); } }
