@charset "utf-8";

img {
  width: 100%;
}

.SPBR {
  display: none;
}

@media screen and (max-width: 768px) {
  .SPBR {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .SPDN {
    display: none;
  }
}

/* ---------------------------- */
/* --- Loading --- */
/* ---------------------------- */

.Loading {
  position: fixed;
  inset: 0;
  margin: auto;
  background-color: #FFFFFF;
  z-index: 10000;
  animation: loading 1s ease-in-out 2.3s 1 normal forwards;
}

@media screen and (max-width: 768px) {
  .Loading {
    animation: loading 1s ease-in-out 2.3s 1 normal forwards;
  }
}

@keyframes loading {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    pointer-events: none;
  }
}

.Loading-Logo {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 29px;
  left: 0;
  margin: auto;
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 349px;
  opacity: 0;
  animation: loading-logo 1s linear 0s 1 normal forwards;
}

@media screen and (max-width: 768px) {
  .Loading-Logo {
    bottom: 6.338028169014084%;
    max-width: 79.375%;
  }
}

@keyframes loading-logo {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.Loading-Decoration {
  position: absolute;
  top: 93px;
  bottom: 0;
  margin: auto;
  width: 400vw;
  height: 2px;
  background-color: #71A5CA;
  transform: translateX(-100%);
  animation: loading-move 3s ease-in-out 1s 1 normal forwards;
}

@media screen and (max-width: 768px) {
  .Loading-Decoration {
    top: 20.774647887323944%;
    animation: loading-move 2s ease-in-out 1s 1 normal forwards;
  }
}

@keyframes loading-move {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(400vw);
  }
}

/* ---------------------------- */
/* --- Fv --- */
/* ---------------------------- */
.Fv {
  position: relative;
  margin-top: 78px;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media screen and (max-width: 768px) {
  .Fv {
    margin-top: 61px;
  }
}

.Fv-Bg {
  width: 100%;
  aspect-ratio: 128/59;
}

.Fv-BgSp {
  width: 100%;
  aspect-ratio: 78/101;
  display: none;
}

.Fv-Bg img,
.Fv-BgSp img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .Fv-Bg {
    display: none;
  }

  .Fv-BgSp {
    display: block;
  }
}

.Fv-Inner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -38%);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 1140px;
}

.Fv-Inner-Content-SubTitle {
  padding: 2px 5px 2px 5px;
  display: inline-block;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: 0.05em;
  background: #71A5CA;
  color: #FFFFFF;
}

.Fv-Inner-Content-SubTitleSp span {
  padding: 2px 5px 2px 5px;
  display: inline-block;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  letter-spacing: 0.05em;
  background: #71A5CA;
  color: #FFFFFF;
  font-size: 18px;
}

.Fv-Inner-Content-SubTitleSp.isB {
  margin-top: 7px;
}

.Fv-Inner-Content-Title {
  margin-top: 32px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 40px;
  line-height: 150%;
  letter-spacing: 0.1em;
  text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
  color: #FFFFFF;
}

@media screen and (max-width: 1141px) {
  .Fv-Inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

@media screen and (max-width: 768px) {
  .Fv-Inner {
    transform: translate(-50%, -34%);
  }

  .Fv-Inner-Content-SubTitle {
    display: none;
  }

  .Fv-Inner-Content-SubTitleSp span {
    font-size: 14px;
  }

  .Fv-Inner-Content-Title {
    margin-top: 12px;
    line-height: 130%;
    font-weight: 500;
    font-size: 32px;
    letter-spacing: 0.3px;
  }
}

@media screen and (max-width: 378px) {
  .Fv-Inner-Content-Title {
    font-size: 30px;
  }
}

@media screen and (max-width: 356px) {
  .Fv-Inner-Content-Title {
    font-size: 28px;
  }
}

@media screen and (max-width: 335px) {
  .Fv-Inner-Content-Title {
    font-size: 26px;
  }
}

@media screen and (max-width: 417px) {
  .Fv-Inner-Content-SubTitleSp span {
    font-size: 12px;
  }
}

@media screen and (max-width: 363px) {
  .Fv-Inner-Content-SubTitleSp span {
    font-size: 10px;
  }
}
/* ---------------------------- */
/* --- スライドショー --- */
/* ---------------------------- */
.swiper {
  margin-top: 78px;
}
@media screen and (max-width: 768px) {
  .swiper {
    margin-top: 61px;
  }
}
.swiper-container .swiper-slide {
	position: relative;
}
.swiper-container .swiper-slide .swiper-slide-content {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.swiper-slide-img-sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .swiper-slide-img-pc {
    display: none;
  }

  .swiper-slide-img-sp {
    display: block;
  }
}
/* ---------------------------- */
/* --- Scroll --- */
/* ---------------------------- */
.Scroll {
  padding-left: 16px;
  padding-right: 16px;
  height: 60px;
  line-height: 60px;
  background: #71A5CA;
}

.Scroll-Inner {
  position: relative;
  z-index: 2;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  max-width: 1140px;
}

.Scroll-Inner-Border {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 2px;
  height: 188px;
  background: #FFFFFF;
  animation: scrollanimation 2.5s cubic-bezier(1, 0, 0, 1) infinite;
}

.Scroll-Inner-Text {
  font-family: 'EB Garamond', sans-serif;
  font-weight: 400;
  font-size: 20px;
  letter-spacing: 0.1em;
  color: #FFFFFF;
}

@media screen and (max-width: 1141px) {
  .Scroll-Inner-Border {
    width: 1px;
    height: 117px;
  }
}

@media screen and (max-width: 768px) {
  .Scroll-Inner {
    padding-left: 9px;
  }

  .Scroll-Inner-Text {
    font-size: 14px;
  }
}

@keyframes scrollanimation {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }

  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }

  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }

  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}

