*:where(:not(html):not(iframe):not(canvas):not(img):not(svg):not(video):not(audio):not(svg *):not(symbol *)) {
  all: unset;
  display: revert;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  min-width: 0;
}

a,
button {
  cursor: revert;
}

ol,
ul,
menu,
summary {
  list-style: none;
}

ol {
  counter-reset: revert;
}

table {
  border-collapse: collapse;
}

input,
textarea {
  -webkit-user-select: auto;
     -moz-user-select: auto;
          user-select: auto;
}

textarea {
  white-space: revert;
}

meter {
  -webkit-appearance: revert;
     -moz-appearance: revert;
          appearance: revert;
}

:where(pre) {
  all: revert;
  box-sizing: border-box;
}

::-moz-placeholder {
  color: inherit;
}

::placeholder {
  color: inherit;
}

:where([contenteditable]:not([contenteditable=false])) {
  -moz-user-modify: read-write;
  -webkit-user-modify: read-write;
  word-wrap: break-word;
  line-break: after-white-space;
  -webkit-user-select: auto;
     -moz-user-select: auto;
          user-select: auto;
}

:where([draggable=true]) {
  -webkit-user-drag: element;
}

:where(dialog:modal) {
  all: revert;
}

::-webkit-details-marker {
  display: none;
}

:where(a, button, summary, label, input, select, textarea):focus-visible {
  outline: -webkit-focus-ring-color auto 1px;
  outline: var(--focus-color, -webkit-focus-ring-color) auto 1px;
}

@property --vw {
  syntax: "<length>";
  initial-value: 0;
  inherits: true;
}
@property --vh {
  syntax: "<length>";
  initial-value: 0;
  inherits: true;
}
@property --one-rem {
  syntax: "<length>";
  initial-value: 0;
  inherits: false;
}
:root {
  --vw: 100vw;
  --vh: 100vh;
  --one-rem: 1rem;
  --window-width: calc(tan(atan2(var(--vw), 1px)));
  --window-height: calc(tan(atan2(var(--vh), 1px)));
  --scale: calc(var(--window-width) / 400);
  --scale-h: calc(var(--window-height) / 750);
  --scale-min: min(var(--scale), var(--scale-h));
  --px: calc(1px * var(--scale));
  --px-h: calc(1px * var(--scale-h));
  --rem: calc(1rem * var(--scale));
  --rem-h: calc(1rem * var(--scale-h));
  --px-min: calc(1px * var(--scale-min));
  --rem-min: calc(1rem * var(--scale-min));
  --font-zen-kaku-gothic: 'Zen Kaku Gothic New', sans-serif;
  --font-roc-grotesk: 'roc-grotesk', sans-serif;
  --font-plus-jakarta-sans: 'Plus Jakarta Sans', sans-serif;
  --color-white: #fff;
  --color-black: #000;
  --color-blue: #224de3;
  --breakpoint-xs: 400px;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 960px;
  --breakpoint-xl: 1488px;
  --breakpoint-xxl: 1920px;
  --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
  --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
  --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
  --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
  --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
  --ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
  --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --ease-gleasing: cubic-bezier(0.4, 0, 0, 1);
  --ease-linear: linear;
  --ease-spring-1: linear(
  	0,
  	0.006,
  	0.025 2.8%,
  	0.101 6.1%,
  	0.539 18.9%,
  	0.721 25.3%,
  	0.849 31.5%,
  	0.937 38.1%,
  	0.968 41.8%,
  	0.991 45.7%,
  	1.006 50.1%,
  	1.015 55%,
  	1.017 63.9%,
  	1.001
  );
  --ease-spring-2: linear(
  	0,
  	0.007,
  	0.029 2.2%,
  	0.118 4.7%,
  	0.625 14.4%,
  	0.826 19%,
  	0.902,
  	0.962,
  	1.008 26.1%,
  	1.041 28.7%,
  	1.064 32.1%,
  	1.07 36%,
  	1.061 40.5%,
  	1.015 53.4%,
  	0.999 61.6%,
  	0.995 71.2%,
  	1
  );
  --ease-spring-3: linear(
  	0,
  	0.009,
  	0.035 2.1%,
  	0.141 4.4%,
  	0.723 12.9%,
  	0.938 16.7%,
  	1.017,
  	1.077,
  	1.121,
  	1.149 24.3%,
  	1.159,
  	1.163,
  	1.161,
  	1.154 29.9%,
  	1.129 32.8%,
  	1.051 39.6%,
  	1.017 43.1%,
  	0.991,
  	0.977 51%,
  	0.974 53.8%,
  	0.975 57.1%,
  	0.997 69.8%,
  	1.003 76.9%,
  	1
  );
  --ease-spring-4: linear(
  	0,
  	0.009,
  	0.037 1.7%,
  	0.153 3.6%,
  	0.776 10.3%,
  	1.001,
  	1.142 16%,
  	1.185,
  	1.209 19%,
  	1.215 19.9% 20.8%,
  	1.199,
  	1.165 25%,
  	1.056 30.3%,
  	1.008 33%,
  	0.973,
  	0.955 39.2%,
  	0.953 41.1%,
  	0.957 43.3%,
  	0.998 53.3%,
  	1.009 59.1% 63.7%,
  	0.998 78.9%,
  	1
  );
  --ease-spring-5: linear(
  	0,
  	0.01,
  	0.04 1.6%,
  	0.161 3.3%,
  	0.816 9.4%,
  	1.046,
  	1.189 14.4%,
  	1.231,
  	1.254 17%,
  	1.259,
  	1.257 18.6%,
  	1.236,
  	1.194 22.3%,
  	1.057 27%,
  	0.999 29.4%,
  	0.955 32.1%,
  	0.942,
  	0.935 34.9%,
  	0.933,
  	0.939 38.4%,
  	1 47.3%,
  	1.011,
  	1.017 52.6%,
  	1.016 56.4%,
  	1 65.2%,
  	0.996 70.2%,
  	1.001 87.2%,
  	1
  );
  --z-base: 100;
  --z-header: 101;
  --z-menu: 102;
  --z-menu-bg: 103;
  --z-modal: 104;
  --grid-columns: 25;
}

