@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&display=swap");
:root {
  --sp5: clamp(4px, 3.545px + 0.121vw, 5px);
  --sp10: clamp(8px, 7.091px + 0.242vw, 10px);
  --sp15: clamp(12px, 10.636px + 0.364vw, 15px);
  --sp20: clamp(16px, 14.182px + 0.485vw, 20px);
  --sp25: clamp(20px, 17.727px + 0.606vw, 25px);
  --sp30: clamp(24px, 21.273px + 0.727vw, 30px);
  --sp35: clamp(28px, 24.818px + 0.848vw, 35px);
  --sp40: clamp(28px, 24.818px + 0.848vw, 35px);
  --sp45: clamp(36px, 31.909px + 1.091vw, 45px);
  --sp50: clamp(40px, 35.455px + 1.212vw, 50px);
  --sp60: clamp(48px, 42.545px + 1.455vw, 60px);
  --sp70: clamp(56px, 49.636px + 1.697vw, 70px);
  --sp80: clamp(64px, 56.727px + 1.939vw, 80px);
  --sp90: clamp(72px, 63.818px + 2.182vw, 90px);
  --sp100: clamp(80px, 70.909px + 2.424vw, 100px);
  --sp110: clamp(88px, 78px + 2.667vw, 110px);
  --sp120: clamp(96px, 85.091px + 2.909vw, 120px);
  --sp130: clamp(104px, 92.182px + 3.152vw, 130px);
  --sp140: clamp(112px, 99.273px + 3.394vw, 140px);
  --sp150: clamp(120px, 106.364px + 3.636vw, 150px);
  --sp160: clamp(128px, 113.455px + 3.879vw, 160px);
  --sp170: clamp(136px, 120.545px + 4.121vw, 170px);
  --sp180: clamp(144px, 127.636px + 4.364vw, 180px);
  --sp190: clamp(152px, 134.727px + 4.606vw, 190px);
  --sp200: clamp(160px, 141.818px + 4.848vw, 200px);
  --fz10: calc(10 / 16 * 1rem);
  --fz11: calc(11 / 16 * 1rem);
  --fz12: calc(12 / 16 * 1rem);
  --fz13: calc(13 / 16 * 1rem);
  --fz14: calc(14 / 16 * 1rem);
  --fz15: calc(15 / 16 * 1rem);
  --fz16: calc(16 / 16 * 1rem);
  --fz17: calc(17 / 16 * 1rem);
  --fz18: calc(18 / 16 * 1rem);
  --fz19: calc(19 / 16 * 1rem);
  --fz20: calc(20 / 16 * 1rem);
  --fz21: calc(21 / 16 * 1rem);
  --fz22: calc(22 / 16 * 1rem);
  --fz23: calc(23 / 16 * 1rem);
  --fz24: calc(24 / 16 * 1rem);
  --fz25: calc(25 / 16 * 1rem);
  --fz26: calc(26 / 16 * 1rem);
  --fz27: calc(27 / 16 * 1rem);
  --fz28: calc(28 / 16 * 1rem);
  --fz29: calc(29 / 16 * 1rem);
  --fz30: calc(30 / 16 * 1rem);
  --fz31: calc(31 / 16 * 1rem);
  --fz32: calc(32 / 16 * 1rem);
  --fz33: calc(33 / 16 * 1rem);
  --fz34: calc(34 / 16 * 1rem);
  --fz35: calc(35 / 16 * 1rem);
  --fz36: calc(36 / 16 * 1rem);
  --fz37: calc(37 / 16 * 1rem);
  --fz38: calc(38 / 16 * 1rem);
  --fz39: calc(39 / 16 * 1rem);
  --fz40: calc(40 / 16 * 1rem);
  --fz41: calc(41 / 16 * 1rem);
  --fz42: calc(42 / 16 * 1rem);
  --fz43: calc(43 / 16 * 1rem);
  --fz44: calc(44 / 16 * 1rem);
  --fz45: calc(45 / 16 * 1rem);
  --fz46: calc(46 / 16 * 1rem);
  --fz47: calc(47 / 16 * 1rem);
  --fz48: calc(48 / 16 * 1rem);
  --fz49: calc(49 / 16 * 1rem);
  --fz50: calc(50 / 16 * 1rem);
  --fzv10: clamp(0.563rem, 0.534rem + 0.12vw, 0.625rem);
  --fzv11: clamp(0.619rem, 0.588rem + 0.13vw, 0.688rem);
  --fzv12: clamp(0.675rem, 0.641rem + 0.15vw, 0.75rem);
  --fzv13: clamp(0.731rem, 0.694rem + 0.16vw, 0.813rem);
  --fzv14: clamp(0.787rem, 0.748rem + 0.17vw, 0.875rem);
  --fzv15: clamp(0.85rem, 0.81rem + 0.17vw, 0.938rem);
  --fzv16: clamp(0.9rem, 0.855rem + 0.19vw, 1rem);
  --fzv17: clamp(0.956rem, 0.908rem + 0.21vw, 1.063rem);
  --fzv18: clamp(1.012rem, 0.961rem + 0.22vw, 1.125rem);
  --fzv19: clamp(1.069rem, 1.015rem + 0.23vw, 1.188rem);
  --fzv20: clamp(1.125rem, 1.068rem + 0.24vw, 1.25rem);
  --fzv21: clamp(1.181rem, 1.122rem + 0.25vw, 1.313rem);
  --fzv22: clamp(1.238rem, 1.175rem + 0.27vw, 1.375rem);
  --fzv23: clamp(1.294rem, 1.228rem + 0.28vw, 1.438rem);
  --fzv24: clamp(1.35rem, 1.282rem + 0.29vw, 1.5rem);
  --fzv25: clamp(1.406rem, 1.335rem + 0.3vw, 1.563rem);
  --fzv26: clamp(1.462rem, 1.389rem + 0.32vw, 1.625rem);
  --fzv27: clamp(1.519rem, 1.442rem + 0.33vw, 1.688rem);
  --fzv28: clamp(1.575rem, 1.495rem + 0.34vw, 1.75rem);
  --fzv29: clamp(1.631rem, 1.549rem + 0.35vw, 1.813rem);
  --fzv30: clamp(1.688rem, 1.602rem + 0.36vw, 1.875rem);
  --fzv31: clamp(1.744rem, 1.656rem + 0.38vw, 1.938rem);
  --fzv32: clamp(1.8rem, 1.709rem + 0.39vw, 2rem);
  --fzv33: clamp(1.856rem, 1.762rem + 0.4vw, 2.063rem);
  --fzv34: clamp(1.913rem, 1.816rem + 0.41vw, 2.125rem);
  --fzv35: clamp(1.969rem, 1.869rem + 0.42vw, 2.188rem);
  --fzv36: clamp(2.025rem, 1.923rem + 0.44vw, 2.25rem);
  --fzv37: clamp(2.081rem, 1.976rem + 0.45vw, 2.313rem);
  --fzv38: clamp(2.138rem, 2.03rem + 0.46vw, 2.375rem);
  --fzv39: clamp(2.194rem, 2.083rem + 0.47vw, 2.438rem);
  --fzv40: clamp(2.25rem, 2.136rem + 0.48vw, 2.5rem);
  --fzv41: clamp(2.306rem, 2.19rem + 0.5vw, 2.563rem);
  --fzv42: clamp(2.362rem, 2.243rem + 0.51vw, 2.625rem);
  --fzv43: clamp(2.419rem, 2.297rem + 0.52vw, 2.688rem);
  --fzv44: clamp(2.475rem, 2.35rem + 0.53vw, 2.75rem);
  --fzv45: clamp(2.531rem, 2.403rem + 0.55vw, 2.813rem);
  --fzv46: clamp(2.587rem, 2.457rem + 0.56vw, 2.875rem);
  --fzv47: clamp(2.644rem, 2.51rem + 0.57vw, 2.938rem);
  --fzv48: clamp(2.7rem, 2.564rem + 0.58vw, 3rem);
  --fzv49: clamp(2.756rem, 2.617rem + 0.59vw, 3.063rem);
  --fzv50: clamp(2.813rem, 2.67rem + 0.61vw, 3.125rem);
  --ayumi-green1: #44b13f;
  --ayumi-green2: #18ad4a;
  --ayumi-green3: #a9cb03;
  --ayumi-blue: #0e63c4;
}

html {
  height: 100%;
  width: 100%;
  scroll-behavior: auto;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  text-size-adjust: 100%;
}