/* ---------------------------- */
/* --- AboutSection --- */
/* ---------------------------- */
.About {
  padding-left: 50px;
  width: 100%;
  background: #71A5CA;
}

.About-Inner {
  margin-left: auto;
  width: 100%;
  max-width: 1208px;
  background: #71A5CA;
}

@media screen and (min-width: 1281px) {
  .About-Inner {
    margin-right: auto;
  }
}

.About-Inner-Img {
  margin-left: auto;
  width: 60%;
  aspect-ratio: 737/513;
}

.About-Inner-Img img {
  width: 100%;
  height: auto;
}

.About-Inner {
  position: relative;
}

.About-Inner-Content {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.About-Inner-Content-Headline {
  width: 167px;
}

.About-Inner-Content-Title {
  margin-top: 24px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 28px;
  line-height: 150%;
  letter-spacing: 0.05em;
  color: #FFFFFF;
}

.About-Inner-Content-Text {
  margin-top: 32px;
  max-width: 511px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 180%;
  letter-spacing: 0.05em;
  color: #FFFFFF;
}

@media screen and (max-width: 768px) {
  .About {
    padding-top: 34px;
    padding-left: 16px;
    padding-bottom: 36px;
  }

  .About-Inner-Content {
    position: relative;
    top: inherit;
    left: inherit;
    transform: none;
    padding-right: 16px;
  }

  .About-Inner-Content-Title {
    margin-top: 25px;
    font-size: 20px;
  }

  .About-Inner-Content-Text {
    margin-top: 24px;
    font-size: 14px;
  }

  .About-Inner-Img {
    margin-top: 32px;
    width: 100%;
  }
}

/* ---------------------------- */
/* --- NewsSection --- */
/* ---------------------------- */
.News {
  background-color: #FFFFFF;
  overflow: hidden;
}

.News__Container {
  padding-top: 72px;
  padding-right: 50px;
  padding-bottom: 94px;
  padding-left: 50px;
}

@media screen and (max-width: 768px) {
  .News__Container {
    padding-top: 50px;
    padding-right: 16px;
    padding-bottom: 48px;
    padding-left: 16px;
  }
}

.News__Inner {
  position: relative;
  margin-right: auto;
  margin-left: auto;
  width: 100%;
  max-width: 944px;
}

.News__Inner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 71%;
  bottom: 0;
  margin-top: -72px;
  margin-bottom: -94px;
  width: 100vw;
  background-color: #F9F9F9;
}

@media screen and (max-width: 768px) {
  .News__Inner::before {
    margin-top: -50px;
    margin-bottom: -48px;
    left: initial;
    right: 100px;
    transform: translateX(100%);
  }
}

.News-Headline {
  position: relative;
  margin-right: auto;
  margin-bottom: 39px;
  margin-left: auto;
  width: 119px;
}

@media screen and (max-width: 768px) {
  .News-Headline {
    margin-bottom: 21px;
    width: 117px;
  }
}

.News-List {
  position: relative;
  margin-bottom: 38px;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .News-List {
    margin-bottom: 40px;
  }
}

.News-List>*+* {
  border-top: 1px solid #C4C4C4;
}

@media screen and (max-width: 768px) {
  .News-List>*+* {
    border-top: initial;
  }
}

@media screen and (max-width: 768px) {
  .News-List-Item {
    margin-right: auto;
    margin-left: auto;
    border-bottom: 1px solid #C4C4C4;
    max-width: 500px;
  }
}

.News-List-Item__Link {
  position: relative;
  padding-top: 32px;
  padding-bottom: 32px;
  display: flex;
  align-items: start;
  gap: 78px;
}

@media screen and (max-width: 768px) {
  .News-List-Item__Link {
    padding-top: 24px;
    padding-bottom: 24px;
    display: block;
  }
}

