body { padding-top: 60px; }

body.top { padding-top: 0; }

.header { position: fixed; z-index: 99; left: 0; top: 0; width: 100%; padding: 8px; }
.header.active { background: #fff; transition-duration: 0.4s; }
.header.white { background: #fff; }
.header .container { max-width: 1600px; margin: 0 auto; display: flex; justify-content: space-between; }
.header b { width: 200px; padding: 8px; }

.hum { width: 30px; padding-top: 8px; }
.hum a { display: block; height: 21px; position: relative; }
.hum i { display: block; background: #016740; height: 3px; border-radius: 2px; width: 100%; position: absolute; left: 0; transition-duration: 0.3s; }
.hum i:nth-child(1) { top: 0; }
.hum i:nth-child(2) { top: calc(50% - 1.5px); }
.hum i:nth-child(3) { bottom: 0; }

.header-menu-active .hum i { bottom: auto; top: calc(50% - 1.5px); }
.header-menu-active .hum i:nth-child(1) { transform: rotate(45deg); }
.header-menu-active .hum i:nth-child(2) { opacity: 0; }
.header-menu-active .hum i:nth-child(3) { transform: rotate(-45deg); }

.menu { position: fixed; left: 0; top: 60px; width: 100%; height: calc(100% - 60px); background: #016740; z-index: 9999; transform: translateY(-150%); transition-duration: 0.4s; transition-timing-function: ease-in-out; }
.menu ul { padding: 2rem; }
.menu ul li { list-style: none; }
.menu ul li a { display: block; padding: 2rem; transition-duration: 0.4s; }
.menu ul li img { height: 3rem; }
.menu ul li a:hover { transform: translateX(8px); }

.header-menu-active .menu { transform: translateY(0); }

.main__fv { min-height: 80vh; }

.sequence__title { transform: translate(-50%, -49%); }

.hannan__top { padding-top: 0; }

.hannan__top__title { line-height: 2; }
.hannan__top__title p { font-size: min(4.4vw, 18px); }

.hannan__top__content { justify-content: space-between; }

.hannan__top__content__left { flex: 0 0 46%; }

.circle { position: relative; background: url("../images/c-bg.png") no-repeat center; background-size: 90%; }
.circle p { opacity: 0; }
.circle li { position: absolute; list-style: none; margin: 0; padding: 0; opacity: 0; width: 50%; transition-duration: 0.5s; }
.circle li.circle_1 { width: 53%; left: 34%; top: 1%; }
.circle li.circle_2 { width: 34%; left: 66%; top: 44%; }
.circle li.circle_3 { width: 45%; left: 17%; top: 64%; }
.circle li.circle_4 { width: 36%; left: 0%; top: 21%; }
.circle li.circle-copy { top: 52%; left: 52%; transform: translate(-50%, -50%); width: 32%; }
.circle.inView li { transition-duration: 2.5s; opacity: 1; }
.circle.inView li.circle_1 { transition-delay: 0.5s; }
.circle.inView li.circle_2 { transition-delay: 1.2s; }
.circle.inView li.circle_3 { transition-delay: 1.9s; }
.circle.inView li.circle_4 { transition-delay: 2.6s; }

.hannan__top__content__right { padding: 30px 25px 25px; flex: 0 0 48%; margin-left: 0; transform: translateX(20px); display: flex; align-items: center; opacity: 0; transition-duration: 2.0s; }
.hannan__top__content__right::before { z-index: -1; height: 100%; background-repeat: no-repeat; background-size: contain; top: 0; }
.hannan__top__content__right h3 { line-height: 0; }
.hannan__top__content__right h3 img { height: 1.3rem; }
.hannan__top__content__right p { font-size: 11px; margin-top: 5px; }
.hannan__top__content__right li { opacity: 0; transition-duration: 0.5s; }
.hannan__top__content__right.inView { opacity: 1; }
.hannan__top__content__right.inView li { opacity: 1; transition-delay: 0.5s; transition-duration: 2.5s; }
.hannan__top__content__right.inView li:nth-child(2) { transition-delay: 1.2s; }
.hannan__top__content__right.inView li:nth-child(3) { transition-delay: 1.9s; }
.hannan__top__content__right.inView li:nth-child(4) { transition-delay: 2.6s; }

body.fixed { overflow: hidden; }

.button img { transition-duration: 0.4s; }
.button:hover img { transform: translateX(8px); }

.hannan__vision .accordion { margin: 100px auto 0; }
.hannan__vision .accordion.active { margin: 0 auto; }

.hannan__vision .accordion__content__left__cake { margin: 0 auto; opacity: 0; }

.hannan__vision .accordion__content__right { opacity: 1; }
.hannan__vision .accordion__content__right__row { opacity: 0; }

.hannan__vision__accordion::after { content: ""; display: block; transform: scale(0); transform-origin: center 100px; aspect-ratio: 1 / 1; z-index: 1; position: absolute; left: 0; top: 0; bottom: auto; width: 100%; background: linear-gradient(180deg, #06b7ce 0%, #006e4f 100%); border-radius: 50%; transition-duration: 1.0s; transition-timing-function: ease-in-out; }
.hannan__vision__accordion dd { z-index: 3; position: relative; }

.hannan__vision__container.active { position: fixed; z-index: 999; width: 100vw; height: 100vh; left: 0; top: 0; background: #fff; overflow-y: auto; }
.hannan__vision__container.active .hannan__vision__accordion { width: 100%; margin: auto; position: relative; overflow: hidden; }
.hannan__vision__container.active .hannan__vision__accordion::after { transform: scale(1.1); }
.hannan__vision__container.active .accordion__content__right__row { opacity: 1; transition-duration: 2.0s; }
.hannan__vision__container.active .accordion__content__right__row-1 { transition-delay: 0.3s; }
.hannan__vision__container.active .accordion__content__right__row-2 { transition-delay: 0.5s; }
.hannan__vision__container.active .accordion__content__right__row-3 { transition-delay: 0.7s; }
.hannan__vision__container.active .accordion__content__right__row-4 { transition-delay: 0.9s; }
.hannan__vision__container.active .accordion__content__right__row-5 { transition-delay: 1.2s; }
.hannan__vision__container.active .accordion__content__left__cake { opacity: 1; transition-duration: 2.0s; }
.hannan__vision__container.active .accordion__content__left__cake.cl-1 { transition-delay: 0.3s; }
.hannan__vision__container.active .accordion__content__left__cake.cl-2 { transition-delay: 0.5s; }
.hannan__vision__container.active .accordion__content__left__cake.cl-3 { transition-delay: 0.7s; }
.hannan__vision__container.active .accordion__content__left__cake.cl-4 { transition-delay: 0.9s; }

.accordion-close { text-align: center; }
.accordion-close a { position: relative; color: #fff; font-size: 12px; cursor: pointer; }
.accordion-close a::after { content: ""; position: absolute; background: #fff; left: 50%; top: 0; transform: translate(-50%, -110%); width: 20px; height: 12px; clip-path: polygon(0 100%, 100% 100%, 50% 0); }

.hannan__history { padding-bottom: 100px; line-height: 2; }
.hannan__history h2 img { height: 36px; }

.hannan__challenge { line-height: 2; }
.hannan__challenge h2 img { height: 36px; }

.hannan__footer { background: url("../images/bg-footer-top.png") no-repeat center top; background-size: 100vw; padding: 20vw 0 0; font-weight: 400; position: relative; overflow: hidden; }
.hannan__footer::after { content: ""; position: absolute; width: 110%; height: 100%; top: 20vw; left: -5%; background: #016740; border-radius: 50%/20% 20% 0% 0%; z-index: 1; }
.hannan__footer .hannan__footer__container { position: relative; z-index: 10; padding: 8vw 0 0; max-width: 92%; margin: 0 auto; }
.hannan__footer h2 { width: 300px; max-width: 80%; margin: 0 auto 2rem; }

.footer_lower { background-image: url("../images/bg-footer-low.png"); }

.hannan__footer__button { justify-content: center; gap: 1rem; }
.hannan__footer__button a { flex: 0 0 300px; display: block; }

.hannan__credit { text-align: center; max-width: 92%; margin: 0 auto; padding: 2rem 0; font-weight: 400; font-size: 11px; color: #fff; }

.hannan__credit__button { justify-content: center; padding: 1rem 0; }
.hannan__credit__button a { color: #fff; }

.lower_body .container { width: 980px; max-width: 92%; margin: 0 auto; }
.lower_body .flex { justify-content: space-between; }
.lower_body .copy { flex: 0 0 32%; line-height: 1.5; padding-top: 4px; }
.lower_body .txt { flex: 0 0 60%; line-height: 2; }
.lower_body .txt p { font-size: 0.9em; padding-bottom: 1em; }
.lower_body h3 { padding-top: 2rem; }
.lower_body .col-6 { flex: 0 0 70%; }
.lower_body .col-4 { flex: 30%; text-align: right; margin-left: auto; }
.lower_body .col-4 figure { text-align: center; line-height: 1.4; }
.lower_body .col-4 img { width: 150px; }
.lower_body figcaption { font-size: 13px; }

.alignend { align-items: flex-end; }

.ti05 { text-indent: -0.5em; padding-left: 0.5em; }

.page_navi { padding-top: 3rem; text-align: right; }
.page_navi img { height: 1.5rem; }
.page_navi a { transition-duration: 0.3s; display: inline-block; }
.page_navi a:hover { transform: translateX(8px); }

x.page_navi { padding-top: 3rem; text-align: right; }
x.page_navi a { color: #016740; display: inline-block; position: relative; text-decoration: none; padding-right: 2rem; transition-duration: 0.3s; }
x.page_navi a::after { content: ""; position: absolute; width: 100%; height: 100%; left: 0; bottom: 0; background: url("../images/arw-right.svg") no-repeat right bottom; background-size: 100%; }
x.page_navi a:hover { transform: translateX(1rem); }
x.page_navi em { font-style: normal; }

.back { padding-top: 3rem; }
.back a { transition-duration: 0.2s; display: inline-block; }
.back a:hover { transform: translateX(-8px); }

.sp { display: none; }

@media (max-width: 768px) { .pc { display: none; }
  .sp { display: inline; }
  .menu ul li a { padding: 1rem 0; }
  .menu ul li img { height: 10vw; max-height: 3rem; }
  .main__fv { overflow: hidden; }
  .sequence__title, .sequence__bubble, .sequence__photo { transform: translate(-50%, -64%); }
  .hannan__top__container { max-width: 92%; }
  .hannan__top__content { display: block; }
  .hannan__top__content__left { margin: 0 auto; }
  .hannan__top__content__right { background: url("../images/top-content-border-sp.svg") no-repeat center top/contain; max-width: 100%; margin: 0 auto; padding: 4rem 2rem 2rem; transform: translateX(0); justify-content: center; }
  .hannan__top__content__right::before { content: none; width: 100%; height: 100%; position: absolute; max-width: 100%; }
  .hannan__top__content__right li { justify-content: space-between; max-width: 320px; margin: 0 auto; }
  .hannan__top__content__right__text { flex: 0 0 72%; }
  .hannan__top__content__right__text h3 { font-size: 16px; }
  .hannan__top__content__right__text p { margin: 0; }
  .hannan__top__content__right__image { flex: 0 0 20%; margin: 0; padding-top: 8px; }
  .hannan__vision { background-size: 100vw; }
  .hannan__vision .accordion { margin: 16vw auto 20vw; }
  .hannan__vision .accordion-open h2 { text-align: center; line-height: 2; }
  .hannan__vision .accordion__content { display: block; }
  .hannan__vision .accordion__content__left { max-width: 92%; margin: 0 auto 2rem; }
  .hannan__vision .accordion__content__right { max-width: 92%; margin: 0 auto; padding: 2rem 0; border-top: 2px dashed #fff; text-align: center; line-height: 2; }
  .hannan__vision__container.active { overflow-y: scroll; }
  .hannan__vision__container.active .hannan__vision__accordion::after { transform: scale(8); }
  .hannan__history__content { max-width: 92%; margin: 0 auto; }
  .hannan__history__content .button { margin: 0 auto; display: block; text-align: center; }
  .hannan__challenge__content { flex-direction: column; max-width: 92%; margin: 0 auto; gap: 1rem; padding-bottom: 2rem; }
  .hannan__challenge__content__left { display: contents; }
  .hannan__challenge__content__left p { line-height: 2; margin-bottom: 0; }
  .hannan__challenge__content__left .button { width: 300px; margin: 0 auto; display: block; text-align: center; order: 6; }
  .hannan__challenge__content__right { order: 5; margin: 0 auto 2rem; }
  .hannan__footer { background-image: url("../images/bg-footer-low.png"); }
  .hannan__footer .hannan__footer__container { padding-top: 16vw; }
  .hannan__footer::after { border-radius: 50%/16vw 16vw 0% 0%; }
  .footer_lower { background-image: url("../images/bg-footer-top.png"); }
  .lower_body { padding-bottom: 8vw; }
  .lower_body .flex { display: block; }
  .lower_body .copy { padding-bottom: 2rem; }
  .lower_body .col-4 { padding-top: 2rem; }
  .lower_body .col-4 figure { display: inline-block; }
  .back { text-align: center; } }

/*# sourceMappingURL=custom.css.map */