body {
  position: relative;
  min-height: 100dvh;
  width: 100%;
  font-family: "Noto Sans JP", -apple-system, "BlinkMacSystemFont", HiraginoSans, "Hiragino Sans", "NotoSansJP", "Noto Sans CJK JP", NotoSansCJKjp-Light, "Noto Sans CJK JP Light", "游ゴシック", "Yu Gothic", "Meiryo", monospace, sans-serif;
  letter-spacing: 0.05em;
  line-height: 1.6;
  word-wrap: break-word;
  color: #4d4d4f;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
}
body.open {
  height: 100vh;
  overflow-y: hidden;
}

.wrap {
  overflow: hidden;
}

img {
  width: 100%;
  height: auto;
}

svg {
  width: 100%;
  height: auto;
  line-height: 1;
  fill: currentColor;
}
svg use {
  width: 100%;
  height: 100%;
}

.text_government {
  aspect-ratio: 425.7/91.2;
}

.text_company {
  aspect-ratio: 344.56/91.188;
}

.text_me {
  aspect-ratio: 174.2/91.2;
}

.for_government_sp {
  aspect-ratio: 568/254.6;
}

.for_company_sp {
  aspect-ratio: 429.13/254.6;
}

.for_me_sp {
  aspect-ratio: 300.8/124.7;
}

a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  cursor: pointer;
}
a.hov {
  display: block;
  opacity: 1;
  transition: opacity 0.3s cubic-bezier(0.2, 0, 0.1, 1);
}
a.hov:hover {
  opacity: 0.7;
}

*:focus {
  outline: none;
}

[class*=line-break] {
  display: inline-block;
}

.notes {
  font-size: var(--fzv14);
}

.indent1em {
  padding-left: 1em;
  text-indent: -1em;
}

.btn-style1 {
  margin: 0 auto;
  text-align: center;
}
.btn-style1 a {
  display: inline-block;
  position: relative;
  padding: 0 2em;
  border: solid 3px black;
  border-radius: 1.6em;
  font-size: var(--fzv20);
  line-height: 1;
  background-color: white;
  transition: all 0.3s cubic-bezier(0.2, 0, 0.1, 1);
  touch-action: manipulation;
  user-select: none;
}
.btn-style1 a span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3em;
}
.btn-style1 a::after {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1em;
  margin: auto;
  width: 0.5em;
  height: 0.5em;
  border-top: 2px solid black;
  border-right: 2px solid black;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: all 0.3s cubic-bezier(0.2, 0, 0.1, 1);
}
.btn-style1 a:hover {
  background-color: black;
  color: white !important;
}
.btn-style1 a:hover::after {
  border-top-color: white !important;
  border-right-color: white !important;
  right: 0.75em;
}
#page_government .btn-style1 a {
  border-color: #78bd36;
  color: #78bd36;
}
#page_government .btn-style1 a::after {
  border-color: #78bd36;
}
#page_government .btn-style1 a:hover {
  background-color: #78bd36;
}

#page_company .btn-style1 a {
  border-color: #44b13f;
  color: #44b13f;
}
#page_company .btn-style1 a::after {
  border-color: #44b13f;
}
#page_company .btn-style1 a:hover {
  background-color: #44b13f;
}

#page_me .btn-style1 a {
  border-color: #a9cb03;
  color: #a9cb03;
}
#page_me .btn-style1 a::after {
  border-color: #a9cb03;
}
#page_me .btn-style1 a:hover {
  background-color: #a9cb03;
}

.btn-style2 {
  margin: 0 auto;
  width: 100%;
}
.btn-style2 a {
  display: block;
  position: relative;
  border-radius: 1.6em;
  font-size: var(--fzv20);
  line-height: 1;
  color: white;
  background-color: rgba(0, 0, 0, 0.6);
  transition: all 0.3s cubic-bezier(0.2, 0, 0.1, 1);
  touch-action: manipulation;
  user-select: none;
}
.btn-style2 a span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3em;
}
.btn-style2 a::after {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1em;
  margin: auto;
  width: 0.5em;
  height: 0.5em;
  border-bottom: 2px solid white;
  border-right: 2px solid white;
  transform: rotate(45deg) translate3d(-2px, -2px, 0);
  transition: all 0.3s cubic-bezier(0.2, 0, 0.1, 1);
}
.btn-style2 a:hover {
  background-color: black;
}
.btn-style2 a:hover::after {
  transform: rotate(45deg) translate3d(1px, 1px, 0);
}
#page_government .btn-style2 a {
  background-color: rgba(120, 189, 54, 0.6);
}
#page_government .btn-style2 a:hover {
  background-color: #78bd36;
}

#page_company .btn-style2 a {
  background-color: rgba(68, 177, 63, 0.6);
}
#page_company .btn-style2 a:hover {
  background-color: #44b13f;
}

#page_me .btn-style2 a {
  background-color: rgba(169, 203, 3, 0.6);
}
#page_me .btn-style2 a:hover {
  background-color: #a9cb03;
}

.btn-style3 a::after {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1em;
  margin: auto;
  width: 0.5em;
  height: 0.5em;
  border-top: 2px solid black;
  border-right: 2px solid black;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: all 0.3s cubic-bezier(0.2, 0, 0.1, 1);
}
.btn-style3 a:hover {
  background-color: black;
  color: white !important;
}
.btn-style3 a:hover::after {
  border-top-color: white !important;
  border-right-color: white !important;
  right: 0.75em;
}

.btn-style4 {
  margin: 0 auto;
  text-align: center;
  width: 100%;
}
.btn-style4 a {
  display: inline-block;
  position: relative;
  padding: 0 2em;
  border: solid 3px black;
  border-radius: 1.6em;
  width: 100%;
  font-size: var(--fzv20);
  line-height: 1;
  color: white;
  background-color: black;
  transition: all 0.3s cubic-bezier(0.2, 0, 0.1, 1);
  touch-action: manipulation;
  user-select: none;
}
.btn-style4 a span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3em;
}
.btn-style4 a::after {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 1em;
  margin: auto;
  width: 0.5em;
  height: 0.5em;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: all 0.3s cubic-bezier(0.2, 0, 0.1, 1);
}
.btn-style4 a:hover {
  background-color: white;
  color: black;
}
.btn-style4 a:hover::after {
  right: 0.75em;
}

#topcontrol {
  z-index: 100;
  position: fixed;
  bottom: 3%;
  right: 3%;
  width: 60px;
  height: 60px;
  opacity: 0;
  transition: opacity 0.2s ease-out;
}
#topcontrol a {
  position: relative;
  display: block;
  border-radius: 10px;
  height: 100%;
  width: 100%;
  font-size: 0;
  text-decoration: none;
  background-color: rgba(0, 0, 0, 0.3);
  transition: background-color 0.3s ease-out;
  touch-action: manipulation;
  user-select: none;
}
#topcontrol a::after {
  display: block;
  content: "";
  position: absolute;
  margin: 40% auto auto auto;
  inset: 0;
  width: 30%;
  height: 30%;
  border-radius: 3px;
  border-top: 4px solid white;
  border-left: 4px solid white;
  transform: rotate(45deg);
}
#topcontrol a:hover {
  background-color: rgba(0, 0, 0, 0.6);
}
#topcontrol.view {
  opacity: 1;
}
#topcontrol.view a {
  pointer-events: all;
}

.anim_slide_up {
  opacity: 0;
}
.anim_slide_up.show {
  animation-name: anim_slide_up;
  animation-duration: 0.75s;
  animation-timing-function: cubic-bezier(0.2, 0, 0.1, 1);
  animation-fill-mode: forwards;
}