.News-List-Item-Time {
  font-family: 'Heebo', sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 12px;
  line-height: 24px;
  color: #969696;
}

@media screen and (max-width: 768px) {
  .News-List-Item-Time {
    margin-bottom: 2px;
    font-size: 12px;
    line-height: 200%;
  }
}

.News-List-Item-Text {
  position: relative;
  padding-right: 58px;
  width: 100%;
  font-family: 'Noto Sans JP', sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 16px;
  line-height: 24px;
  color: #969696;
  transition: all .4s;
}

@media screen and (max-width: 768px) {
  .News-List-Item-Text {
    padding-right: 14px;
    font-size: 14px;
    line-height: 171%;
  }
}

.News-List-Item__Link:hover .News-List-Item-Text {
  color: #71A5CA;
}

.News-List-Item-Text-Decoration {
  position: absolute;
  top: 0px;
  right: 25px;
  bottom: 0;
  margin: auto;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .News-List-Item-Text-Decoration {
    right: 4px;
  }
}

.News-List-Item-Text-Decoration img {
  display: block;
  height: 14px;
  flex-shrink: 0;
}

@media screen and (max-width: 768px) {
  .News-List-Item-Text-Decoration img {
    height: 10px;
  }
}

.News-Link {
  position: relative;
  margin-right: auto;
  margin-left: auto;
  border: 1px solid #CA9671;
  display: block;
  width: 314px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #FFFFFF;
  text-align: center;
  background-color: #CA9671;
  transition: all 0.3s;
}

@media screen and (max-width: 768px) {
  .News-Link {
    width: 260px;
    line-height: 150%;
  }
}

.News-Link:hover {
  color: #CA9671;
}

@media screen and (max-width: 768px) {
  .News-Link:hover {
    color: #FFFFFF;
  }
}

.News-Link::before {
  content: "";
  position: absolute;
  top: 1px;
  right: 1px;
  bottom: 1px;
  left: 1px;
  margin: auto;
  background-color: #FFFFFF;
  transition: transform 0.3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}

.News-Link:hover.News-Link::before {
  transform-origin: left top;
  transform: scale(1, 1);
}

@media screen and (max-width: 768px) {
  .News-Link:hover.News-Link::before {
    transform: scale(0, 1);
    transform-origin: right top;
  }
}

.News-Link__Contents {
  position: relative;
  z-index: 1;
  padding-top: 18px;
  padding-bottom: 18px;
  display: block;
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 768px) {
  .News-Link__Contents {
    padding-top: 15px;
    padding-bottom: 15px;
  }
}

.News-Link-Decoration {
  position: absolute;
  top: 0;
  right: 32px;
  bottom: 0;
  margin: auto;
  display: block;
  width: 32px;
  height: 9px;
}

@media screen and (max-width: 768px) {
  .News-Link-Decoration {
    right: 21px;
  }
}

.News-Link-Decoration-Path01 {
  stroke-dasharray: 50;
  stroke-dashoffset: 100;
  stroke: #FFFFFF;
  animation: HoverEnd 0.8s ease-in-out 0s 1 normal forwards;
}

@media screen and (max-width: 768px) {
  .News-Link-Decoration-Path01 {
    animation: initial;
  }
}

.News-Link:hover .News-Link-Decoration-Path01 {
  stroke: #CA9671;
  animation: HoverStart 0.8s ease-in-out 0s 1 normal forwards;
}

