#hero {
  position: relative;
}
#hero .visual {
  aspect-ratio: 1/1.4;
  object-fit: cover;
  object-position: 70% center;
}
@media (768px <= width) {
  #hero .visual {
    aspect-ratio: 1.4/1;
    width: 100%;
    max-height: 85vh;
    object-position: top center;
  }
}
#hero *[data-aos=fade-up] {
  transform: translate3d(0, 16px, 0);
}
#hero *[data-aos=fade-up].aos-animate {
  transform: translate3d(0, 0px, 0);
}
#hero .float-content {
  position: absolute;
  bottom: 16px;
  left: 0;
  right: 0;
  z-index: 100;
}
@media (768px <= width) {
  #hero .float-content {
    bottom: 48px;
  }
}
#hero .float-content > div {
  width: calc(100% - 48px);
  max-width: 1160px;
  margin-inline: auto;
}
#hero .float-content > div h1 {
  font-family: YuMincho, serif;
  text-shadow: 0 0 24px rgb(1, 63, 110);
  font-size: 48px;
  font-weight: normal;
  line-height: 1.4;
  margin: 0;
  color: #fff;
}
@media (768px <= width) {
  #hero .float-content > div h1 {
    font-size: 96px;
  }
}
#hero .float-content > div .lead {
  font-weight: bold;
  margin-top: 16px;
  color: rgb(1, 62, 110);
}
@media (768px <= width) {
  #hero .float-content > div .lead {
    margin-top: 32px;
  }
}
#hero .float-content > div .lead p {
  margin: 0;
}
#hero .float-content > div .lead p + p {
  margin-top: 8px;
}
@media (768px <= width) {
  #hero .float-content > div .lead p + p {
    margin-top: 16px;
  }
}
#hero .float-content > div .lead br {
  display: none;
}
@media (768px <= width) {
  #hero .float-content > div .lead br {
    display: initial;
  }
}
#hero .float-content > div .footer-link {
  margin-top: 24px;
}

.p-guide__links {
  display: grid;
  gap: 16px;
}
.p-guide__link {
  display: block;
  text-decoration: none;
  background: #cbb04e;
  color: #fff;
  border-radius: 4px;
  line-height: 1.6;
  position: relative;
  overflow: hidden;
}
.p-guide__link-image {
  left: 0;
  top: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@media (768px <= width) {
  .p-guide__link-image {
    aspect-ratio: 1.4/1;
  }
}
.p-guide__link-eng {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
}
@media (768px <= width) {
  .p-guide__link-eng {
    font-size: 12px;
  }
}
.p-guide__link-jp {
  display: block;
  margin-top: 4px;
}
@media (768px <= width) {
  .p-guide__link-jp {
    font-size: 24px;
  }
}
.p-guide__link-jp br {
  display: none;
}
@media (768px <= width) {
  .p-guide__link-jp br {
    display: initial;
  }
}
.p-guide__link-content-wrapper {
  display: grid;
  grid-template-columns: 96px 1fr 32px;
  align-items: center;
  gap: 16px;
  padding-right: 16px;
}
@media (768px <= width) {
  .p-guide__link-content-wrapper {
    grid-template-columns: 240px 1fr 50px;
    padding-right: 32px;
    gap: 24px;
  }
}
.p-guide__link-text-wrapper {
  padding: 12px 0px;
}
@media (768px <= width) {
  .p-guide__link-text-wrapper {
    padding: 24px 0;
    padding: 32px;
  }
}
.p-guide__link-decoration {
  font-size: 14px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  position: relative;
  transition: border 0.3s;
  width: 32px;
  height: 32px;
  margin-left: auto;
}
@media (768px <= width) {
  .p-guide__link-decoration {
    font-size: 15px;
    margin-top: 0;
    width: 50px;
    height: 50px;
  }
}
.p-guide__link-decoration::after {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  background: #fff;
  border-radius: 50%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  transition: opacity 0.3s, transform 0.3s;
  opacity: 0;
}
@media (768px <= width) {
  .p-guide__link-decoration::after {
    width: 8px;
    height: 8px;
  }
}
.p-guide__link-decoration img {
  position: absolute;
  right: 24px;
  left: 50%;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
}
@media (768px <= width) {
  .p-guide__link-decoration img {
    width: 8px;
    height: 12px;
  }
}
.p-guide__link:hover .p-guide__link-decoration {
  border: 1px solid #fff;
}
.p-guide__link:hover .p-guide__link-decoration::after {
  opacity: 1;
  transform: translateY(-50%) translateX(-50%) scale(1.5);
}
.p-guide__link:hover .p-guide__link-decoration img {
  opacity: 0;
}

.p-about__footer-link {
  margin-top: 24px;
}

#businesses > div {
  width: calc(100% - 48px);
  max-width: 1160px;
  margin-inline: auto;
}
#businesses > div h2 + * {
  margin-top: 16px;
}
@media (768px <= width) {
  #businesses > div h2 + * {
    margin-top: 32px;
  }
}
#businesses > div .content {
  max-width: 1160px;
  margin-inline: auto;
}
#businesses > div .content section + section {
  margin-top: 32px;
}
@media (768px <= width) {
  #businesses > div .content section + section {
    margin-top: 48px;
  }
}
@media (768px <= width) {
  #businesses > div .content section {
    display: flex;
    gap: 32px;
    align-items: center;
  }
}
@media (768px <= width) {
  #businesses > div .content section .image {
    flex: 1;
  }
}
#businesses > div .content section .image img {
  aspect-ratio: 1.4/1;
  object-fit: cover;
  border-radius: 4px;
}
#businesses > div .content section .body {
  margin-top: 24px;
}
@media (768px <= width) {
  #businesses > div .content section .body {
    flex: 1;
    margin-top: 0;
  }
}
#businesses > div .content section .body h3 {
  line-height: 1.6;
  font-size: 20px;
}
@media (768px <= width) {
  #businesses > div .content section .body h3 {
    font-size: 24px;
  }
}
#businesses > div .content section .body h3 + * {
  margin-top: 16px;
}
#businesses > div .content section .body dl dd {
  margin: 0;
}
#businesses > div .content section .body dl dd ul {
  padding: 0;
  margin: 0;
}
#businesses > div .content section .body dl dd ul li {
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.6;
}
#businesses > div .content section .body dl dd ul li + li {
  margin-top: 8px;
}
#businesses > div .content section .body dl dd ul li a,
#businesses > div .content section .body dl dd ul li .online {
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  text-decoration: none;
}
#businesses > div .content section .body dl dd ul li a i,
#businesses > div .content section .body dl dd ul li .online i {
  color: #cbb04e;
}
#businesses > div .content section .body dl dd ul li a span,
#businesses > div .content section .body dl dd ul li .online span {
  font-size: 14px;
}
#businesses > div .content section .body .body-footer a {
  margin-left: auto;
}

