*,
*::before,
*::after {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

:where([hidden]:not([hidden='until-found'])) {
	display: none !important;
}

:where(html) {
	-webkit-text-size-adjust: none;
}

@supports not (min-block-size: 100dvb) {
	:where(html) {
		block-size: 100%;
	}
}

@media (prefers-reduced-motion: no-preference) {
	:where(html:focus-within) {
		scroll-behavior: smooth;
	}
}

:where(body) {
	block-size: 100%;
	block-size: 100dvb;
	line-height: 1.5;
	font-family: system-ui, sans-serif;
	-webkit-font-smoothing: antialiased;
}

:where(input, button, textarea, select) {
	font: inherit;
	color: inherit;
}

:where(textarea) {
	resize: vertical;
	resize: block;
}

:where(button, label, select, summary, [role='button'], [role='option']) {
	cursor: pointer;
}

:where(:disabled) {
	cursor: not-allowed;
}

:where(label:has(> input:disabled), label:has(+ input:disabled)) {
	cursor: not-allowed;
}

:where(button) {
	border-style: solid;
}

:where(a) {
	text-underline-offset: 0.2ex;
}

:where(ul, ol) {
	list-style: none;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
	display: block;
}

:where(img, picture, svg) {
	max-inline-size: 100%;
	block-size: auto;
}

:where(p, h1, h2, h3, h4, h5, h6) {
	overflow-wrap: break-word;
}

:where(h1, h2, h3) {
	line-height: calc(1em + 0.5rem);
}

:where(hr) {
	border: none;
	-webkit-border-before: 1px solid;
	        border-block-start: 1px solid;
	color: inherit;
	block-size: 0;
	overflow: visible;
}

:where(:focus-visible) {
	outline: 2px solid var(--focus-color, Highlight);
	outline-offset: 2px;
}

:where(.visually-hidden:not(:focus, :active, :focus-within, .not-visually-hidden)) {
	-webkit-clip-path: inset(50%) !important;
	        clip-path: inset(50%) !important;
	height: 1px !important;
	width: 1px !important;
	overflow: hidden !important;
	position: absolute !important;
	white-space: nowrap !important;
	border: 0 !important;
}

/*!
 * Luminous v2.3.5
 * Copyright 2015-2021, Zebrafish Labs
 * Licensed under BSD-2 (https://github.com/imgix/luminous/blob/main/LICENSE.md)
 */@keyframes a{0%{opacity:0}to{opacity:1}}@keyframes b{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes c{0%{transform:translate(-50%,-50%) rotate(0)}50%{transform:translate(-50%,-50%) rotate(-180deg)}to{transform:translate(-50%,-50%) rotate(-1turn)}}@keyframes d{0%{transform:scale(1)}10%{transform:scale(1.2) translateX(6px)}25%{transform:scale(1.3) translateX(8px)}40%{transform:scale(1.2) translateX(6px)}50%{transform:scale(1)}60%{transform:scale(.8) translateX(6px)}75%{transform:scale(.7) translateX(8px)}90%{transform:scale(.8) translateX(6px)}to{transform:scale(1)}}@keyframes e{0%{transform:scale(1)}10%{transform:scale(1.2) translateX(-6px)}25%{transform:scale(1.3) translateX(-8px)}40%{transform:scale(1.2) translateX(-6px)}50%{transform:scale(1)}60%{transform:scale(.8) translateX(-6px)}75%{transform:scale(.7) translateX(-8px)}90%{transform:scale(.8) translateX(-6px)}to{transform:scale(1)}}.lum-lightbox{background:rgba(0,0,0,.6)}.lum-lightbox-inner{bottom:2.5%;left:2.5%;right:2.5%;top:2.5%}.lum-lightbox-inner img{position:relative}.lum-lightbox-inner .lum-lightbox-caption{color:#fff;margin:0 auto;max-width:700px;text-align:center}.lum-loading .lum-lightbox-loader{animation:c 1.8s linear infinite;display:block;height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:66px}.lum-lightbox-loader:after,.lum-lightbox-loader:before{background:hsla(0,0%,100%,.9);border-radius:20px;content:"";display:block;height:20px;margin-top:-10px;position:absolute;top:50%;width:20px}.lum-lightbox-loader:before{animation:d 1.8s linear infinite;left:0}.lum-lightbox-loader:after{animation:e 1.8s linear infinite;animation-delay:-.9s;right:0}.lum-lightbox.lum-opening{animation:a .18s ease-out}.lum-lightbox.lum-opening .lum-lightbox-inner{animation:b .18s ease-out}.lum-lightbox.lum-closing{animation:a .3s ease-in;animation-direction:reverse}.lum-lightbox.lum-closing .lum-lightbox-inner{animation:b .3s ease-in;animation-direction:reverse}.lum-img{transition:opacity .12s ease-out}.lum-loading .lum-img{opacity:0}.lum-gallery-button{background:transparent;border:0;cursor:pointer;height:100px;margin:0;max-height:100%;outline:0;overflow:hidden;padding:0;position:absolute;text-indent:150%;top:50%;transform:translateY(-50%);white-space:nowrap;width:60px}.lum-close-button{height:32px;opacity:.3;position:absolute;right:5px;top:5px;width:32px}.lum-close-button:hover{opacity:1}.lum-close-button:after,.lum-close-button:before{background-color:#fff;content:" ";height:33px;left:15px;position:absolute;width:2px}.lum-close-button:before{transform:rotate(45deg)}.lum-close-button:after{transform:rotate(-45deg)}.lum-previous-button{left:12px}.lum-next-button{right:12px}.lum-gallery-button:after{border-top:4px solid hsla(0,0%,100%,.8);content:"";display:block;height:36px;position:absolute;top:50%;width:36px}.lum-previous-button:after{border-left:4px solid hsla(0,0%,100%,.8);border-radius:3px 0 0 0;box-shadow:-2px 0 rgba(0,0,0,.2);left:12%;transform:translateY(-50%) rotate(-45deg)}.lum-next-button:after{border-radius:0 3px 0 0;border-right:4px solid hsla(0,0%,100%,.8);box-shadow:2px 0 rgba(0,0,0,.2);right:12%;transform:translateY(-50%) rotate(45deg)}@media (max-width:460px){.lum-lightbox-image-wrapper{-webkit-overflow-scrolling:touch;display:flex;overflow:auto}.lum-lightbox-caption{bottom:0;position:absolute;width:100%}.lum-lightbox-position-helper{margin:auto}.lum-lightbox-inner img{max-height:none;max-width:none}}
html.l {
  font-size: 120%;
}

body {
  font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.125rem;
  line-height: 1.7777777778;
}
@media screen and (max-width: 749px) {
  body {
    font-size: 1rem;
  }
}
@media screen and (max-width: 749px) {
  .main {
    padding-top: 60px;
  }
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  line-height: 1;
}

.lum-gallery-button {
  display: none;
}

.lum-img {
  margin: auto;
}

.clearfix::after {
  clear: both;
  content: "";
  display: table;
}

@media screen and (min-width: 750px), print {
  .float-left {
    float: left;
  }
  .float-right {
    float: right;
  }
}
.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  max-width: 1032px;
  padding-left: 16px;
  padding-right: 16px;
}
.container.is-wide {
  max-width: 1232px;
}
.container.no-mv {
  margin-top: 50px;
}

a:not([class]) {
  color: #52A28B;
  text-decoration: underline;
}

h1 {
  font-size: 1.5rem;
  font-weight: bold;
}
@media screen and (max-width: 749px) {
  h1 {
    font-size: 1.25rem;
  }
}

h2, h3, h4 {
  margin-bottom: 22px;
}
@media screen and (max-width: 749px) {
  h2, h3, h4 {
    margin-bottom: 15px;
  }
}
h2 + h2, h2 + h3, h2 + h4, h3 + h2, h3 + h3, h3 + h4, h4 + h2, h4 + h3, h4 + h4 {
  margin-top: 50px;
}
@media screen and (max-width: 749px) {
  h2 + h2, h2 + h3, h2 + h4, h3 + h2, h3 + h3, h3 + h4, h4 + h2, h4 + h3, h4 + h4 {
    margin-top: 20px;
  }
}

h2 {
  font-size: 1.375rem;
  font-weight: bold;
  color: #107557;
  border: 1px solid #52A28B;
  border-left-width: 15px;
  padding: 4px 20px;
}
@media screen and (max-width: 749px) {
  h2 {
    font-size: 1.25rem;
    border-left-width: 10px;
    padding: 0 8px;
  }
}

h3 {
  font-size: 1.25rem;
  font-weight: bold;
  color: #107557;
  border-bottom: 1px solid #52A28B;
  padding: 4px 0 4px 17px;
  margin-left: 20px;
  margin-right: 20px;
}
@media screen and (max-width: 749px) {
  h3 {
    font-size: 1.125rem;
    padding: 4px 0 4px 8px;
    margin-left: 18px;
    margin-right: 18px;
  }
}

h4 {
  font-size: 1.25rem;
  font-weight: bold;
  color: #000;
  margin-left: 35px;
}
@media screen and (max-width: 749px) {
  h4 {
    font-size: 1rem;
    margin-left: 18px;
  }
}

.page-title {
  background-color: #107557;
  margin-bottom: 50px;
  padding-top: 17px;
  padding-bottom: 16px;
}
.page-title h1 {
  color: #fff;
  padding-left: 40px;
}
@media screen and (max-width: 749px) {
  .page-title {
    margin-bottom: 20px;
    padding-top: 11px;
    padding-bottom: 11px;
  }
  .page-title h1 {
    padding-left: 0;
    text-align: center;
  }
}

.image.is-center {
  margin-left: auto;
  margin-right: auto;
}
.image.float-left {
  margin-right: 40px;
  margin-bottom: 10px;
}
.image.float-right {
  margin-left: 40px;
  margin-bottom: 10px;
}
@media screen and (max-width: 749px) {
  .image.float-left, .image.float-right {
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 750px), print {
  .image-content {
    margin-top: 40px;
  }
}

.content {
  padding-left: 50px;
  padding-right: 50px;
  margin-bottom: 58px;
}
.content.w-630 {
  max-width: 730px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 750px), print {
  .content + .content {
    margin-top: -8px;
  }
}
@media screen and (max-width: 749px) {
  .content {
    padding-left: 0;
    padding-right: 0;
    margin-bottom: 20px;
  }
}
.content ul, .content ol {
  margin-left: 1em;
}
.content ul {
  list-style-type: disc;
}
.content ul li::marker {
  color: #52A28B;
}
.content ol {
  list-style-type: decimal;
}
.content table {
  border-spacing: 0;
  border-collapse: collapse;
}
.content table th, .content table td {
  border: 1px solid #000;
  padding: 8px 20px;
}
@media screen and (max-width: 749px) {
  .content table th, .content table td {
    padding: 5px 8px;
  }
}
.content table th {
  color: #107557;
}

.mv {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  width: 100%;
  height: 350px;
}
@media screen and (max-width: 749px) {
  .mv {
    height: 150px;
  }
}
.mv.is-home {
  height: 700px;
  margin-bottom: 50px;
}
@media screen and (max-width: 749px) {
  .mv.is-home {
    height: 250px;
    margin-bottom: 30px;
  }
}

.banner-wrapper {
  margin-top: 40px;
}
@media screen and (max-width: 749px) {
  .banner-wrapper {
    margin-top: 0;
  }
}
.banner-wrapper a {
  display: block;
  margin-bottom: 40px;
}
.banner-wrapper a img {
  width: 100%;
}
@media screen and (max-width: 749px) {
  .banner-wrapper a {
    margin-bottom: 17px;
  }
}

.toggle-list {
  font-size: 1.25rem;
  line-height: 1.75;
  font-weight: bold;
  color: #107557;
  margin-bottom: 50px;
}
.toggle-list-title {
  background-color: #52A28B;
  color: #fff;
  padding: 5px 15px 6px;
  cursor: pointer;
  position: relative;
}
.toggle-list-title:before {
  content: "";
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 12px solid #fff;
  position: absolute;
  top: 14px;
  right: 20px;
}
.toggle-list-title.is-close + * {
  display: none;
}
.toggle-list ul {
  line-height: 2.4;
  padding: 10px 20px 5px 10px;
  border: 1px solid #52A28B;
  margin: 0;
  list-style-type: disc;
}
.toggle-list ul li::marker {
  color: #52A28B;
}
@media screen and (max-width: 749px) {
  .toggle-list ul {
    display: block;
  }
}
.toggle-list ul li {
  margin-bottom: 5px;
  margin-left: 27px;
}
.toggle-list ul li a {
  text-decoration: none;
}

.header {
  position: relative;
  background-color: #fff;
  width: 100%;
  z-index: 10;
}
@media screen and (max-width: 749px) {
  .header {
    position: fixed;
    top: 0;
    left: 0;
    height: 60px;
  }
}
.header .navbar-header {
  padding: 20px 18px 20px 20px;
}
@media screen and (max-width: 749px) {
  .header .navbar-header {
    padding: 12px 64px 12px 0;
  }
}
.header .navbar-header .brand-logo {
  max-width: 53%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 749px) {
  .header .navbar-header .brand-logo {
    max-width: 100%;
  }
}
.header .navbar-header .brand-logo h1 {
  display: flex;
  align-items: center;
}
.header .navbar-header .brand-logo a {
  display: block;
}
@media screen and (max-width: 749px) {
  .header .navbar-header .brand-logo a img {
    width: 100%;
  }
}
.header .navbar-header .brand-logo .brand-logo-link {
  max-width: 86%;
}
@media screen and (max-width: 749px) {
  .header .navbar-header .brand-logo .brand-logo-link {
    max-width: 246px;
  }
}
.header .navbar-header .brand-logo .brand-logo-link.logo-nara-ni {
  max-width: 14%;
}
@media screen and (max-width: 749px) {
  .header .navbar-header .brand-logo .brand-logo-link.logo-nara-ni {
    max-width: 32px;
  }
}
.header .navbar-header .tool {
  width: 26%;
  text-align: right;
}
@media screen and (max-width: 749px) {
  .header .navbar-header .tool {
    display: none;
  }
}
.header .navbar-header .tool-size {
  display: inline-block;
  font-size: 0.8125rem;
  line-height: 2.1538461538;
  font-weight: bold;
  color: #52A28B;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 20px;
}
.header .navbar-header .tool-size p {
  margin-right: 2px;
}
.header .navbar-header .tool-size button {
  background-color: #fff;
  border: 1px solid #52A28B;
  border-radius: 50%;
  padding: 3px;
  margin-left: 8px;
}
.header .navbar-header .tool-search .form {
  font-size: 1rem;
  position: relative;
}
.header .navbar-header .tool-search .form input {
  width: 100%;
  height: 44px;
  border: 1px solid #727171;
  border-radius: 22px;
  padding: 0 38px 0 16px;
}
.header .navbar-header .tool-search .form button {
  width: 22px;
  background: none;
  border: none;
  position: absolute;
  right: 12px;
  top: 10px;
}
@media screen and (min-width: 750px), print {
  .header .navbar-header .navbar-burger {
    display: none;
  }
}
@media screen and (max-width: 749px) {
  .header .navbar-header .navbar-burger {
    display: block;
    width: 70px;
    height: 60px;
    position: absolute;
    top: 0;
    right: 0;
  }
  .header .navbar-header .navbar-burger span {
    display: block;
    width: 40px;
    height: 3px;
    background-color: #88A829;
    position: absolute;
    right: 15px;
    transition: transform 0.3s;
  }
  .header .navbar-header .navbar-burger span:nth-child(1) {
    top: 17px;
  }
  .header .navbar-header .navbar-burger span:nth-child(2) {
    top: 28px;
  }
  .header .navbar-header .navbar-burger span:nth-child(3) {
    top: 39px;
  }
  .header .navbar-header .navbar-burger.is-active span:nth-child(1), .header .navbar-header .navbar-burger.is-active span:nth-child(3) {
    top: 28px;
    left: 15px;
  }
  .header .navbar-header .navbar-burger.is-active span:nth-child(1) {
    transform: rotate(-45deg);
  }
  .header .navbar-header .navbar-burger.is-active span:nth-child(2) {
    opacity: 0;
  }
  .header .navbar-header .navbar-burger.is-active span:nth-child(3) {
    transform: rotate(45deg);
  }
}
.header .navbar-menu {
  background-color: #84B470;
}
@media screen and (max-width: 749px) {
  .header .navbar-menu {
    display: none;
  }
  .header .navbar-menu.is-active {
    display: block;
  }
}
.header .navbar-menu .container {
  padding: 0;
}
.header .navbar-menu .gnav-list li {
  display: inline-block;
  width: 16.6666666667%;
  text-align: center;
  vertical-align: top;
  position: relative;
}
.header .navbar-menu .gnav-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 1px;
  height: 40px;
  background-color: #fff;
}
@media screen and (max-width: 749px) {
  .header .navbar-menu .gnav-list li::before {
    display: none;
  }
}
.header .navbar-menu .gnav-list li:last-child::after {
  content: "";
  position: absolute;
  right: 0;
  top: 10px;
  width: 1px;
  height: 40px;
  background-color: #fff;
}
@media screen and (max-width: 749px) {
  .header .navbar-menu .gnav-list li:last-child::after {
    display: none;
  }
}
@media screen and (max-width: 749px) {
  .header .navbar-menu .gnav-list li:last-child {
    border-bottom: none;
  }
}
@media screen and (max-width: 749px) {
  .header .navbar-menu .gnav-list li {
    width: 100%;
    border-bottom: 1px solid #fff;
  }
}
.header .navbar-menu .gnav-list li a {
  display: block;
  width: 100%;
  font-weight: bold;
  color: #fff;
  padding: 14px 2px;
  text-decoration: none;
}
.header .navbar-menu .gnav-list li a.is-active, .header .navbar-menu .gnav-list li a:hover {
  background-color: #E4E24F;
  color: #107557;
}

.footer {
  font-size: 1.125rem;
  line-height: 1.7777777778;
  background-color: #BADCC8;
  padding: 50px 0 10px;
  margin-top: 100px;
}
@media screen and (max-width: 749px) {
  .footer {
    padding-top: 30px;
  }
}
.footer #page-to-top {
  position: fixed;
  right: 50px;
  bottom: 50px;
  width: 50px;
  cursor: pointer;
}
@media screen and (max-width: 749px) {
  .footer #page-to-top {
    display: none;
  }
}
@media screen and (max-width: 749px) {
  .footer-inner {
    display: flex;
    flex-direction: column-reverse;
  }
}
.footer-content, .footer-link {
  display: inline-block;
  width: 50%;
}
@media screen and (max-width: 749px) {
  .footer-content, .footer-link {
    width: 100%;
  }
}
.footer-content {
  padding-right: 68px;
  border-right: 1px solid #B0B0B1;
}
@media screen and (max-width: 749px) {
  .footer-content {
    padding-right: 0;
    border-right: none;
  }
}
.footer-content .footer-logo {
  width: 100%;
  max-width: 312px;
  margin-bottom: 20px;
}
.footer-content h5 {
  font-size: 1.25rem;
  line-height: 1.75;
  font-weight: bold;
  margin-bottom: 20px;
}
@media screen and (max-width: 749px) {
  .footer-content p {
    font-size: 0.9375rem;
    line-height: 1.4666666667;
  }
}
.footer-content p span {
  display: block;
  font-size: 0.75rem;
  line-height: 1.75;
}
@media screen and (max-width: 749px) {
  .footer-content p span {
    line-height: 1.5;
    margin-top: 14px;
  }
}
.footer-link {
  padding-left: 93px;
}
@media screen and (max-width: 749px) {
  .footer-link {
    padding-left: 0;
    padding: 0 18px;
  }
}
.footer-link-text {
  margin-bottom: 38px;
}
@media screen and (max-width: 749px) {
  .footer-link-text {
    margin-bottom: 28px;
  }
}
.footer-link-text-inner {
  display: inline-block;
  width: 150px;
  vertical-align: top;
}
@media screen and (max-width: 749px) {
  .footer-link-text-inner {
    width: 100%;
  }
}
.footer-link-text-inner:first-child {
  width: 200px;
}
@media screen and (max-width: 749px) {
  .footer-link-text-inner:first-child {
    width: 100%;
  }
}
.footer-link-text-inner:last-child p {
  margin-bottom: 0;
}
.footer-link-text-inner p {
  margin-bottom: 20px;
}
.footer-link-text-inner p a {
  font-size: 1.125rem;
  line-height: 1.5555555556;
  font-weight: bold;
  color: #107557;
  text-decoration: none;
}
.footer-link-banner a {
  display: inline-block;
  margin-right: 38px;
  margin-bottom: 20px;
}
@media screen and (max-width: 749px) {
  .footer-link-banner a {
    margin-right: 0;
  }
}
.footer-link-banner a:last-child {
  margin-right: 0;
}
@media screen and (max-width: 749px) {
  .footer-link-banner a:last-child {
    margin-bottom: 60px;
  }
}
.footer-link-banner a img {
  max-width: 200px;
}
@media screen and (max-width: 749px) {
  .footer-link-banner a img {
    max-width: 100%;
  }
}
.footer small {
  display: block;
  width: 100%;
  color: #52A28B;
  text-align: center;
  margin-top: 30px;
}
@media screen and (max-width: 749px) {
  .footer small {
    font-size: 0.75rem;
    line-height: 1.5;
  }
}