@keyframes HoverStart {
  0% {
    stroke-dasharray: 50;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes HoverEnd {
  0% {
    stroke-dasharray: 50;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

/* ---------------------------- */
/* --- FlowSection --- */
/* ---------------------------- */

.Flow {
  position: relative;
}

.Flow__Container {
  padding-top: 72px;
  padding-right: 50px;
  padding-bottom: 189px;
  padding-left: 50px;
}

@media screen and (max-width: 768px) {
  .Flow__Container {
    padding-top: 86px;
    padding-right: 16px;
    padding-bottom: 76px;
    padding-left: 16px;
  }
}

.Flow__Inner {
  position: relative;
  margin-right: auto;
  margin-left: auto;
  max-width: 944px;
  width: 100%;
}

.Flow__Inner::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 288px;
  transform: translateX(-100%);
  margin-top: -72px;
  margin-bottom: -189px;
  width: 100vw;
  background-color: #E3EDF4;
}

@media screen and (max-width: 768px) {
  .Flow__Inner::before {
    left: 100px;
    margin-top: -86px;
    margin-bottom: -76px;
  }
}

.Flow-Headline {
  position: relative;
  margin-right: auto;
  margin-bottom: 26px;
  margin-left: auto;
  width: 127px;
}

@media screen and (max-width: 768px) {
  .Flow-Headline {
    margin-bottom: 39px;
    width: 124px;
  }
}

.Flow-List>*+* {
  position: relative;
  padding-top: 90px;
}

@media screen and (max-width: 768px) {
  .Flow-List>*+* {
    padding-top: 24px;
  }
}

.Flow-List>*+*::before {
  content: "";
  position: absolute;
  top: 0px;
  left: 42px;
  background-image: url(../images/top-flow-icon.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 18px;
  height: calc(100% - 128.5px);
  display: flex;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .Flow-List>*+*::before {
    left: 25px;
    width: 10px;
    height: 24px;
  }
}

.Flow-List-Item {
  position: relative;
  display: flex;
  align-items: end;
  gap: 44px;
}

@media screen and (max-width: 768px) {
  .Flow-List-Item {
    gap: 25px;
    align-items: start;
  }
}

.Flow-List-Item-Num {
  flex-shrink: 0;
  width: 159px;
}

@media screen and (max-width: 768px) {
  .Flow-List-Item-Num {
    width: 91px;
  }
}

.Flow-List-Item-Title {
  margin-bottom: 16px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 18px;
  line-height: 150%;
  letter-spacing: 0.05em;
  color: #1A1A1A;
}

@media screen and (max-width: 768px) {
  .Flow-List-Item-Title {
    margin-bottom: 8px;
    font-size: 16px;
  }
}

.Flow-List-Item-Text {
  position: relative;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 15px;
  line-height: 180%;
  letter-spacing: 0.1em;
  color: #333333;
}

@media screen and (max-width: 768px) {
  .Flow-List-Item-Text {
    font-size: 12px;
    line-height: 150%;
  }
}

/* ---------------------------- */
/* --- NavSection --- */
/* ---------------------------- */
.Nav {
  width: 100%;
  display: flex;
}

.Nav-Item {
  position: relative;
  width: calc(100%/3);
}

@media screen and (max-width: 1000px) {
  .Nav {
    flex-wrap: wrap;
  }

  .Nav-Item {
    width: 100%;
  }
}

.Nav-Item-Bg {
  width: 100%;
  aspect-ratio: 427/418;
}

.Nav-Item-Bg.isLawyer {
  height: 100%;
  aspect-ratio: 439/417;
}

.Nav-Item-Bg img {
  width: 100%;
  height: auto;
}

.Nav-Item-Bg.isLawyer img {
  height: 100%;
}

.Nav-Item-Content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 299px;
}

.Nav-Item-Content-Headline {
  margin-left: auto;
  margin-right: auto;
}

.Nav-Item-Content-Headline.isLawyer {
  width: 153px;
}

.Nav-Item-Content-Headline.isAccess {
  width: 124px;
}

.Nav-Item-Content-Headline.isContact {
  width: 159px;
}

.Nav-Item-Content-Text {
  margin-top: 3.5vw;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.8;
  text-align: center;
  letter-spacing: 0.05em;
  color: #FFFFFF;
}

.Nav-Item-Content-Btn {
  position: relative;
  margin-top: 3.5vw;
  margin-right: auto;
  margin-left: auto;
  border: 1px solid #FFFFFF;
  display: block;
  width: 222px;
  text-align: center;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #FFFFFF;
}

.Nav-Item-Content-Btn::before {
  content: "";
  position: absolute;
  top: -1px;
  right: -1px;
  bottom: -1px;
  left: -1px;
  margin: auto;
  background-color: #71A5CA;
  transition: transform 0.3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}

.Nav-Item-Content-Btn:hover.Nav-Item-Content-Btn::before {
  transform-origin: left top;
  transform: scale(1, 1);
}

.Nav-Item-Content-Btn__Contents {
  position: relative;
  z-index: 1;
  padding-top: 18px;
  padding-bottom: 18px;
  display: block;
  width: 100%;
  height: 100%;
}

.Nav-Item-Content-Btn-Decoration {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto;
  display: flex;
  width: 24px;
}

.Nav-Item-Content-Btn-Decoration-Path01 {
  stroke-dasharray: 50;
  stroke-dashoffset: 100;
  stroke: #FFFFFF;
  animation: HoverEnd 0.8s ease-in-out 0s 1 normal forwards;
}

.Nav-Item-Content-Btn:hover .Nav-Item-Content-Btn-Decoration-Path01 {
  animation: HoverStart 0.8s ease-in-out 0s 1 normal forwards;
}

@keyframes HoverStart {
  0% {
    stroke-dasharray: 50;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes HoverEnd {
  0% {
    stroke-dasharray: 50;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

@media screen and (max-width: 480px) {
  .Nav-Item-Content-Text {
    margin-top: 6vw;
  }

  .Nav-Item-Content-Btn {
    margin-top: 6vw;
  }
}

/* ---------------------------- */
/* --- Google MAP --- */
/* ---------------------------- */
#map {
  width: 100%;
  height: 358px;
}

@media screen and (max-width: 768px) {
  #map {
    height: 349px;
  }
}