#base > div .content {
  max-width: 1160px;
  margin-inline: auto;
}
@media (768px <= width) {
  #base > div .content section {
    display: flex;
    gap: 32px;
    align-items: center;
  }
}
#base > div .content section + section {
  margin-top: 32px;
}
@media (768px <= width) {
  #base > div .content section + section {
    margin-top: 48px;
  }
}
@media (768px <= width) {
  #base > div .content section .image {
    flex: 1;
  }
}
#base > div .content section .image img {
  aspect-ratio: 1.4/1;
  object-fit: cover;
  border-radius: 4px;
}
#base > div .content section .body {
  margin-top: 24px;
}
@media (768px <= width) {
  #base > div .content section .body {
    flex: 1;
    margin-top: 0;
  }
}
#base > div .content section .body h3 {
  line-height: 1.6;
  font-size: 20px;
}
@media (768px <= width) {
  #base > div .content section .body h3 {
    font-size: 24px;
  }
}
#base > div .content section .body h3 + * {
  margin-top: 16px;
}
#base > div .content section .body dl dd {
  margin: 0;
}
#base > div .content section .body dl dd ul {
  padding: 0;
  margin: 0;
  list-style: none;
}
#base > div .content section .body dl dd ul li {
  line-height: 1.6;
}
#base > div .content section .body dl dd ul li + li {
  margin-top: 8px;
}
#base > div .content section .body dl dd ul li a {
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  text-decoration: none;
}
#base > div .content section .body dl dd ul li a i {
  color: #cbb04e;
}
#base > div .content section .body dl dd ul li a span {
  font-size: 14px;
}
#base > div .content section .body .body-footer a {
  margin-left: auto;
}

#news > div ul {
  list-style: none;
  padding: 0;
}
#news > div ul li + li {
  margin-top: 16px;
}
#news > div ul li a {
  background: rgb(248, 248, 248);
  padding: 16px;
  display: block;
  border-radius: 8px;
  text-decoration: none;
  display: grid;
  grid-template-columns: 1fr 50px;
  align-items: center;
  gap: 16px;
}
@media (768px <= width) {
  #news > div ul li a {
    padding: 24px;
  }
}
@media (768px <= width) {
  #news > div ul li a .content {
    display: flex;
    gap: 24px;
  }
}
#news > div ul li a .content .info {
  display: flex;
  gap: 8px;
  font-size: 14px;
  line-height: 1.6;
  align-items: center;
}
#news > div ul li a .content .info time {
  font-family: "Inter", sans-serif;
  color: #666;
}
@media (768px <= width) {
  #news > div ul li a .content .info time {
    width: 88px;
  }
}
#news > div ul li a .content .info span {
  padding: 2px 6px;
  background: rgb(255, 255, 255);
  border-radius: 4px;
  color: rgb(1, 62, 110);
  font-size: 13px;
}
@media (768px <= width) {
  #news > div ul li a .content .info span {
    font-size: 13px;
    width: 140px;
    text-align: center;
  }
}
#news > div ul li a .content .title {
  display: block;
  margin-top: 16px;
  line-height: 1.6;
}
@media (768px <= width) {
  #news > div ul li a .content .title {
    margin-top: 0;
  }
}
#news > div ul li a .accent {
  font-size: 14px;
  border: 1px solid #ccc;
  border-radius: 50%;
  position: relative;
  transition: border 0.3s;
  width: 50px;
  height: 50px;
}
@media (768px <= width) {
  #news > div ul li a .accent {
    font-size: 15px;
  }
}
#news > div ul li a .accent::after {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  background: rgb(45, 94, 139);
  border-radius: 50%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  transition: opacity 0.3s, transform 0.3s;
  opacity: 0;
}
@media (768px <= width) {
  #news > div ul li a .accent::after {
    width: 8px;
    height: 8px;
  }
}
#news > div ul li a .accent img {
  position: absolute;
  right: 24px;
  left: 50%;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
}
@media (768px <= width) {
  #news > div ul li a .accent img {
    width: 8px;
    height: 12px;
  }
}
#news > div ul li a:hover .accent {
  border: 1px solid rgb(45, 94, 139);
}
#news > div ul li a:hover .accent::after {
  opacity: 1;
  transform: translateY(-50%) translateX(-50%) scale(1.5);
}
#news > div ul li a:hover .accent img {
  opacity: 0;
}
#news > div .footer a {
  margin-left: auto;
}
@media (768px <= width) {
  #news > div .footer a {
    margin-top: 32px;
    margin-right: auto;
  }
}

/*# sourceMappingURL=front-page.css.map */