@media screen and (min-width: 960px) {
  :root {
    --scale: calc(var(--window-width) / 1488);
    --scale-h: calc(var(--window-height) / 848);
    --grid-columns: 62;
  }
}
@supports not (animation-timing-function: linear(0, 1)) {
  :root {
    --ease-spring-1: var(--ease-out-quad);
    --ease-spring-2: var(--ease-out-cubic);
    --ease-spring-3: var(--ease-out-quart);
    --ease-spring-4: var(--ease-out-quint);
    --ease-spring-5: var(--ease-out-expo);
  }
}
@media (scripting: none) {
  :root {
    --init-opacity: 1;
  }
}
:root.is-scroll-lock {
  overflow: hidden;
}

body {
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-family: var(--font-zen-kaku-gothic);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
          text-size-adjust: none;
}

a {
  display: block;
  color: currentcolor;
  cursor: pointer;
}

button {
  color: currentcolor;
  cursor: pointer;
}

details,
summary {
  cursor: pointer;
}

video,
img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

video {
  outline: 1px solid transparent;
  border: none;
  box-shadow: none;
  filter: drop-shadow(0 0 #000);
  -webkit-mask-image: radial-gradient(white, black);
          mask-image: radial-gradient(white, black);
  transform: translateZ(0);
}

svg {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.preload * {
  transition: none !important;
}

::-moz-selection {
  color: #fff;
  color: var(--color-white);
  background-color: #000;
  background-color: var(--color-black);
}

::selection {
  color: #fff;
  color: var(--color-white);
  background-color: #000;
  background-color: var(--color-black);
}

.uVisuallyHidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  border: 0 !important;
  clip: rect(0 0 0 0) !important;
}

@media screen and (min-width: 960px) {
  .uSpOnly {
    display: none !important;
  }
}

@media screen and (max-width: 960px) {
  .uPcOnly {
    display: none !important;
  }
}

.skip-link {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 2rem;
  font-weight: 700;
  opacity: 0;
  translate: 0 -1000vw;
  transition: opacity 0.4s cubic-bezier(0, 0.7, 0, 1);
}
.skip-link:focus {
  opacity: 1;
  translate: 0 0;
}

@keyframes linehover-animation-out {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(100%);
  }
}
@keyframes linehover-animation-in {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes drawPath {
  0% {
    stroke-dashoffset: 0;
    stroke-dashoffset: var(--path-length, 0);
  }
  100% {
    stroke-dashoffset: 0;
  }
}
.cLinkOverlay__imageWrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.cLinkOverlay__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  background-image: url("../../assets/images/home/hover-bg.png");
  background-repeat: repeat;
  background-position: top left;
  background-size: calc(148 * (1px * min(calc((tan(atan2(100vw, 1px))) / 400), calc((tan(atan2(100vh, 1px))) / 750)))) calc(121 * (1px * min(calc((tan(atan2(100vw, 1px))) / 400), calc((tan(atan2(100vh, 1px))) / 750))));
  background-size: calc(148 * calc(1px * min(calc(calc(tan(atan2(100vw, 1px))) / 400), calc(calc(tan(atan2(100vh, 1px))) / 750)))) calc(121 * calc(1px * min(calc(calc(tan(atan2(100vw, 1px))) / 400), calc(calc(tan(atan2(100vh, 1px))) / 750))));
  background-size: calc(148 * var(--px-min)) calc(121 * var(--px-min));
  opacity: 0.8;
  transform: translateX(-100%);
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.6s var(--ease-out-quart);
}
.cLinkOverlay__headline {
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), color 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.4s var(--ease-out-quart), color 0.4s var(--ease-out-quart);
}

