/*! Writen  by SCSS */
ul.gnavi li.nav_ren a {
  opacity: 0.7; }

.fadeup {
  transform: translateY(0);
  opacity: 0;
  transition: opacity 1.2s cubic-bezier(0.5, 1, 0.89, 1);
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.5, 1, 0.89, 1);
  will-change: auto; }
  .fadeup.p-view {
    opacity: 1;
    transform: translateY(0px); }

div.wrap {
  padding-top: 0 !important; }

div.header {
  border-bottom: solid 1px rgba(255, 255, 255, 0.4); }
  div.header .bk {
    opacity: 0; }
  div.header .wh {
    opacity: 1; }
  @media screen and (max-width: 768px) {
    div.header .logo {
      border-right: solid 1px rgba(255, 255, 255, 0.4); } }
  div.header ul.headnavi {
    border-right: solid 1px rgba(255, 255, 255, 0.4);
    border-left: solid 1px rgba(255, 255, 255, 0.4); }
    div.header ul.headnavi li:not(:last-child) {
      border-bottom: solid 1px rgba(255, 255, 255, 0.4); }
    div.header ul.headnavi li a {
      color: #fff; }
  div.header .gnavi_head .gnavi_h > li a,
  div.header .gnavi_head .gnavi_h > li .nav_bus_text {
    color: #fff; }
  div.header .gnavi_head .gnavi_h > li.nav_bus .nav_list li a {
    color: #fff;
    background: rgba(0, 0, 0, 0.4); }
  div.header .nav_btn hr {
    background: #fff; }

.breadlist {
  display: none; }

.sec_box {
  min-height: calc(100vh + 300px);
  position: relative;
  z-index: 2;
  /*&.fix_on {
  	.bg {
  		position: fixed;
  		top:0;
  		bottom:auto;
  	}
  }
  &.fix_off {
  	.bg {
  		position: absolute;
  	}
  }*/ }
  @media screen and (max-width: 480px) {
    .sec_box {
      min-height: calc(100lvh + 100px); } }
  .sec_box .bg {
    clip-path: inset(0 0 0 0);
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0; }
    .sec_box .bg::before {
      content: "";
      display: block;
      position: fixed;
      z-index: -1;
      top: 0;
      left: 0;
      width: 100%;
      height: 100lvh;
      background-repeat: no-repeat;
      background-size: cover;
      background-position: center; }
  .sec_box .inner {
    position: relative;
    z-index: 5; }
    .sec_box .inner .txt01 {
      font-size: clamp(22px, 4.033vw, 50px);
      letter-spacing: 0.18em;
      font-weight: 700;
      line-height: 1;
      margin-bottom: 0.8em;
      opacity: 0; }
      @media screen and (min-width: 480px) {
        .sec_box .inner .txt01 {
          color: transparent;
          -webkit-text-stroke: 1px #fff;
          text-stroke: 1px #fff; } }
      @media screen and (max-width: 480px) {
        .sec_box .inner .txt01 {
          background: linear-gradient(0deg, #e8e6e2, #c8ba9c);
          background: -webkit-linear-gradient(90deg, #e8e6e2, #c8ba9c);
          -webkit-background-clip: text;
          -webkit-text-fill-color: transparent; } }
      .sec_box .inner .txt01.p-view {
        opacity: 0.45; }
        @media screen and (max-width: 480px) {
          .sec_box .inner .txt01.p-view {
            opacity: 0.7; } }
    .sec_box .inner .txt02 {
      font-size: clamp(26px, 5.162vw, 64px);
      letter-spacing: 0.05em;
      font-weight: 700;
      line-height: 1; }
      .sec_box .inner .txt02 span {
        background: linear-gradient(0deg, #e8e6e2, #c8ba9c);
        background: -webkit-linear-gradient(90deg, #e8e6e2, #c8ba9c);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        opacity: 0.7; }
    .sec_box .inner .txt03 {
      font-size: clamp(18px, 2.05vw, 25px);
      letter-spacing: 0.1em;
      font-weight: 700;
      line-height: 1;
      color: #fff;
      margin: -0.5em 0 2em; }
    .sec_box .inner .txt04 {
      font-size: clamp(16px, 2.05vw, 25px);
      letter-spacing: 0;
      font-weight: 700;
      line-height: 2;
      color: #fff;
      margin-bottom: 1em; }
      @media screen and (max-width: 480px) {
        .sec_box .inner .txt04 {
          margin-right: -20px; } }
    .sec_box .inner .txt05 {
      font-size: clamp(13px, 1.394vw, 17px);
      letter-spacing: 0.1em;
      font-weight: 700;
      line-height: 3;
      color: #fff; }
      @media screen and (max-width: 480px) {
        .sec_box .inner .txt05 {
          line-height: 2.4; } }
    .sec_box .inner .txt06 {
      font-size: clamp(13px, 1.394vw, 17px);
      letter-spacing: 0.1em;
      font-weight: 700;
      line-height: 3;
      color: #fff; }
      @media screen and (max-width: 480px) {
        .sec_box .inner .txt06 {
          line-height: 2.4; } }
  .sec_box.sec00 .bg::before {
    background-image: url("../images/renovation/sec00_bg.jpg"); }
  .sec_box.sec00 .inner {
    max-width: 1200px;
    padding: calc((160% / 16) + 100px) 20px calc(180% / 16); }
    @media screen and (max-width: 480px) {
      .sec_box.sec00 .inner {
        height: fit-content;
        padding: calc((190% / 4.8) + 60px) 0 calc(140% / 4.8); } }
  .sec_box.sec01 .bg::before {
    background-image: url("../images/renovation/sec01_bg.jpg"); }
  .sec_box.sec01 .inner {
    max-width: 1200px;
    padding: calc((180% / 16) + 100px) 20px calc(120% / 16); }
    @media screen and (max-width: 480px) {
      .sec_box.sec01 .inner {
        height: fit-content;
        padding: calc((140% / 4.8) + 60px) 0 calc(100% / 4.8); } }
    .sec_box.sec01 .inner .txt06 {
      text-shadow: 0px 0px 0px rgba(0, 0, 0, 0.8), 0px 0px 1px rgba(0, 0, 0, 0.8), 0px 0px 2px rgba(0, 0, 0, 0.8), 0px 0px 3px rgba(0, 0, 0, 0.8), 0px 0px 4px rgba(0, 0, 0, 0.8), 0px 0px 5px rgba(0, 0, 0, 0.8); }
  .sec_box.sec02 .bg::before {
    background-image: url("../images/renovation/sec02_bg.jpg"); }
  .sec_box.sec02 .inner {
    max-width: 1200px;
    padding: calc((180% / 16) + 100px) 20px calc(180% / 16); }
    @media screen and (max-width: 480px) {
      .sec_box.sec02 .inner {
        height: fit-content;
        padding: calc((140% / 4.8) + 60px) 0 calc(140% / 4.8); } }

.ba_box {
  margin-top: 70px;
  max-width: 1080px;
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 480px) {
    .ba_box {
      display: block; } }
  .ba_box .before {
    width: calc(440% / 10.8); }
    @media screen and (max-width: 480px) {
      .ba_box .before {
        width: 80%; } }
  .ba_box .arrow {
    width: 20px;
    position: relative; }
    @media screen and (max-width: 480px) {
      .ba_box .arrow {
        width: 100%;
        margin: 36px 0 0; } }
    .ba_box .arrow::after {
      content: "";
      display: block;
      position: absolute;
      top: 39%;
      background: #dfdfdf;
      height: 40px;
      width: 20px;
      clip-path: polygon(0 0, 100% 50%, 0 100%); }
      @media screen and (max-width: 480px) {
        .ba_box .arrow::after {
          position: static;
          margin: 0 auto;
          top: 0;
          height: 15px;
          width: 30px;
          clip-path: polygon(0 0, 100% 0, 50% 100%); } }
  .ba_box .after {
    width: calc(530% / 10.8); }
    @media screen and (max-width: 480px) {
      .ba_box .after {
        width: 100%;
        margin-top: -28px; } }
  .ba_box .ba_ttl {
    font-size: clamp(20px, 2.322vw, 26px);
    letter-spacing: 0.1em;
    font-weight: 700;
    line-height: 1.4;
    color: #fff;
    text-shadow: 0px 0px 0px rgba(0, 0, 0, 0.8), 0px 0px 1px rgba(0, 0, 0, 0.8), 0px 0px 2px rgba(0, 0, 0, 0.8), 0px 0px 3px rgba(0, 0, 0, 0.8), 0px 0px 4px rgba(0, 0, 0, 0.8), 0px 0px 5px rgba(0, 0, 0, 0.8);
    margin-bottom: 0.8em; }
    .ba_box .ba_ttl .ja {
      display: block;
      font-size: 60%;
      letter-spacing: 0.05em; }
  .ba_box .slide_main {
    position: relative;
    margin-bottom: 15px; }
    .ba_box .slide_main li {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      opacity: 0;
      transition: all 0.8s ease-in-out 0s; }
      .ba_box .slide_main li.active {
        opacity: 1; }
      .ba_box .slide_main li:first-child {
        position: relative; }
  .ba_box .slide_thum {
    display: flex;
    gap: calc(25% / 5.3);
    flex-wrap: wrap; }
    .ba_box .slide_thum li {
      width: calc(160% / 5.3);
      position: relative;
      cursor: pointer; }
      @media screen and (max-width: 480px) {
        .ba_box .slide_thum li {
          width: calc(159% / 5.3); } }
      .ba_box .slide_thum li:nth-child(n + 4) {
        margin-top: 10px; }
      .ba_box .slide_thum li::after {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: #fff;
        background: #000;
        opacity: 0.4;
        opacity: 0.6;
        transition: all 0.3s ease-in-out 0s; }
      .ba_box .slide_thum li.active::after, body:not(.mobile) .ba_box .slide_thum li:hover::after {
        opacity: 0; }

.sec03 {
  background: url("../images/common/article_bg.jpg") center center/cover;
  height: calc(450vw / 16);
  height: calc(400vw / 16);
  padding: calc(50% / 16) 0; }
  @media screen and (max-width: 480px) {
    .sec03 {
      background: url("../images/common/article_bg_sp.jpg") top center/100% auto no-repeat;
      height: auto;
      padding: 60vw 0 30px;
      padding: 50vw 0 30px;
      padding: 40vw 0 20px;
      background-position: center top 40%;
      background-position: center top 45%; } }
  .sec03 .inn {
    padding: 0 40px;
    text-align: right;
    height: 100%; }
    @media screen and (max-width: 480px) {
      .sec03 .inn {
        padding: 0 20px;
        text-align: left; } }
    .sec03 .inn > div {
      text-align: left;
      height: 100%;
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      justify-content: center; }
      @media screen and (max-width: 480px) {
        .sec03 .inn > div {
          display: block; } }
      .sec03 .inn > div .sec_ttl_wrap {
        width: 36em; }
        @media screen and (max-width: 768px) {
          .sec03 .inn > div .sec_ttl_wrap {
            width: auto; } }
      .sec03 .inn > div .sec_ttl {
        font-size: clamp(12px, 1.476vw, 18px);
        color: #555;
        letter-spacing: 0;
        font-weight: 600;
        line-height: 1.4;
        margin-bottom: 1.4em; }
        @media screen and (max-width: 480px) {
          .sec03 .inn > div .sec_ttl {
            margin-right: -20px; } }
      .sec03 .inn > div .d_btn {
        display: flex;
        align-items: center;
        color: #111;
        cursor: pointer;
        font-size: clamp(12px, 1.23vw, 15px); }
        .sec03 .inn > div .d_btn .icon {
          display: block;
          width: 2em;
          height: 2em;
          margin-left: 0.8em;
          border: solid 1px #555555;
          border-radius: 50%;
          display: flex;
          justify-content: center;
          align-items: center;
          transition: all 0.3s ease-in-out 0s; }
          .sec03 .inn > div .d_btn .icon > span {
            display: inline-block;
            line-height: 0;
            font-size: 0;
            margin: 0;
            padding: 0;
            position: relative; }
            .sec03 .inn > div .d_btn .icon > span .off {
              position: relative;
              opacity: 1;
              transition: all 0.3s ease-in-out 0s; }
            .sec03 .inn > div .d_btn .icon > span .on {
              position: absolute;
              inset: 0;
              opacity: 0;
              transition: all 0.3s ease-in-out 0s; }
        .sec03 .inn > div .d_btn:hover .icon {
          background: #555555; }
          .sec03 .inn > div .d_btn:hover .icon > span .off {
            opacity: 0; }
          .sec03 .inn > div .d_btn:hover .icon > span .on {
            opacity: 1; }

.slide_img {
  overflow: hidden;
  position: relative; }
  .slide_img .inn {
    position: relative;
    display: flex;
    width: calc(((480vw * 7) / 16) * 2);
    animation: slider 75s linear infinite both; }
    @media screen and (max-width: 480px) {
      .slide_img .inn {
        width: calc(((330vw * 7) / 4.8) * 2); } }
    .slide_img .inn .img01 {
      width: calc((480vw * 7) / 16);
      display: flex; }
      @media screen and (max-width: 480px) {
        .slide_img .inn .img01 {
          width: calc((330vw * 7) / 4.8); } }
      .slide_img .inn .img01 li {
        width: calc(480vw / 16); }
        @media screen and (max-width: 480px) {
          .slide_img .inn .img01 li {
            width: calc(330vw / 4.8); } }
        .slide_img .inn .img01 li > div {
          overflow: hidden; }

@keyframes slider {
  0% {
    transform: translateX(0); }
  100% {
    transform: translateX(-50%); } }
@media screen and (max-width: 480px) {
  .sp_ex {
    letter-spacing: 0.08em !important; } }

/*# sourceMappingURL=renovation.css.map */