@keyframes anim_slide_up {
  from {
    transform: translate3d(0, 50px, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.anim_slide_down {
  opacity: 0;
}
.anim_slide_down.show {
  animation-name: anim_slide_down;
  animation-duration: 0.75s;
  animation-timing-function: cubic-bezier(0.2, 0, 0.1, 1);
  animation-fill-mode: forwards;
}

@keyframes anim_slide_down {
  from {
    transform: translate3d(0, -50px, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.anim_slide_right {
  opacity: 0;
}
.anim_slide_right.show {
  animation-name: anim_slide_right;
  animation-duration: 0.75s;
  animation-timing-function: cubic-bezier(0.2, 0, 0.1, 1);
  animation-fill-mode: forwards;
}

@keyframes anim_slide_right {
  from {
    transform: translate3d(50px, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.anim_slide_left {
  opacity: 0;
}
.anim_slide_left.show {
  animation-name: anim_slide_left;
  animation-duration: 0.75s;
  animation-timing-function: cubic-bezier(0.2, 0, 0.1, 1);
  animation-fill-mode: forwards;
}

@keyframes anim_slide_left {
  from {
    transform: translate3d(-50px, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.anim_fadein {
  opacity: 0;
}
.anim_fadein.show {
  animation-name: anim_fadein;
  animation-duration: 0.75s;
  animation-timing-function: cubic-bezier(0.2, 0, 0.1, 1);
  animation-fill-mode: forwards;
}

@keyframes anim_fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.anim_delay_05s {
  animation-delay: 0.5s !important;
}

.anim_delay_1s {
  animation-delay: 1s !important;
}

.anim_delay_15s {
  animation-delay: 1.5s !important;
}

.anim_delay_2s {
  animation-delay: 2s !important;
}

.anim_delay_3s {
  animation-delay: 3s !important;
}

.anim_delay_4s {
  animation-delay: 4s !important;
}

.anim_delay_5s {
  animation-delay: 5s !important;
}

.anim_duration_15s {
  animation-duration: 1.5s !important;
}

.anim_duration_2s {
  animation-duration: 2s !important;
}

.anim_duration_3s {
  animation-duration: 3s !important;
}

.anim_duration_4s {
  animation-duration: 4s !important;
}

.anim_duration_5s {
  animation-duration: 5s !important;
}

.nav-button-wrap {
  display: block;
  position: relative;
  z-index: 1000;
  padding: 15px;
  line-height: 0;
  cursor: pointer;
  transition: all 0.5s ease;
}
@media print, screen and (min-width: 768px) {
  .nav-button-wrap {
    display: none;
  }
}
.nav-button-wrap .nav-button,
.nav-button-wrap .nav-button span {
  display: inline-block;
  transition: all 0.3s;
}
.nav-button-wrap .nav-button {
  z-index: 20;
  width: 30px;
  height: 21px;
  position: relative;
}
.nav-button-wrap .nav-button span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: black;
}
.nav-button-wrap .nav-button span:nth-of-type(1) {
  top: 0;
}
.nav-button-wrap .nav-button span:nth-of-type(2) {
  top: 9px;
}
.nav-button-wrap .nav-button span:nth-of-type(3) {
  bottom: 0;
}
.nav-button-wrap.active .nav-button span:nth-of-type(1) {
  transform: translateY(11px) rotate(-45deg);
}
.nav-button-wrap.active .nav-button span:nth-of-type(2) {
  opacity: 0;
}
.nav-button-wrap.active .nav-button span:nth-of-type(3) {
  transform: translateY(-8px) rotate(45deg);
}

.globalnav-wrap {
  z-index: -1;
  position: fixed;
  inset: 0;
  height: 100%;
  opacity: 0;
  pointer-events: none;
}
body.open .globalnav-wrap {
  z-index: 100;
  opacity: 1;
  pointer-events: all;
}

.globalnav-wrap ul.globalnav {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: 0 auto;
  height: 100%;
}
.globalnav-wrap ul.globalnav > li {
  width: min(60%, 400px);
}
.globalnav-wrap ul.globalnav > li a {
  display: block;
  text-decoration: none;
  color: #222222;
  transition: color 0.3s cubic-bezier(0.2, 0, 0.1, 1);
}
.globalnav-wrap ul.globalnav > li a svg {
  margin-left: 0.25em;
  text-align: left;
  width: 100%;
}
.globalnav-wrap ul.globalnav > li a span {
  display: block;
  font-size: var(--fzv20);
  line-height: 1.2;
}
.globalnav-wrap ul.globalnav > li a:hover {
  color: #78bd36;
}
.globalnav-wrap ul.globalnav > li:nth-of-type(2) a svg {
  width: 81%;
}
.globalnav-wrap ul.globalnav > li:nth-of-type(2) a:hover {
  color: #44b13f;
}
.globalnav-wrap ul.globalnav > li:nth-of-type(3) a svg {
  width: 40.98%;
}
.globalnav-wrap ul.globalnav > li:nth-of-type(3) a:hover {
  color: #a9cb03;
}
.globalnav-wrap ul.globalnav > li + li {
  margin-top: var(--sp80);
}
#page_government .globalnav-wrap ul.globalnav > li:nth-of-type(1) a {
  color: #78bd36;
}

#page_company .globalnav-wrap ul.globalnav > li:nth-of-type(2) a {
  color: #44b13f;
}

#page_me .globalnav-wrap ul.globalnav > li:nth-of-type(3) a {
  color: #a9cb03;
}

.globalnav-wrap.open ul.globalnav {
  background: white;
}
@media print, screen and (min-width: 768px) {
  .globalnav-wrap {
    transition: opacity 0 ease;
  }
  body:not(.open) .globalnav-wrap {
    flex: 1;
    z-index: 100;
    position: relative;
    height: auto;
    width: 100%;
    opacity: 1;
    pointer-events: all;
  }
  body:not(.open) .globalnav-wrap ul.globalnav {
    flex-direction: row;
    justify-content: space-between;
    position: relative;
    width: 88%;
    max-width: 420px;
  }
  body:not(.open) .globalnav-wrap ul.globalnav > li {
    position: relative;
    padding: 0.5em 0;
    width: auto;
  }
  body:not(.open) .globalnav-wrap ul.globalnav > li a {
    padding: 0;
    width: 100%;
    background: none;
    text-align: center;
  }
  body:not(.open) .globalnav-wrap ul.globalnav > li a svg {
    margin: 0 2.2vw;
    height: 22px;
    width: auto;
  }
  body:not(.open) .globalnav-wrap ul.globalnav > li a span {
    display: block;
    margin-top: -0.75em;
    padding-top: 0.5em;
    border-top: solid 1px #222222;
    font-size: var(--fz10);
    line-height: 1;
    letter-spacing: -0.05em;
  }
  body:not(.open) .globalnav-wrap ul.globalnav > li + li {
    margin-top: 0;
  }
}
@media print, screen and (min-width: 1300px) {
  body:not(.open) .globalnav-wrap ul.globalnav {
    max-width: 460px;
  }
  body:not(.open) .globalnav-wrap ul.globalnav > li a svg {
    margin: 0 25px;
    height: 26px;
  }
  body:not(.open) .globalnav-wrap ul.globalnav > li a span {
    font-size: var(--fz12);
  }
}

header {
  z-index: 9999;
  position: sticky;
  top: 0;
  width: 100%;
  background-color: white;
}
header #header-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0 2.5%;
  width: 100%;
  max-width: 1300px;
}
header #header-wrap h1 {
  width: min(70%, 300px);
  line-height: 1;
  z-index: 1000;
}
header #header-wrap h1 a {
  display: block;
}
header #header-wrap h1 a img {
  width: 100%;
}
header #header-wrap .logo_tokyu-land {
  display: none;
  width: min(13%, 160px);
  line-height: 1;
}
header #header-wrap .logo_tokyu-land a {
  display: block;
}
body.open header {
  position: fixed;
}
body.open header #header-wrap .logo_tokyu-land {
  position: fixed;
  left: 50%;
  bottom: var(--sp30);
  transform: translateX(-50%);
  display: block;
  z-index: 1000;
  width: min(35%, 200px);
  line-height: 1;
}

@media print, screen and (min-width: 768px) {
  header {
    background-color: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(10px);
  }
  header #header-wrap {
    width: 95%;
  }
  header #header-wrap h1 {
    width: min(30%, 360px);
  }
  header #header-wrap .logo_tokyu-land {
    display: block;
  }
}

main {
  position: relative;
}
main #page_header {
  margin: 0 auto;
  padding: 0.1px 0;
  width: 95%;
  max-width: 1300px;
}
main #infomation {
  z-index: 2;
  position: relative;
  margin: var(--sp80) auto 0;
  width: min(95%, 1000px);
}
main #infomation > p {
  font-size: var(--fzv26);
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  line-height: 1;
  color: #44b13f;
}
main #infomation > ul {
  margin-top: var(--sp20);
  border-bottom: solid 1px #44b13f;
}
main #infomation > ul > li {
  border-top: solid 1px #44b13f;
  padding-block: var(--sp20);
}
main #infomation > ul > li .info_date {
  padding: 0.25em 0;
  width: 7.5em;
  font-weight: bold;
  text-align: center;
  line-height: 1;
  color: white;
  background-color: #44b13f;
}
main #infomation > ul > li .info_item {
  margin-top: 0.25em;
  line-height: 1.4;
}
main #infomation > ul > li a {
  display: block;
  position: relative;
  width: 100%;
}
main #infomation > ul > li a .info_item {
  padding-inline: 0em 2em;
}
main #infomation > ul > li a::before {
  display: block;
  content: "";
  position: absolute;
  inset: 0 0 0 auto;
  margin: auto;
  border-radius: calc(infinity * 1px);
  width: 1.5em;
  height: 1.5em;
  background-color: #44b13f;
}
main #infomation > ul > li a::after {
  display: block;
  content: "";
  position: absolute;
  inset: 0 0.6em 0 auto;
  margin: auto;
  width: 0.5em;
  height: 0.5em;
  border-top: 2px solid white;
  border-right: 2px solid white;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#page_government main #infomation > p {
  color: #78bd36;
}
#page_government main #infomation > ul {
  border-bottom: solid 1px #78bd36;
}
#page_government main #infomation > ul > li {
  border-top: solid 1px #78bd36;
}
#page_government main #infomation > ul > li .info_date {
  background-color: #78bd36;
}
#page_government main #infomation > ul > li a::before {
  background-color: #78bd36;
}