.cButtonOverlay {
  position: relative;
  overflow: hidden;
}
.cButtonOverlay__bg {
  transform: translateX(-101%);
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: transform 0.4s var(--ease-out-quart);
}
.cButtonOverlay__text {
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 960px) and (any-hover: hover) {
  .cLinkOverlay:hover .cLinkOverlay__image {
    transform: translateX(0);
  }
  .cLinkOverlay:hover .cLinkOverlay__headline {
    color: #000;
    color: var(--color-black);
    transform: translateX(10px);
  }
  .cLinkOverlay:hover .cLinkIcon__path {
    stroke: #000;
    stroke: var(--color-black);
    stroke-dasharray: 0;
    stroke-dasharray: var(--path-length, 0);
    stroke-dashoffset: 0;
    stroke-dashoffset: var(--path-length, 0);
    animation: drawPath 1s forwards cubic-bezier(0.165, 0.84, 0.44, 1);
    animation: drawPath 1s forwards var(--ease-out-quart);
  }
  .cButtonOverlay:hover .cButtonOverlay__bg {
    transform: translateX(0);
  }
  .cButtonOverlay:hover .cLinkIcon__path {
    stroke: #fff;
    stroke: var(--color-white);
    stroke-dasharray: 0;
    stroke-dasharray: var(--path-length, 0);
    stroke-dashoffset: 0;
    stroke-dashoffset: var(--path-length, 0);
    animation: drawPath 1.5s forwards cubic-bezier(0.165, 0.84, 0.44, 1);
    animation: drawPath 1.5s forwards var(--ease-out-quart);
  }
  .cBorderLink {
    overflow: hidden;
  }
  .cBorderLink:hover::before {
    animation: 0.4s forwards linehover-animation-out, 0.4s 0.4s forwards linehover-animation-in;
  }
}
.lHeader {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 101;
  z-index: var(--z-header);
  width: 100%;
  padding: calc(18 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(1.25 * (1rem * ((tan(atan2(100vw, 1px))) / 400))) 0;
  padding: calc(18 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(1.25 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400))) 0;
  padding: calc(18 * var(--px)) calc(1.25 * var(--rem)) 0;
}
.lHeader__inner {
  position: relative;
  width: 100%;
  padding: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400))) 0 calc(5 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) 0 calc(5 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding: calc(8 * var(--px)) 0 calc(5 * var(--px));
}
.lHeader__inner::before, .lHeader__inner::after {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  content: "";
  background-color: #000;
  background-color: var(--color-black);
}
.lHeader__inner::before {
  top: 0;
}
.lHeader__inner::after {
  bottom: 0;
}
.lHeader__top {
  display: grid;
  grid-template-columns: 49.75vw 1fr;
  grid-column-gap: calc(0.5625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  grid-column-gap: calc(0.5625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  grid-column-gap: calc(0.5625 * var(--rem));
  -moz-column-gap: calc(0.5625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
       column-gap: calc(0.5625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  -moz-column-gap: calc(0.5625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
       column-gap: calc(0.5625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  -moz-column-gap: calc(0.5625 * var(--rem));
       column-gap: calc(0.5625 * var(--rem));
  align-items: flex-start;
}
.lHeader__title {
  width: 49.75vw;
  height: 10.75vw;
  margin-top: calc(3 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(3 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(3 * var(--px));
}
.lHeader__actions {
  position: fixed;
  top: calc(26 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  top: calc(26 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  top: calc(26 * var(--px));
  right: calc(20 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  right: calc(20 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  right: calc(20 * var(--px));
  z-index: 102;
  z-index: var(--z-menu);
  display: grid;
  grid-template-columns: 18vw 18vw;
  grid-column-gap: 2vw;
  -moz-column-gap: 2vw;
       column-gap: 2vw;
}
.lHeader__entry {
  display: flex;
  align-items: center;
  justify-content: center;
  height: calc(2.5 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(2.5 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(2.5 * var(--rem));
  padding: calc(12 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(12 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding: calc(12 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(12 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding: calc(12 * var(--px)) calc(12 * var(--px)) calc(8 * var(--px));
  font-family: 'roc-grotesk', sans-serif;
  font-family: var(--font-roc-grotesk);
  font-size: calc(0.8125 * (1rem * min(calc((tan(atan2(100vw, 1px))) / 400), calc((tan(atan2(100vh, 1px))) / 750))));
  font-size: calc(0.8125 * calc(1rem * min(calc(calc(tan(atan2(100vw, 1px))) / 400), calc(calc(tan(atan2(100vh, 1px))) / 750))));
  font-size: calc(0.8125 * var(--rem-min));
  font-weight: 500;
  line-height: 1.5;
  color: #fff;
  color: var(--color-white);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background-color: #224de3;
  background-color: var(--color-blue);
  border-radius: 999px;
}
.lHeader__entryText {
  position: relative;
  z-index: 1;
}
.lHeader__menuBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  height: calc(2.5 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(2.5 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(2.5 * var(--rem));
  background-color: #224de3;
  background-color: var(--color-blue);
  border-radius: 999px;
}
.lHeader__entryHoverBg, .lHeader__menuHoverBg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #0c30ad;
  transform: translateX(-100%);
}
.lHeader__menuIcon {
  position: relative;
  display: flex;
  gap: 6px;
  align-items: center;
  justify-content: center;
  width: min(36px, 9vw);
  height: min(36px, 9vw);
}
.lHeader__menuLine {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 1px;
  background-color: #fff;
  background-color: var(--color-white);
  transition: translate 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), rotate 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: translate 0.4s var(--ease-out-quart), rotate 0.4s var(--ease-out-quart);
}
.lHeader__menuLine:nth-child(1) {
  translate: 0 max(-4px, -1vw);
}
.lHeader__menuLine:nth-child(2) {
  translate: 0 min(4px, 1vw);
}
.lHeader__bottom {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  padding-top: calc(4 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding-top: calc(4 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding-top: calc(4 * var(--px));
  margin-left: auto;
}
.lHeader__bottom::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background-color: #000;
  background-color: var(--color-black);
}
.lHeader__bottomText {
  width: -moz-fit-content;
  width: fit-content;
  font-family: 'roc-grotesk', sans-serif;
  font-family: var(--font-roc-grotesk);
  font-size: calc(0.75 * (1rem * min(calc((tan(atan2(100vw, 1px))) / 400), calc((tan(atan2(100vh, 1px))) / 750))));
  font-size: calc(0.75 * calc(1rem * min(calc(calc(tan(atan2(100vw, 1px))) / 400), calc(calc(tan(atan2(100vh, 1px))) / 750))));
  font-size: calc(0.75 * var(--rem-min));
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.14em;
}

@media screen and (min-width: 960px) {
  .lHeader {
    position: absolute;
    top: 0;
    right: 0;
    left: auto;
    left: initial;
    z-index: 101;
    z-index: var(--z-header);
    width: calc(25.9375 * (1rem * ((tan(atan2(100vw, 1px))) / 400)) + 32 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(25.9375 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)) + 32 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(25.9375 * var(--rem) + 32 * var(--px));
    padding: calc(32 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(32 * (1px * ((tan(atan2(100vw, 1px))) / 400))) 0 0;
    padding: calc(32 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(32 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) 0 0;
    padding: calc(32 * var(--px)) calc(32 * var(--px)) 0 0;
  }
  .lHeader__inner {
    padding: calc(10 * (1px * ((tan(atan2(100vw, 1px))) / 400))) 0 calc(7 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    padding: calc(10 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) 0 calc(7 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    padding: calc(10 * var(--px)) 0 calc(7 * var(--px));
  }
  .lHeader__inner::after {
    bottom: -1px;
  }
  .lHeader__top {
    grid-template-columns: calc(13.5 * (1rem * ((tan(atan2(100vw, 1px))) / 400))) 1fr;
    grid-template-columns: calc(13.5 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400))) 1fr;
    grid-template-columns: calc(13.5 * var(--rem)) 1fr;
    -moz-column-gap: calc(1.5625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
         column-gap: calc(1.5625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    -moz-column-gap: calc(1.5625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
         column-gap: calc(1.5625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    -moz-column-gap: calc(1.5625 * var(--rem));
         column-gap: calc(1.5625 * var(--rem));
  }
  .lHeader__title {
    width: calc(13.5 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(13.5 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(13.5 * var(--rem));
    height: calc(2.9375 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(2.9375 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(2.9375 * var(--rem));
    margin-top: 0;
  }
  .lHeader__actions {
    top: calc(43 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    top: calc(43 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    top: calc(43 * var(--px));
    right: calc(32 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    right: calc(32 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    right: calc(32 * var(--px));
    grid-template-columns: calc(6 * (1rem * ((tan(atan2(100vw, 1px))) / 400))) calc(4.5 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    grid-template-columns: calc(6 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(4.5 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    grid-template-columns: calc(6 * var(--rem)) calc(4.5 * var(--rem));
    -moz-column-gap: calc(0.375 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
         column-gap: calc(0.375 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    -moz-column-gap: calc(0.375 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
         column-gap: calc(0.375 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    -moz-column-gap: calc(0.375 * var(--rem));
         column-gap: calc(0.375 * var(--rem));
    margin-top: 1px;
    transform-origin: center right;
  }
  .lHeader__entry {
    display: flex;
    align-items: center;
    justify-content: center;
    height: calc(2 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(2 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(2 * var(--rem));
    padding: 0 calc(12 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    padding: 0 calc(12 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    padding: 0 calc(12 * var(--px));
    font-size: calc(0.9375 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(0.9375 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(0.9375 * var(--rem));
    line-height: 1.3;
  }
  .lHeader__menuBtn {
    height: calc(2 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(2 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(2 * var(--rem));
  }
  .lHeader__menuIcon {
    width: calc(36 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(36 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(36 * var(--px));
    height: calc(32 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(32 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(32 * var(--px));
  }
  .lHeader__menuLine:nth-child(1) {
    translate: 0 calc(-4 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    translate: 0 calc(-4 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    translate: 0 calc(-4 * var(--px));
  }
  .lHeader__menuLine:nth-child(2) {
    translate: 0 calc(4 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    translate: 0 calc(4 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    translate: 0 calc(4 * var(--px));
  }
  .lHeader__bottom {
    padding-top: calc(7 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    padding-top: calc(7 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    padding-top: calc(7 * var(--px));
    padding-right: calc(2 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    padding-right: calc(2 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    padding-right: calc(2 * var(--px));
  }
  .lHeader__bottom::before {
    top: -2px;
  }
  .lHeader__bottomText {
    font-size: calc(0.875 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(0.875 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(0.875 * var(--rem));
    letter-spacing: 0.13em;
  }
}
.lFooter {
  width: 100%;
}
.lFooter__inner {
  position: relative;
  padding: calc(80 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(40 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(32 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding: calc(80 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(40 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(32 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding: calc(80 * var(--px)) calc(40 * var(--px)) calc(32 * var(--px));
  overflow: hidden;
}
.lFooter__inner::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  content: "";
  background-image: url("../../assets/images/common/footer-bg.png");
  background-repeat: repeat;
  background-position: top left;
  background-size: calc(148 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(121 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  background-size: calc(148 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(121 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  background-size: calc(148 * var(--px)) calc(121 * var(--px));
}
.lFooter__link {
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: calc(78 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(78 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(78 * var(--px));
  font-family: 'roc-grotesk', sans-serif;
  font-family: var(--font-roc-grotesk);
  font-size: calc(1.125 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(1.125 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(1.125 * var(--rem));
  font-weight: 500;
  line-height: 1.5;
  color: #fff;
  color: var(--color-white);
  letter-spacing: 0.1em;
  background-color: #224de3;
}
.lFooter__link_hoverBg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-color: #0c30ad;
  transform: translateX(-100%);
}
.lFooter__copyright {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: calc(140 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(140 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(140 * var(--px));
  margin-right: calc(-16 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  margin-right: calc(-16 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  margin-right: calc(-16 * var(--px));
  margin-left: auto;
  font-family: 'roc-grotesk', sans-serif;
  font-family: var(--font-roc-grotesk);
  font-size: calc(0.75 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.75 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.75 * var(--rem));
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.02em;
}
.lFooter__leaf {
  position: absolute;
  mix-blend-mode: multiply;
}
.lFooter__leaf[data-leaf="1"] {
  top: calc(40 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  top: calc(40 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  top: calc(40 * var(--px));
  left: calc(-12 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  left: calc(-12 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  left: calc(-12 * var(--px));
  width: calc(72 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  width: calc(72 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  width: calc(72 * var(--px));
  height: calc(66 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(66 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(66 * var(--px));
}
.lFooter__leaf[data-leaf="2"] {
  top: calc(130 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  top: calc(130 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  top: calc(130 * var(--px));
  right: calc(4 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  right: calc(4 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  right: calc(4 * var(--px));
  width: calc(65 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  width: calc(65 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  width: calc(65 * var(--px));
  height: calc(62 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(62 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(62 * var(--px));
}
.lFooter__leaf[data-leaf="3"] {
  top: calc(194 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  top: calc(194 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  top: calc(194 * var(--px));
  left: calc(70 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  left: calc(70 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  left: calc(70 * var(--px));
  width: calc(103 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  width: calc(103 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  width: calc(103 * var(--px));
  height: calc(77 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(77 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(77 * var(--px));
}

@media screen and (min-width: 960px) {
  .lFooter {
    width: 100%;
  }
  .lFooter__inner {
    padding: calc(80 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(384 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(152 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    padding: calc(80 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(384 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(152 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    padding: calc(80 * var(--px)) calc(384 * var(--px)) calc(152 * var(--px));
  }
  .lFooter__link {
    width: calc(720 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(720 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(720 * var(--px));
    height: calc(150 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(150 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(150 * var(--px));
    font-family: 'roc-grotesk', sans-serif;
    font-family: var(--font-roc-grotesk);
    font-size: calc(1.75 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(1.75 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(1.75 * var(--rem));
  }
  .lFooter__link_hoverBg {
    transition-duration: 0.6s;
  }
  .lFooter__copyright {
    position: absolute;
    bottom: calc(24 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    bottom: calc(24 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    bottom: calc(24 * var(--px));
    left: calc(24 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    left: calc(24 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    left: calc(24 * var(--px));
    margin-top: 0;
    margin-right: 0;
  }
  .lFooter__leaf {
    position: absolute;
    mix-blend-mode: multiply;
  }
  .lFooter__leaf[data-leaf="1"] {
    top: calc(22 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    top: calc(22 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    top: calc(22 * var(--px));
    left: calc(24 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    left: calc(24 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    left: calc(24 * var(--px));
    width: calc(141 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(141 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(141 * var(--px));
    height: calc(114 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(114 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(114 * var(--px));
  }
  .lFooter__leaf[data-leaf="2"] {
    top: calc(198 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    top: calc(198 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    top: calc(198 * var(--px));
    right: calc(37 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    right: calc(37 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    right: calc(37 * var(--px));
    width: calc(107 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(107 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(107 * var(--px));
    height: calc(104 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(104 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(104 * var(--px));
  }
  .lFooter__leaf[data-leaf="3"] {
    top: auto;
    top: initial;
    right: calc(406 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    right: calc(406 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    right: calc(406 * var(--px));
    bottom: calc(-77 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    bottom: calc(-77 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    bottom: calc(-77 * var(--px));
    left: auto;
    left: initial;
    width: calc(171 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(171 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(171 * var(--px));
    height: calc(181 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(181 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(181 * var(--px));
  }
}
.cModal__inner {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 10000;
  overflow: auto;
  background-color: #fff;
  opacity: 0;
  transform: translateX(101%);
  transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1), opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.cModal__wrapper {
  width: 100%;
}
.cModal__content {
  width: 100%;
}
.cModal__overlay {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.is-menu-open {
  min-height: 100vh;
}
.is-menu-open .cModal__inner {
  opacity: 1;
  transform: translateX(0);
}
.is-menu-open .cModal__overlay {
  pointer-events: auto;
}

.cMenu__nolink {
  pointer-events: none;
  cursor: default;
  opacity: 0.2;
}
.cMenu__inner {
  z-index: 104;
  z-index: var(--z-modal);
  background-color: #d7eae8;
}
.cMenu__wrapper {
  height: 100%;
  overflow-y: auto;
}
.cMenu__bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-color: #fff;
  background-color: var(--color-white);
}
.cMenu__fixed {
  position: absolute;
  top: calc(17 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  top: calc(17 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  top: calc(17 * var(--px));
  left: 0;
  z-index: 2;
  display: grid;
  grid-template-columns: calc(14.0625 * (1rem * ((tan(atan2(100vw, 1px))) / 400))) calc(5.25 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  grid-template-columns: calc(14.0625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(5.25 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  grid-template-columns: calc(14.0625 * var(--rem)) calc(5.25 * var(--rem));
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: calc(4.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(4.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(4.625 * var(--rem));
  padding: 0 calc(23 * (1px * ((tan(atan2(100vw, 1px))) / 400))) 0 calc(20 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding: 0 calc(23 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) 0 calc(20 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding: 0 calc(23 * var(--px)) 0 calc(20 * var(--px));
}
.cMenu__fixed_link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: calc(2.5 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(2.5 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(2.5 * var(--rem));
  padding: calc(3 * (1px * ((tan(atan2(100vw, 1px))) / 400))) 0 0;
  padding: calc(3 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) 0 0;
  padding: calc(3 * var(--px)) 0 0;
  font-family: 'roc-grotesk', sans-serif;
  font-family: var(--font-roc-grotesk);
  font-size: calc(0.8125 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.8125 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.8125 * var(--rem));
  font-weight: 500;
  line-height: 1.5;
  color: #fff;
  color: var(--color-white);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background-color: #224de3;
  background-color: var(--color-blue);
  border-radius: 999px;
}
.cMenu__closeBtn {
  display: grid;
  grid-template-columns: calc(3.0625 * (1rem * ((tan(atan2(100vw, 1px))) / 400))) calc(1.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  grid-template-columns: calc(3.0625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(1.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  grid-template-columns: calc(3.0625 * var(--rem)) calc(1.625 * var(--rem));
  justify-content: space-between;
}
.cMenu__closeText {
  margin-top: calc(4 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(4 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(4 * var(--px));
  font-family: 'roc-grotesk', sans-serif;
  font-family: var(--font-roc-grotesk);
  font-size: calc(0.8125 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.8125 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.8125 * var(--rem));
  font-weight: 500;
  line-height: 1.5;
  text-transform: uppercase;
  letter-spacing: 0.11em;
}
.cMenu__closeIcon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(1.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  width: calc(1.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  width: calc(1.625 * var(--rem));
  height: calc(1.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(1.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(1.625 * var(--rem));
  overflow: hidden;
}
.cMenu__closeLine {
  position: absolute;
  width: 100%;
  height: 100%;
}
.cMenu__closeLine::before {
  position: absolute;
  bottom: 50%;
  left: -20%;
  width: 140%;
  height: 1px;
  content: "";
  background-image: linear-gradient(currentcolor, currentcolor);
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 100% 1px;
}
.cMenu__closeLine:nth-child(1)::before {
  transform: rotate(45deg);
}
.cMenu__closeLine:nth-child(2)::before {
  transform: rotate(-45deg);
}
.cMenu__main {
  position: relative;
  z-index: 1;
}
.cMenu__main_inner {
  padding: calc(88 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(20 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(60 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding: calc(88 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(20 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(60 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding: calc(88 * var(--px)) calc(20 * var(--px)) calc(60 * var(--px));
}
.cMenu__main_nav {
  display: grid;
  grid-row-gap: calc(12 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  grid-row-gap: calc(12 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  grid-row-gap: calc(12 * var(--px));
  row-gap: calc(12 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  row-gap: calc(12 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  row-gap: calc(12 * var(--px));
}
.cMenu__navLink {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  padding: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(16 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(9 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(16 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(9 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding: calc(8 * var(--px)) calc(16 * var(--px)) calc(9 * var(--px));
  font-size: calc(1 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(1 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(1 * var(--rem));
  font-weight: 500;
  line-height: 1.5;
}
.cMenu__navLink::before {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background-image: linear-gradient(currentcolor, currentcolor);
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 100% 1px;
}
.cMenu__subNav {
  display: grid;
  grid-row-gap: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  grid-row-gap: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  grid-row-gap: calc(8 * var(--px));
  row-gap: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  row-gap: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  row-gap: calc(8 * var(--px));
  padding-left: calc(24 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding-left: calc(24 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding-left: calc(24 * var(--px));
  margin-top: calc(10 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(10 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  margin-top: calc(10 * var(--px));
}
.cMenu__subNavLink {
  position: relative;
  display: grid;
  grid-template-columns: calc(0.8125 * (1rem * ((tan(atan2(100vw, 1px))) / 400))) 1fr;
  grid-template-columns: calc(0.8125 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400))) 1fr;
  grid-template-columns: calc(0.8125 * var(--rem)) 1fr;
  grid-column-gap: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  grid-column-gap: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  grid-column-gap: calc(8 * var(--px));
  -moz-column-gap: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
       column-gap: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  -moz-column-gap: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
       column-gap: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  -moz-column-gap: calc(8 * var(--px));
       column-gap: calc(8 * var(--px));
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  padding: calc(4 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(12 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(5 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
  padding: calc(4 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(12 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(5 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  padding: calc(4 * var(--px)) calc(12 * var(--px)) calc(5 * var(--px));
}
.cMenu__subNavLink::before {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 1px;
  content: "";
  background-image: linear-gradient(to right, currentcolor 1px, transparent 1px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 3px 1px;
}
.cMenu__subNavNum {
  height: calc(0.875 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  height: calc(0.875 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  height: calc(0.875 * var(--rem));
  font-family: 'roc-grotesk', sans-serif;
  font-family: var(--font-roc-grotesk);
  font-size: calc(0.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.625 * var(--rem));
  font-weight: 500;
  line-height: 1;
}
.cMenu__subNavText {
  font-size: calc(0.9375 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.9375 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
  font-size: calc(0.9375 * var(--rem));
  font-weight: 500;
  line-height: 1.5;
}

.is-menu-open {
  min-height: 100vh;
}
.is-menu-open .cMenu__inner {
  opacity: 1;
  transform: translateX(0);
}

@media screen and (min-width: 960px) {
  .cMenu__inner {
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    background-color: transparent;
  }
  .cMenu__content {
    position: relative;
    z-index: 1;
    width: calc(30 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(30 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(30 * var(--rem));
    height: 100%;
    margin-left: auto;
  }
  .cMenu__bg {
    position: fixed;
    z-index: -1;
  }
  .cMenu__fixed {
    top: calc(24 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    top: calc(24 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    top: calc(24 * var(--px));
    display: flex;
    justify-content: end;
    height: calc(1.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    height: calc(1.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    height: calc(1.625 * var(--rem));
    padding: 0 calc(23 * (1px * ((tan(atan2(100vw, 1px))) / 400))) 0 0;
    padding: 0 calc(23 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) 0 0;
    padding: 0 calc(23 * var(--px)) 0 0;
  }
  .cMenu__closeBtn {
    -moz-column-gap: calc(0.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
         column-gap: calc(0.625 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    -moz-column-gap: calc(0.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
         column-gap: calc(0.625 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    -moz-column-gap: calc(0.625 * var(--rem));
         column-gap: calc(0.625 * var(--rem));
  }
  .cMenu__closeBtn:hover .cMenu__closeLine:nth-child(1) {
    animation: 0.4s forwards linehover-cross-animation-out, 0.4s 0.4s forwards linehover-cross-animation-in;
  }
  .cMenu__closeBtn:hover .cMenu__closeLine:nth-child(2) {
    animation: 0.4s forwards linehover-cross-animation-out-2, 0.4s 0.4s forwards linehover-cross-animation-in-2;
  }
  .cMenu__main {
    height: 100%;
  }
  .cMenu__main_inner {
    padding: calc(80 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(32 * (1px * ((tan(atan2(100vw, 1px))) / 400))) calc(100 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    padding: calc(80 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(32 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400))) calc(100 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    padding: calc(80 * var(--px)) calc(32 * var(--px)) calc(100 * var(--px));
  }
  .cMenu__main_nav {
    display: flex;
    flex-wrap: wrap;
    gap: calc(8 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    gap: calc(8 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    gap: calc(8 * var(--px));
    width: calc(22.5 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    width: calc(22.5 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    width: calc(22.5 * var(--rem));
  }
  .cMenu__navItem {
    width: -moz-fit-content;
    width: fit-content;
  }
  .cMenu__navLink {
    font-size: calc(1.125 * (1rem * ((tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(1.125 * calc(1rem * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    font-size: calc(1.125 * var(--rem));
  }
  .cMenu__navLink:hover::before {
    animation: 0.4s forwards linehover-animation-out, 0.4s 0.4s forwards linehover-animation-in;
  }
  .cMenu__subNav {
    display: grid;
    grid-row-gap: calc(2 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    grid-row-gap: calc(2 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    grid-row-gap: calc(2 * var(--px));
    row-gap: calc(2 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    row-gap: calc(2 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    row-gap: calc(2 * var(--px));
    margin-top: calc(2 * (1px * ((tan(atan2(100vw, 1px))) / 400)));
    margin-top: calc(2 * calc(1px * calc(calc(tan(atan2(100vw, 1px))) / 400)));
    margin-top: calc(2 * var(--px));
  }
}
@keyframes linehover-cross-animation-out {
  0% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(-100%, -100%);
  }
}
@keyframes linehover-cross-animation-in {
  0% {
    transform: translate(100%, 100%);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes linehover-cross-animation-out-2 {
  0% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(100%, -100%);
  }
}
@keyframes linehover-cross-animation-in-2 {
  0% {
    transform: translate(-100%, 100%);
  }
  100% {
    transform: translate(0, 0);
  }
}
:host {
  --output-file-name-important: common;
}