.lead {
  text-align: center;
  margin-bottom: 60px;
}
@media screen and (max-width: 749px) {
  .lead {
    text-align: left;
    margin-bottom: 46px;
    line-height: 1.75;
  }
}

.news {
  padding: 0 30px;
  border-bottom: 2px solid #107557;
  margin-bottom: 117px;
  height: 450px;
  overflow-y: scroll;
}
@media screen and (max-width: 749px) {
  .news {
    padding: 0;
    margin-bottom: 100px;
  }
}
.news li {
  display: flex;
  line-height: 1.8888888889;
  border-bottom: 1px solid #E0E0E0;
  padding: 20px 6px 20px 0;
}
@media screen and (max-width: 749px) {
  .news li {
    flex-direction: column;
    line-height: 1.4666666667;
    padding: 30px 0 15px;
    min-height: 105px;
  }
}
@media screen and (max-width: 749px) {
  .news li:first-child {
    padding-top: 5px;
  }
}
.news li:last-child {
  border-bottom: none;
}
.news li span {
  display: inline-block;
  font-weight: bold;
  color: #107557;
  min-width: 265px;
}
@media screen and (max-width: 749px) {
  .news li span {
    width: 100%;
    margin-bottom: 8px;
  }
}
.news li a {
  color: #000;
  text-decoration: none;
}
@media screen and (max-width: 749px) {
  .news li a {
    width: 100%;
  }
}

.embedding {
  width: 100%;
  border: none;
}
.embedding.news-iframe {
  margin-bottom: 117px;
}