#page_company main #infomation > p {
  color: #44b13f;
}
#page_company main #infomation > ul {
  border-bottom: solid 1px #44b13f;
}
#page_company main #infomation > ul > li {
  border-top: solid 1px #44b13f;
}
#page_company main #infomation > ul > li .info_date {
  background-color: #44b13f;
}
#page_company main #infomation > ul > li a::before {
  background-color: #44b13f;
}

#page_me main #infomation > p {
  color: #a9cb03;
}
#page_me main #infomation > ul {
  border-bottom: solid 1px #a9cb03;
}
#page_me main #infomation > ul > li {
  border-top: solid 1px #a9cb03;
}
#page_me main #infomation > ul > li .info_date {
  background-color: #a9cb03;
}
#page_me main #infomation > ul > li a::before {
  background-color: #a9cb03;
}

@media print, screen and (min-width: 768px) {
  main #infomation > ul > li {
    display: flex;
    align-items: start;
  }
  main #infomation > ul > li .info_item {
    flex: 1;
    margin-top: 0;
    padding-inline: 2em 0em;
  }
  main #infomation > ul > li a {
    display: flex;
    align-items: start;
  }
  main #infomation > ul > li a .info_item {
    padding-inline: 2em 3em;
  }
  main #infomation > ul > li a:hover {
    color: #44b13f;
    text-decoration: underline;
  }
}
main .reason-to-choose {
  padding-bottom: var(--sp100);
}
main .reason-to-choose > p {
  text-align: center;
}
main .reason-to-choose > p.reason-to-choose__title {
  font-size: var(--fzv26);
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  line-height: 1.3;
  color: #44b13f;
  word-break: keep-all;
}
main .reason-to-choose > p.reason-to-choose__lead {
  margin-top: 1em;
  line-height: 1.8;
}
main .reason-to-choose > ul {
  margin: 0 auto;
  max-width: 500px;
}
main .reason-to-choose > ul li {
  margin-top: var(--sp30);
  line-height: 1;
}
main .reason-to-choose > ul li p {
  margin-top: 0.5em;
  line-height: 1.5;
}
main .reason-to-choose > ul li p:first-of-type {
  font-size: var(--fzv26);
  font-weight: bold;
  text-align: center;
  line-height: 1.3;
  color: #44b13f;
}
#page_government main .reason-to-choose > p.reason-to-choose__title {
  color: #78bd36;
}
#page_government main .reason-to-choose > ul li p:first-of-type {
  color: #78bd36;
}

#page_company main .reason-to-choose > p.reason-to-choose__title {
  color: #44b13f;
}
#page_company main .reason-to-choose > ul li p:first-of-type {
  color: #44b13f;
}

@media print, screen and (min-width: 768px) {
  main .reason-to-choose > p.reason-to-choose__title {
    font-size: var(--fzv30);
  }
  main .reason-to-choose > ul {
    max-width: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    column-gap: 50px;
  }
  main .reason-to-choose > ul li {
    flex: 1;
  }
  main .reason-to-choose > ul li:nth-of-type(2) {
    animation-delay: 0.3s;
  }
  main .reason-to-choose > ul li:nth-of-type(3) {
    animation-delay: 0.6s;
  }
}
main #for {
  margin: 0 auto 0;
  padding: 1px 0;
  container-type: inline-size;
  width: min(100%, 2500px);
}
main #for .for {
  position: relative;
}
main #for .for picture {
  display: block;
  width: 100%;
  overflow: hidden;
}
main #for .for picture img {
  opacity: 0;
}
main #for .for picture.show img {
  animation: anim_blur 1s ease-in-out forwards;
}
main #for .for > div {
  position: relative;
  margin: -7% auto 0;
  width: min(90%, 1000px);
}
main #for .for > div .text_pc {
  display: none;
}
main #for .for > div p:not([class]) {
  font-size: var(--fzv18);
}
main #for .for > div p.lead {
  margin-top: var(--sp20);
  font-size: var(--fzv16);
  word-break: keep-all;
}
main #for .for > div .btn-style1 {
  margin-top: var(--sp30);
}
main #for .for > div .btn-style1 a span {
  padding: 0 2em;
}
main #for .for#for_government svg {
  color: #78bd36;
}
main #for .for#for_government svg.for_government_sp {
  width: 87.692%;
}
main #for .for#for_government .btn-style1 a {
  color: #78bd36;
  border-color: #78bd36;
}
main #for .for#for_government .btn-style1 a::after {
  border-top-color: #78bd36;
  border-right-color: #78bd36;
}
main #for .for#for_government .btn-style1 a:hover {
  color: white;
  background-color: #78bd36;
}
main #for .for#for_government .btn-style1 a:hover::after {
  border-top-color: white;
  border-right-color: white;
}
main #for .for#for_company svg {
  color: #44b13f;
}
main #for .for#for_company svg.for_company_sp {
  width: 66.153%;
}
main #for .for#for_company .btn-style1 a {
  color: #44b13f;
  border-color: #44b13f;
}
main #for .for#for_company .btn-style1 a::after {
  border-top-color: #44b13f;
  border-right-color: #44b13f;
}
main #for .for#for_company .btn-style1 a:hover {
  color: white;
  background-color: #44b13f;
}
main #for .for#for_company .btn-style1 a:hover::after {
  border-top-color: white;
  border-right-color: white;
}
main #for .for#for_me svg {
  color: #a9cb03;
}
main #for .for#for_me svg.for_me_sp {
  width: 46.461%;
}
main #for .for#for_me .btn-style1 a {
  color: #a9cb03;
  border-color: #a9cb03;
}
main #for .for#for_me .btn-style1 a::after {
  border-top-color: #a9cb03;
  border-right-color: #a9cb03;
}
main #for .for#for_me .btn-style1 a:hover {
  color: white;
  background-color: #a9cb03;
}
main #for .for#for_me .btn-style1 a:hover::after {
  border-top-color: white;
  border-right-color: white;
}
@media print, screen and (min-width: 768px) {
  main #for .for {
    display: flex;
    justify-content: end;
  }
  main #for .for picture {
    width: 65%;
  }
  main #for .for > div {
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    padding: 3cqw 7cqw;
    width: auto;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: start;
    justify-content: start;
  }
  main #for .for > div svg {
    width: auto;
    height: 8cqw;
  }
  main #for .for > div .text_pc {
    display: block;
  }
  main #for .for > div .text_sp {
    display: none;
  }
  main #for .for > div p:not([class]) {
    margin-top: 0.5em;
    font-weight: bold;
  }
  main #for .for > div p.lead {
    margin-top: var(--sp30);
    width: 26cqw;
    line-height: 1.6;
  }
  main #for .for > div .btn-style1 {
    margin-left: 0;
  }
}
@media print, screen and (min-width: 1000px) {
  main #for .for > div {
    padding-top: 6cqw;
  }
  main #for .for > div p.lead {
    margin-top: var(--sp40);
    line-height: 2;
  }
}
@keyframes anim_blur {
  0% {
    filter: blur(10px) brightness(120%) saturate(120%);
    opacity: 0;
  }
  100% {
    filter: none;
    opacity: 1;
  }
}

.page_template main #service {
  margin: var(--sp100) auto 0;
  width: min(95%, 1300px);
}
.page_template main #service h2 {
  text-align: center;
}
.page_template main #service h2 .text_service {
  aspect-ratio: 262.94/80.62;
  width: 160px;
}
.page_template main #service .service_block {
  position: relative;
  margin: var(--sp80) auto 0;
}
.page_template main #service .service_block figure {
  display: block;
  position: relative;
  container-type: inline-size;
}
.page_template main #service .service_block figure > div {
  position: relative;
  line-height: 0;
  vertical-align: bottom;
}
.page_template main #service .service_block figure > div:first-of-type {
  padding: var(--sp30);
}
.page_template main #service .service_block figure > div:first-of-type > div {
  overflow: hidden;
}
.page_template main #service .service_block figure > div:first-of-type > div img {
  transform: scale(1.2, 1.2);
  opacity: 0;
  transition: all 1s cubic-bezier(0.2, 0, 0.1, 1);
}
.page_template main #service .service_block figure > div:first-of-type::before, .page_template main #service .service_block figure > div:first-of-type::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  background-color: black;
}
.page_template main #service .service_block figure > div:first-of-type::before {
  width: 1px;
  height: 30%;
}
.page_template main #service .service_block figure > div:first-of-type::after {
  width: 30%;
  height: 1px;
}
.page_template main #service .service_block figure > div:nth-of-type(2) {
  position: absolute;
  bottom: 0;
  border-radius: 50%;
  overflow: hidden;
  border: solid 5px #78bd36;
  width: min(20cqw, 150px);
  transform: scale(0.7, 0.7);
  opacity: 0;
  transition: all 1s cubic-bezier(0.2, 0, 0.1, 1);
}
.page_template main #service .service_block figure.show > div:first-of-type > div img {
  transform: scale(1, 1);
  opacity: 1;
}
.page_template main #service .service_block figure.show > div:nth-of-type(2) {
  transform: scale(1, 1);
  opacity: 1;
}
.page_template main #service .service_block > div {
  margin: var(--sp30) auto 0;
}
.page_template main #service .service_block > div p {
  margin-top: var(--sp30);
}
.page_template main #service .service_block > div p.btn-style2 {
  width: 15em;
}
.page_template main #service .service_block > div p.btn-style1 {
  width: auto;
}
.page_template main #service .service_block > div > div h3 {
  font-size: var(--fzv30);
  font-weight: bold;
  line-height: 1.3;
  word-break: keep-all;
  width: 100%;
  max-width: 100%;
}
.page_template main #service .service_block > div > div p:not([class]) {
  margin-top: var(--sp20);
}
.page_template main #service .service_block > div .for_service_list {
  width: 100%;
}
.page_template main #service .service_block > div .for_service_list img {
  margin-top: var(--sp20);
}
.page_template main #service .service_block.service_block_r figure > div:first-of-type::before, .page_template main #service .service_block.service_block_r figure > div:first-of-type::after {
  left: 0;
}
.page_template main #service .service_block.service_block_r figure > div:nth-of-type(2) {
  right: -1%;
}
.page_template main #service .service_block.service_block_l figure > div:first-of-type::before, .page_template main #service .service_block.service_block_l figure > div:first-of-type::after {
  right: 0;
}
.page_template main #service .service_block.service_block_l figure > div:nth-of-type(2) {
  left: -1%;
}
@media print, screen and (min-width: 768px) {
  .page_template main #service .service_block.paddingBottom100 {
    padding-bottom: 100px;
  }
  .page_template main #service .service_block figure {
    width: 65%;
  }
  .page_template main #service .service_block > div {
    margin: 0;
    position: absolute;
    top: 4%;
    width: 43%;
  }
  .page_template main #service .service_block > div > div {
    padding: var(--sp30);
    background-color: rgba(255, 255, 255, 0.8);
  }
  .page_template main #service .service_block > div .for_service_list {
    display: flow-root;
  }
  .page_template main #service .service_block > div .for_service_list img {
    float: right;
    width: 66%;
  }
  .page_template main #service .service_block > div .btn-style2,
  .page_template main #service .service_block > div .btn-style1 {
    margin-top: var(--sp10);
  }
  .page_template main #service .service_block > div.width_small {
    width: max(35%, 350px);
  }
  .page_template main #service .service_block.service_block_r > div {
    right: 0;
  }
  .page_template main #service .service_block.service_block_l figure {
    margin: 0 0 0 auto;
  }
  .page_template main #service .service_block.service_block_l > div > div {
    left: 0;
  }
}
.page_template main #result {
  margin: var(--sp100) auto 0;
  width: min(95%, 1300px);
}
.page_template main #result h2 {
  text-align: center;
}
.page_template main #result h2 .text_result {
  aspect-ratio: 196.94/78.09;
  width: 120px;
}
.page_template main #result .result_block {
  position: relative;
  margin: 0 auto 0;
  padding-top: var(--sp80);
}
.page_template main #result .result_block h3 {
  line-height: 0;
  vertical-align: bottom;
  border-bottom: solid 1px black;
  text-align: center;
}
.page_template main #result .result_block h3 .text_case {
  transform: scale(1.5, 1.5);
  transition: transform 0.6s cubic-bezier(0.2, 0, 0.1, 1);
}
.page_template main #result .result_block h3 + p {
  margin: var(--sp40) auto 0;
  text-align: center;
  font-size: var(--fzv32);
  font-weight: bold;
  line-height: 1.4;
}
.page_template main #result .result_block h3 + p span {
  display: inline-block;
}
.page_template main #result .result_block h3 + p span.fs80 {
  font-size: 80%;
}
.page_template main #result .result_block h3 + p span.fs60 {
  font-size: 60%;
}
.page_template main #result .result_block h3 + p img {
  width: min(95%, 400px);
}
.page_template main #result .result_block h3.show .text_case {
  transform: scale(1, 1);
}
.page_template main #result .result_block > div figure {
  display: block;
  position: relative;
  container-type: inline-size;
}
.page_template main #result .result_block > div figure > div {
  position: relative;
  line-height: 0;
  vertical-align: bottom;
}
.page_template main #result .result_block > div figure > div:first-of-type {
  padding: var(--sp30);
}
.page_template main #result .result_block > div figure > div:first-of-type > div {
  overflow: hidden;
}
.page_template main #result .result_block > div figure > div:first-of-type > div img {
  transform: scale(1.2, 1.2);
  opacity: 0;
  transition: all 1s cubic-bezier(0.2, 0, 0.1, 1);
}
.page_template main #result .result_block > div figure > div:first-of-type::before, .page_template main #result .result_block > div figure > div:first-of-type::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  background-color: black;
}
.page_template main #result .result_block > div figure > div:first-of-type::before {
  width: 1px;
  height: 30%;
}
.page_template main #result .result_block > div figure > div:first-of-type::after {
  width: 30%;
  height: 1px;
}
.page_template main #result .result_block > div figure > div:nth-of-type(2) {
  position: absolute;
  bottom: 0;
  width: min(20cqw, 150px);
  transform: scale(0.7, 0.7);
  opacity: 0;
  transition: all 1s cubic-bezier(0.2, 0, 0.1, 1);
}
.page_template main #result .result_block > div figure.show > div:first-of-type > div img {
  transform: scale(1, 1);
  opacity: 1;
}
.page_template main #result .result_block > div figure.show > div:nth-of-type(2) {
  transform: scale(1, 1);
  opacity: 1;
}
.page_template main #result .result_block > div .result_text {
  margin: var(--sp30) auto 0;
}
.page_template main #result .result_block#result_case1 h3 .text_case {
  aspect-ratio: 168.91/67.12;
  width: 125.81px;
}
.page_template main #result .result_block#result_case2 h3 .text_case {
  aspect-ratio: 183/67;
  width: 136.57px;
}
.page_template main #result .result_block#result_case3 h3 .text_case {
  aspect-ratio: 182.32/66.6;
  width: 136.88px;
}
.page_template main #result .result_block#result_case4 h3 .text_case {
  aspect-ratio: 186.06/66.8;
  width: 139.27px;
}
.page_template main #result .result_block#result_case5 h3 .text_case {
  aspect-ratio: 182.5/66.6;
  width: 137.01px;
}
.page_template main #result .result_block#result_case6 h3 .text_case {
  aspect-ratio: 185.06/66.8;
  width: 138.5px;
}
.page_template main #result .result_block#result_case6 > div figure > div:first-of-type::before, .page_template main #result .result_block#result_case6 > div figure > div:first-of-type::after {
  content: "";
  display: none;
}
.page_template main #result .result_block#result_case6 > div .result_text {
  margin: var(--sp30) auto 0;
}
.page_template main #result .result_block#result_case7 h3 .text_case {
  aspect-ratio: 178.16/66.5;
  width: 138.5px;
}
.page_template main #result .result_block#result_case8 h3 .text_case {
  aspect-ratio: 183.13/66.5;
  width: 138.5px;
}
.page_template main #result .result_block#result_case9 h3 .text_case {
  aspect-ratio: 183.56/66.5;
  width: 138.5px;
}
.page_template main #result .result_block#result_case10 h3 .text_case {
  aspect-ratio: 178.16/66.5;
  width: 138.5px;
}
.page_template main #result .result_block.result_block_r figure > div:first-of-type::before, .page_template main #result .result_block.result_block_r figure > div:first-of-type::after {
  left: 0;
}
.page_template main #result .result_block.result_block_l figure > div:first-of-type::before, .page_template main #result .result_block.result_block_l figure > div:first-of-type::after {
  right: 0;
}
.page_template main #result .result_block_type2 {
  margin-top: var(--sp40);
  border-top: solid 1px black;
}
.page_template main #result .result_block_type2 ul {
  margin-top: var(--sp40);
}
.page_template main #result .result_block_type2 ul li p {
  padding-bottom: var(--sp10);
  font-size: var(--fzv20);
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
.page_template main #result .result_block_type2 ul li + li {
  margin-top: var(--sp20);
}
.page_template main #result ul.details {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  container-type: inline-size;
  margin: var(--sp30) auto 0;
  width: min(90%, 450px);
}
.page_template main #result ul.details li {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-inline: 0.5%;
  width: 23%;
  aspect-ratio: 1;
  border: solid 3px #78bd36;
  border-radius: 10%;
  font-size: 4cqw;
  font-weight: bold;
  color: #78bd36;
  background-color: white;
}
.page_template main #result ul.details + p {
  margin-top: var(--sp30);
}
.page_template main #result .js-swiper-main [class^=swiper-button-]::after {
  font-size: 30px;
  color: #666;
}
.page_template main #result .js-swiper-thumbs .swiper-wrapper .swiper-slide {
  cursor: pointer;
  opacity: 0.5;
}
.page_template main #result .js-swiper-thumbs .swiper-wrapper .swiper-slide.swiper-slide-thumb-active {
  opacity: 1;
}
@media print, screen and (min-width: 768px) {
  .page_template main #result .result_block h3 {
    text-align: left;
  }
  .page_template main #result .result_block > div {
    position: relative;
    display: flex;
  }
  .page_template main #result .result_block > div figure {
    width: 65%;
  }
  .page_template main #result .result_block > div .result_text {
    margin: 0;
    padding-top: var(--sp30);
    width: 34.5%;
  }
  .page_template main #result .result_block > div .result_text p {
    line-height: 1.8;
  }
  .page_template main #result .result_block.result_block_r > div > div {
    right: 0;
  }
  .page_template main #result .result_block.result_block_l > div figure {
    margin: 0 0 0 auto;
  }
  .page_template main #result .result_block.result_block_l > div .result_text {
    left: 0;
  }
  .page_template main #result .result_block.result_nophoto ul.details li {
    width: 32.5%;
    font-size: 6cqw;
  }
  .page_template main #result .result_block.result_nophoto > div figure {
    width: 30%;
  }
  .page_template main #result .result_block.result_nophoto > div .result_text {
    width: 60%;
  }
  .page_template main #result .result_block_type2 ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-gap: 5%;
  }
  .page_template main #result .result_block_type2 ul li + li {
    margin-top: 0;
  }
  .page_template main #result ul.details {
    justify-content: start;
    margin-inline: 0;
  }
}
.page_template main .figure_bg {
  position: relative;
}
.page_template main .figure_bg::after {
  display: block;
  content: "";
  position: absolute;
  z-index: -1;
  top: -20%;
  width: min(80vw, 1200px);
  aspect-ratio: 1;
  opacity: 0.8;
  animation: figure_bg_rotate_anime 40s linear infinite;
}
.page_template main .figure_bg.figure_bg_r::after {
  right: -30vw;
}
.page_template main .figure_bg.figure_bg_l::after {
  left: -30vw;
}
@keyframes figure_bg_rotate_anime {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.page_template#page_government main #service h2 {
  color: #78bd36;
}
.page_template#page_government main #service .service_block figure div:first-of-type::before, .page_template#page_government main #service .service_block figure div:first-of-type::after {
  background-color: #78bd36;
}
.page_template#page_government main #service .service_block figure div:nth-of-type(2) {
  border-color: #78bd36;
}
.page_template#page_government main #service .service_block > div > div h3 {
  color: #78bd36;
}
.page_template#page_government main #result h2,
.page_template#page_government main #result h3 {
  color: #78bd36;
}
.page_template#page_government main #result h3 {
  border-color: #78bd36;
}
.page_template#page_government main #result .result_block figure div:first-of-type::before, .page_template#page_government main #result .result_block figure div:first-of-type::after {
  background-color: #78bd36;
}
.page_template#page_government main #result .result_block > div > div h3 {
  color: #78bd36;
}
.page_template#page_government main .figure_bg::after {
  background: url("/assets/img/figure_bg_government.svg") no-repeat center center/contain;
}
.page_template#page_company main #service h2 {
  color: #44b13f;
}
.page_template#page_company main #service .service_block figure div:first-of-type::before, .page_template#page_company main #service .service_block figure div:first-of-type::after {
  background-color: #44b13f;
}
.page_template#page_company main #service .service_block figure div:nth-of-type(2) {
  border-color: #44b13f;
}
.page_template#page_company main #service .service_block > div > div h3 {
  color: #44b13f;
}
.page_template#page_company main #result h2,
.page_template#page_company main #result h3 {
  color: #44b13f;
}
.page_template#page_company main #result h3 {
  border-color: #44b13f;
}
.page_template#page_company main #result .result_block figure div:first-of-type::before, .page_template#page_company main #result .result_block figure div:first-of-type::after {
  background-color: #44b13f;
}
.page_template#page_company main #result .result_block > div > div h3 {
  color: #44b13f;
}
.page_template#page_company main #result .result_block_type2 {
  border-top-color: #44b13f;
}
.page_template#page_company main #result .result_block_type2 ul li p {
  color: #44b13f;
}
.page_template#page_company main .figure_bg::after {
  background: url("/assets/img/figure_bg_company.svg") no-repeat center center/contain;
}
.page_template#page_me main #service h2 {
  color: #a9cb03;
}
.page_template#page_me main #service .service_block figure div:first-of-type::before, .page_template#page_me main #service .service_block figure div:first-of-type::after {
  background-color: #a9cb03;
}
.page_template#page_me main #service .service_block figure div:nth-of-type(2) {
  border-color: #a9cb03;
}
.page_template#page_me main #service .service_block > div > div h3 {
  color: #a9cb03;
}
.page_template#page_me main #result h2,
.page_template#page_me main #result h3 {
  color: #a9cb03;
}
.page_template#page_me main #result h3 {
  border-color: #a9cb03;
}
.page_template#page_me main #result .result_block figure div:first-of-type::before, .page_template#page_me main #result .result_block figure div:first-of-type::after {
  background-color: #a9cb03;
}
.page_template#page_me main #result .result_block > div > div h3 {
  color: #a9cb03;
}
.page_template#page_me main .figure_bg::after {
  background: url("/assets/img/figure_bg_me.svg") no-repeat center center/contain;
}
.page_template#ayumi_scan .figure_bg::after {
  background: url("/assets/img/figure_bg_ayumi.svg") no-repeat center center/contain;
}
.page_template#ayumi_scan .hero {
  padding-block: var(--sp20);
  width: 100%;
  font-weight: bold;
  text-align: center;
  color: white;
  background: var(--ayumi-green1) url(/ayumi-scan/img/hero_bg_sp.svg) no-repeat center center/auto 100%;
}
.page_template#ayumi_scan .hero .inner {
  margin: 0 auto;
  width: min(95%, 1200px);
}
.page_template#ayumi_scan .hero h2,
.page_template#ayumi_scan .hero p {
  position: relative;
  z-index: 2;
  word-break: keep-all;
  line-height: 1.4;
}
.page_template#ayumi_scan .hero h2 {
  font-size: var(--fzv26);
}
.page_template#ayumi_scan .hero h2 span {
  display: block;
  margin: 0.5em auto 0.5em;
  padding: 0.25em 0.75em;
  width: fit-content;
  font-size: 65%;
  line-height: 1;
  color: var(--ayumi-green1);
  background-color: white;
}
.page_template#ayumi_scan .hero p {
  margin-top: 0.75em;
  font-size: var(--fzv18);
}
.page_template#ayumi_scan .hero picture {
  display: block;
}
.page_template#ayumi_scan .btn_area {
  margin: 0 auto;
  padding-block: var(--sp60) var(--sp80);
  width: min(90%, 1100px);
}
.page_template#ayumi_scan .btn_area > div {
  container-type: inline-size;
  margin: 0 auto;
  width: min(96%, 550px);
}
.page_template#ayumi_scan .btn_area > div p.btn-style4 a {
  font-size: var(--fzv24);
  font-weight: bold;
}
.page_template#ayumi_scan .btn_area > div p.btn-style4::before {
  content: "";
  display: block;
  margin-bottom: 0.25em;
  font-size: 4.2cqw;
  font-weight: bold;
  color: currentColor;
}
.page_template#ayumi_scan .btn_area > div:first-of-type p.btn-style4 a {
  background-color: var(--ayumi-green2);
  border-color: var(--ayumi-green2);
}
.page_template#ayumi_scan .btn_area > div:first-of-type p.btn-style4 a:hover {
  color: var(--ayumi-green2);
  background-color: white;
}
.page_template#ayumi_scan .btn_area > div:first-of-type p.btn-style4::before {
  content: "サービス紹介資料をプレゼント";
  color: var(--ayumi-green2);
}
.page_template#ayumi_scan .btn_area > div:last-of-type p.btn-style4 a {
  background-color: var(--ayumi-green3);
  border-color: var(--ayumi-green3);
}
.page_template#ayumi_scan .btn_area > div:last-of-type p.btn-style4 a:hover {
  color: var(--ayumi-green3);
  background-color: white;
}
.page_template#ayumi_scan .btn_area > div:last-of-type p.btn-style4::before {
  content: "貴社のご課題・お悩みに合わせてご提案します！";
  color: var(--ayumi-green3);
}
.page_template#ayumi_scan #problem {
  background-color: #eff8ec;
}
.page_template#ayumi_scan #problem .inner {
  margin: 0 auto;
  padding-block: var(--sp80);
  width: min(95%, 1200px);
}
.page_template#ayumi_scan #problem h3 {
  font-weight: bold;
  text-align: center;
  font-size: var(--fzv26);
  color: var(--ayumi-green2);
}
.page_template#ayumi_scan #problem ul li {
  margin: var(--sp30) auto 0;
  width: min(100%, 450px);
}
.page_template#ayumi_scan #problem ul li::after {
  content: "";
  display: block;
  margin: -50px auto 0;
  border-radius: 50%;
  width: 90%;
  aspect-ratio: 1;
}
.page_template#ayumi_scan #problem ul li > div {
  container-type: inline-size;
  position: relative;
  display: inline-block;
  width: 100%;
  margin-bottom: 20px;
  padding: 1em 0;
  border: 3px solid var(--ayumi-green2);
  border-radius: 10px;
  background-color: white;
  text-align: center;
  font-size: var(--fzv18);
  font-weight: bold;
}
.page_template#ayumi_scan #problem ul li > div::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 20px 14px 0 14px;
  border-color: var(--ayumi-green2) transparent transparent;
  translate: -50% 100%;
}
.page_template#ayumi_scan #problem ul li > div::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 14.8px 10.3px 0 10.3px;
  border-color: white transparent transparent;
  translate: -50% 100%;
}
.page_template#ayumi_scan #problem ul li > div p {
  font-size: 5cqw;
}
.page_template#ayumi_scan #problem ul li:nth-of-type(1)::after {
  background: url(/ayumi-scan/img/problem1.jpg) no-repeat center center/cover;
}
.page_template#ayumi_scan #problem ul li:nth-of-type(2)::after {
  background: url(/ayumi-scan/img/problem2.jpg) no-repeat center center/cover;
}
.page_template#ayumi_scan #problem ul li:nth-of-type(3)::after {
  background: url(/ayumi-scan/img/problem3.jpg) no-repeat center center/cover;
}
.page_template#ayumi_scan #solution .inner {
  margin: 0 auto;
  padding-block: var(--sp80);
  width: min(95%, 1300px);
}
.page_template#ayumi_scan #solution h3 {
  font-weight: bold;
  text-align: center;
  font-size: var(--fzv26);
  color: var(--ayumi-green2);
  word-break: keep-all;
}
.page_template#ayumi_scan #solution ul li {
  margin: var(--sp60) auto 0;
  padding: 1px 5px 30px 5px;
  border-radius: 25px;
  width: min(100%, 450px);
  text-align: center;
  background-color: #82cb03;
}
.page_template#ayumi_scan #solution ul li .step_num {
  display: block;
  margin: -25px auto 0;
  width: 130px;
}
.page_template#ayumi_scan #solution ul li p {
  container-type: inline-size;
  font-weight: bold;
  color: white;
  font-size: var(--fzv18);
  line-height: 1.4;
}
.page_template#ayumi_scan #solution ul li p.step_title {
  font-size: min(8cqw, 20px);
  color: #ffff00;
}
.page_template#ayumi_scan #solution ul li p.step_title span {
  display: block;
  font-size: min(9.2cqw, 32px);
}
.page_template#ayumi_scan #solution ul li p.step_text {
  padding-block: 0.5em 1em;
  word-break: keep-all;
}
.page_template#ayumi_scan #solution ul li img:not([class]) {
  display: block;
  margin: 0 auto;
  width: min(90%, 350px);
}
.page_template#ayumi_scan #solution ul li:nth-of-type(2) {
  background-color: #5eb946;
}
.page_template#ayumi_scan #solution ul li:nth-of-type(3) {
  background-color: #18ad4a;
}
.page_template#ayumi_scan #points .inner {
  margin: 0 auto;
  padding-block: var(--sp40) var(--sp80);
  width: min(95%, 1050px);
}
.page_template#ayumi_scan #points .points_video video {
  width: 100%;
  height: auto;
}
.page_template#ayumi_scan #points .points_num {
  font-size: var(--fzv26);
  font-weight: bold;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  text-align: center;
  line-height: 1;
  color: var(--ayumi-blue);
}
.page_template#ayumi_scan #points .points_num span {
  font-size: 160%;
}
.page_template#ayumi_scan #points .points_title {
  margin: 0;
  padding-top: var(--sp20);
  font-size: var(--fzv24);
  font-weight: bold;
  text-align: center;
  word-break: keep-all;
}
.page_template#ayumi_scan #points .points_text {
  margin: 0;
  padding-block: var(--sp20) var(--sp30);
  font-size: var(--fzv16);
}
.page_template#ayumi_scan #points .points_4_list li + li {
  margin-top: var(--sp30);
}
.page_template#ayumi_scan #points .points_4_list_title {
  font-size: var(--fzv24);
  font-weight: bold;
  text-align: center;
  color: var(--ayumi-green1);
}
.page_template#ayumi_scan #points .points_4_list_title + p {
  margin-block: var(--sp10) var(--sp20);
  font-size: var(--fz16);
}
.page_template#ayumi_scan #flow .inner {
  margin: 0 auto;
  padding-block: var(--sp40) var(--sp80);
  width: min(95%, 1300px);
}
.page_template#ayumi_scan #flow h3 {
  font-weight: bold;
  text-align: center;
  font-size: var(--fzv30);
  color: var(--ayumi-green2);
  word-break: keep-all;
}
.page_template#ayumi_scan #flow ul li {
  position: relative;
  margin: var(--sp60) auto 0;
  padding: var(--sp25) var(--sp15);
  border: solid 5px var(--ayumi-green2);
  border-radius: 15px;
  width: min(100%, 450px);
  opacity: 0;
}
.page_template#ayumi_scan #flow ul li:nth-of-type(n + 2)::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  margin: 0 auto;
  transform: translate3d(0, -145%, 0);
  width: var(--sp40);
  aspect-ratio: 1;
  clip-path: url(#flow_arrow);
  background-color: var(--ayumi-green2);
}
.page_template#ayumi_scan #flow ul li p.flow_num {
  font-size: var(--fzv30);
  font-weight: bold;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  text-align: center;
  line-height: 1;
  color: var(--ayumi-green2);
}
.page_template#ayumi_scan #flow ul li p.flow_num span {
  font-size: 160%;
}
.page_template#ayumi_scan #flow ul li p.flow_title {
  container-type: inline-size;
  margin-block: 0.5em 0.6em;
  padding-block: 0.5em;
  font-weight: bold;
  font-size: min(7cqw, 30px);
  line-height: 1;
  text-align: center;
  color: var(--ayumi-green2);
  background-color: #eff8ec;
}
.page_template#ayumi_scan #flow ul li p.flow_text {
  font-size: var(--fzv18);
}
.page_template#ayumi_scan #flow ul li.show {
  animation-name: anim_slide_down;
  animation-duration: 0.75s;
  animation-timing-function: cubic-bezier(0.2, 0, 0.1, 1);
  animation-fill-mode: forwards;
}
.page_template#ayumi_scan #result h2,
.page_template#ayumi_scan #result h3 {
  color: var(--ayumi-green1);
}
.page_template#ayumi_scan #result h3 {
  border-color: var(--ayumi-green1);
}
.page_template#ayumi_scan #result .result_block figure div:first-of-type::before, .page_template#ayumi_scan #result .result_block figure div:first-of-type::after {
  background-color: var(--ayumi-green1);
}
.page_template#ayumi_scan #result .result_block > div > div h3 {
  color: var(--ayumi-green1);
}
.page_template#ayumi_scan #result .result_block_type2 {
  border-top-color: var(--ayumi-green1);
}
.page_template#ayumi_scan #result .result_block_type2 ul li p {
  color: var(--ayumi-green1);
}
@media only screen and (min-width: 550px) {
  .page_template#ayumi_scan .hero h2 {
    font-size: var(--fzv32);
  }
  .page_template#ayumi_scan .hero p {
    font-size: var(--fzv20);
  }
}
@media only screen and (max-width: 767px) {
  .page_template#ayumi_scan .btn_area > div {
    margin-block: 1em;
  }
  .page_template#ayumi_scan #points .points_container {
    margin-top: var(--sp60);
  }
}
@media print, screen and (min-width: 768px) {
  .page_template main #service h2 {
    text-align: left;
  }
  .page_template main #result h2 {
    text-align: left;
  }
  .page_template main #result h3 {
    text-align: left;
  }
  .page_template main #result h3 .text_case {
    text-align: left;
  }
  .page_template#ayumi_scan .hero {
    background: var(--ayumi-green1) url(/ayumi-scan/img/hero_bg_pc.svg) no-repeat center center/auto 100%;
  }
  .page_template#ayumi_scan .hero h2 {
    font-size: var(--fz48);
  }
  .page_template#ayumi_scan .hero p {
    margin-block: 0.5em;
    font-size: var(--fzv26);
  }
  .page_template#ayumi_scan .hero picture {
    position: relative;
    margin: 0 auto;
    width: min(70%, 664px);
  }
  .page_template#ayumi_scan .hero picture img {
    position: relative;
    z-index: 1;
  }
  .page_template#ayumi_scan .hero picture::before, .page_template#ayumi_scan .hero picture::after {
    z-index: 0;
    display: block;
    content: "";
    position: absolute;
    bottom: 0;
  }
  .page_template#ayumi_scan .hero picture::before {
    width: 53%;
    aspect-ratio: 1;
    bottom: 20px;
    left: -55%;
    background: url(/ayumi-scan/img/hero_bg_pc_left.png) no-repeat center center/contain;
  }
  .page_template#ayumi_scan .hero picture::after {
    width: 77%;
    aspect-ratio: 85/66;
    bottom: -5px;
    right: -67%;
    background: url(/ayumi-scan/img/hero_bg_pc_right.png) no-repeat center center/contain;
  }
  .page_template#ayumi_scan .btn_area {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 0px;
    grid-row-gap: 0px;
  }
  .page_template#ayumi_scan #problem ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 2%;
    grid-row-gap: 0px;
  }
  .page_template#ayumi_scan #problem ul li:nth-of-type(2) {
    animation-delay: 0.3s;
  }
  .page_template#ayumi_scan #problem ul li:nth-of-type(3) {
    animation-delay: 0.6s;
  }
  .page_template#ayumi_scan #solution ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-column-gap: 2%;
    grid-row-gap: 0px;
    gap: 16px;
  }
  .page_template#ayumi_scan #solution ul li {
    display: grid;
    grid-row: span 4;
    grid-template-rows: subgrid;
    gap: 0;
    align-items: center;
  }
  .page_template#ayumi_scan #solution ul li:nth-of-type(2) {
    animation-delay: 0.3s;
  }
  .page_template#ayumi_scan #solution ul li:nth-of-type(3) {
    animation-delay: 0.6s;
  }
  .page_template#ayumi_scan #points .points_container {
    margin-top: var(--sp40);
  }
  .page_template#ayumi_scan #points .points_container .points_num {
    text-align: left;
  }
  .page_template#ayumi_scan #points .points_container .points_num span {
    font-size: 160%;
  }
  .page_template#ayumi_scan #points .points_container .points_title {
    text-align: left;
    font-size: var(--fzv28);
  }
  .page_template#ayumi_scan #points .points_container.points_column {
    display: grid;
    grid-template-columns: 1fr 400px;
    grid-template-rows: 1fr;
    grid-column-gap: var(--sp50);
    grid-row-gap: 0px;
  }
  .page_template#ayumi_scan #points .points_4_list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-column-gap: var(--sp60);
  }
  .page_template#ayumi_scan #points .points_4_list li {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
  }
  .page_template#ayumi_scan #points .points_4_list li:nth-of-type(2) {
    margin-top: 0;
  }
  .page_template#ayumi_scan #points .points_4_list li:nth-of-type(n + 3) {
    margin-top: var(--sp50);
  }
  .page_template#ayumi_scan #points .points_4_list_title {
    text-align: left;
  }
}
@media print, screen and (min-width: 1000px) {
  .page_template#ayumi_scan #flow ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-column-gap: 4.5%;
  }
  .page_template#ayumi_scan #flow ul li {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
    margin: var(--sp40) auto 0;
  }
  .page_template#ayumi_scan #flow ul li:nth-of-type(n + 2)::before {
    inset: 0;
    margin: auto 0;
    width: 30px;
    height: 30px;
    transform: translate3d(max(-48px, -4vw), 0, 0) rotate(-90deg);
  }
  .page_template#ayumi_scan #flow ul li p.flow_title {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding-inline: 0.5em;
    font-size: min(2cqw, 28px);
    line-height: 1.2;
  }
  .page_template#ayumi_scan #flow ul li p.flow_title span {
    display: inline-block;
  }
  .page_template#ayumi_scan #flow ul li.show {
    animation-name: anim_slide_left;
    animation-duration: 0.75s;
    animation-timing-function: cubic-bezier(0.2, 0, 0.1, 1);
    animation-fill-mode: forwards;
  }
  .page_template#ayumi_scan #flow ul li:nth-of-type(2) {
    animation-delay: 0.3s;
  }
  .page_template#ayumi_scan #flow ul li:nth-of-type(3) {
    animation-delay: 0.6s;
  }
  .page_template#ayumi_scan #flow ul li:nth-of-type(4) {
    animation-delay: 0.9s;
  }
}

#contact {
  position: relative;
  margin: var(--sp100) auto 0;
  padding: var(--sp100) var(--sp10);
  width: 100%;
  text-align: center;
  background: url("/assets/img/contact_bg.jpg") no-repeat center center/cover;
}
#contact > div {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  container-type: inline-size;
  margin: 0 auto;
  width: min(90%, 1300px);
  color: white;
}
#contact > div h2 {
  font-size: var(--fzv26);
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.6;
  word-break: keep-all;
}
#contact > div p {
  margin-top: var(--sp30);
  font-size: var(--fzv18);
  line-height: 1.8;
}
#contact > div .btn-style1 {
  width: 100%;
}
#contact > div .btn-style1 a {
  color: black !important;
  background-color: white;
  border-color: black !important;
}
#contact > div .btn-style1 a span {
  padding: 0 1em;
}
#contact > div .btn-style1 a::after {
  border-color: black !important;
}
#contact > div .btn-style1 a:hover {
  color: white !important;
  background-color: black;
}
#contact > div .btn-style1 a:hover::after {
  border-color: white !important;
}
#contact > p {
  container-type: inline-size;
  margin: var(--sp30) auto 0;
  width: min(90%, 1300px);
  font-size: var(--fzv14);
  color: white;
  text-align: left;
}
@media print, screen and (min-width: 768px) {
  #contact > div {
    flex-direction: row;
    justify-content: space-between;
    padding: var(--sp50) 0;
    text-align: left;
  }
  #contact > div p {
    margin-top: var(--sp10);
  }
  #contact > div .btn-style1 {
    margin: 0;
    width: 20em;
  }
  #contact > p {
    margin: 0 auto;
  }
}

footer {
  position: relative;
  padding: var(--sp70) 0;
  width: 100%;
  text-align: center;
}
footer ul li {
  padding: 3px;
}
footer ul li a {
  display: block;
  color: #297db7;
  text-decoration: underline;
}
footer ul li a:hover {
  text-decoration: none;
}
footer h6 {
  margin: var(--sp30) auto 0;
  width: 260px;
}
footer .copyright {
  margin: var(--sp20) auto 0;
  font-size: var(--fz10);
  letter-spacing: 0;
  word-break: keep-all;
}
@media print, screen and (min-width: 768px) {
  footer ul li {
    display: inline-block;
  }
  footer ul li a {
    padding: 0.25em;
  }
  footer .copyright {
    font-size: var(--fz12);
    letter-spacing: 0.1em;
  }
}

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