html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

body {
  -webkit-text-size-adjust: none;
}

mark {
  background-color: transparent;
  color: inherit;
}

input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input[type="text"],
input[type="email"],
select,
textarea {
  -moz-appearance: none;
  -webkit-appearance: none;
  -ms-appearance: none;
  appearance: none;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

body {
  line-height: 1;
  min-height: var(--viewport-height);
  min-width: 320px;
  overflow-x: hidden;
  word-wrap: break-word;
}

body:before {
  content: "";
  display: block;
  background-attachment: scroll;
  height: var(--background-height);
  left: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  transform: scale(1);
  width: 100vw;
  z-index: 0;
  background-image: url(""),
    linear-gradient(to top, rgba(0, 0, 0, 0.761), rgba(0, 0, 0, 0.761)),
    url("../assets/images/bg.jpg?v=9484d5d4");
  background-size: 113px, auto, cover;
  background-position: center, 0% 0%, center;
  background-repeat: repeat, repeat, repeat;
  background-color: #ffffff;
}

body:after {
  background-color: #1c1c1c;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  opacity: 0;
  position: fixed;
  top: 0;
  transform: scale(1);
  transition: opacity 0.75s ease-in-out 0s, visibility 0.75s 0s;
  visibility: hidden;
  width: 100%;
  z-index: 1;
}

body.is-loading:after {
  opacity: 1;
  visibility: visible;
}

:root {
  --background-height: 100vh;
  --site-language-alignment: left;
  --site-language-direction: ltr;
  --site-language-flex-alignment: flex-start;
  --viewport-height: 100vh;
}

html {
  font-size: 18pt;
}

u {
  text-decoration: underline;
}

strong {
  color: inherit;
  font-weight: bolder;
}

em {
  font-style: italic;
}

code {
  background-color: rgba(144, 144, 144, 0.25);
  border-radius: 0.25em;
  font-family: "Lucida Console", "Courier New", monospace;
  font-size: 0.9em;
  font-weight: normal;
  letter-spacing: 0;
  margin: 0 0.25em;
  padding: 0.25em 0.5em;
  text-indent: 0;
}

mark {
  background-color: rgba(144, 144, 144, 0.25);
}

s {
  text-decoration: line-through;
}

sub {
  font-size: smaller;
  vertical-align: sub;
}

sup {
  font-size: smaller;
  vertical-align: super;
}

a {
  color: inherit;
  text-decoration: underline;
  transition: color 0.25s ease;
}

#wrapper {
  -webkit-overflow-scrolling: touch;
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: var(--viewport-height);
  overflow: hidden;
  position: relative;
  z-index: 2;
}

#main {
  --alignment: left;
  --flex-alignment: flex-start;
  --border-radius-tl: 0;
  --border-radius-tr: 0;
  --border-radius-br: 0;
  --border-radius-bl: 0;
  align-items: center;
  display: flex;
  flex-grow: 0;
  flex-shrink: 0;
  justify-content: center;
  max-width: 100%;
  position: relative;
  text-align: var(--alignment);
  z-index: 1;
}

#main > .inner {
  --padding-horizontal: 3rem;
  --padding-vertical: 3.75rem;
  --spacing: 1.625rem;
  --width: 44rem;
  border-radius: var(--border-radius-tl) var(--border-radius-tr)
    var(--border-radius-br) var(--border-radius-bl);
  max-width: 100%;
  position: relative;
  width: var(--width);
  z-index: 1;
  padding: var(--padding-vertical) var(--padding-horizontal);
}

#main > .inner > * {
  margin-top: var(--spacing);
  margin-bottom: var(--spacing);
  transition: opacity 1s ease-in-out 0s;
}

#main > .inner > :first-child {
  margin-top: 0 !important;
}

#main > .inner > :last-child {
  margin-bottom: 0 !important;
}

#main > .inner > .full {
  margin-left: calc(var(--padding-horizontal) * -1);
  max-width: calc(100% + calc(var(--padding-horizontal) * 2) + 0.4725px);
  width: calc(100% + calc(var(--padding-horizontal) * 2) + 0.4725px);
}

#main > .inner > .full:first-child {
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
  margin-top: calc(var(--padding-vertical) * -1) !important;
}

#main > .inner > .full:last-child {
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
  margin-bottom: calc(var(--padding-vertical) * -1) !important;
}

#main > .inner > .full.screen {
  border-radius: 0 !important;
  max-width: 100vw;
  position: relative;
  width: 100vw;
  left: 0;
  margin-left: calc(var(--padding-horizontal) * -1);
  right: auto;
}

body.is-loading #main > .inner > * {
  opacity: 0;
}

#main > .inner > :nth-child(2) {
  transition-delay: 0.125s;
}

#main > .inner > :nth-child(3) {
  transition-delay: 0.25s;
}

#main > .inner > :nth-child(4) {
  transition-delay: 0.375s;
}

#main > .inner > :nth-child(5) {
  transition-delay: 0.5s;
}

body.is-instant #main,
body.is-instant #main > .inner > *,
body.is-instant #main > .inner > section > * {
  transition: none !important;
}

body.is-instant:after {
  display: none !important;
  transition: none !important;
}

.image {
  display: block;
  line-height: 0;
  max-width: 100%;
  position: relative;
}

.image .frame {
  -webkit-backface-visibility: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  vertical-align: top;
  width: 100%;
}

.image .frame img {
  border-radius: 0 !important;
  max-width: 100%;
  vertical-align: top;
  width: inherit;
}

.image.full .frame {
  display: block;
}

.image.full:first-child .frame {
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
}

.image.full:last-child .frame {
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
}

#image01 {
  position: relative;
  display: inline-block;
  margin-bottom: 0 !important;
}

#image01 img {
  display: block;
  max-width: 100%;
  height: auto;
}

#image01 svg {
  position: absolute;
  max-width: 50%;
  top: 25%;
  left: 25%;
  fill: rgba(255, 255, 255, 0);
  transition: fill 500ms ease-in;
}

#image01 .frame {
  width: 9rem;
  border-radius: 100%;
  border-color: rgba(255, 255, 255, 0.392);
  border-style: solid;
  border-width: 3px;
  transition:  border-color 500ms ease;
}

#image01 .frame:hover {
  border-color: rgba(255, 255, 255, 0.749);
  border-width: 4px;
  transition: border-color 500ms ease;
}


#image01 .frame img {
  transition: all 500ms ease;
}

#image01 .frame:hover img {
  filter: brightness(70%);
  -webkit-filter: brightness(70%);
  transition: all 500ms ease;
}


#image01 .frame:hover svg {
  fill: rgba(255, 255, 255, 0.749);
  transition: all 500ms ease-in;
}

h1,
h2,
h3,
p {
  direction: var(--site-language-direction);
  position: relative;
}

h1 span.p,
h2 span.p,
h3 span.p,
p span.p {
  display: block;
  position: relative;
}

h1 span[style],
h2 span[style],
h3 span[style],
p span[style],
h1 strong,
h2 strong,
h3 strong,
p strong,
h1 a,
h2 a,
h3 a,
p a,
h1 code,
h2 code,
h3 code,
p code,
h1 mark,
h2 mark,
h3 mark,
p mark {
  -webkit-text-fill-color: currentcolor;
}

#text02 {
  color: #ffffff;
  font-family: "Space Mono", monospace;
  font-size: 2em;
  line-height: 1.175;
  font-weight: 400;
}

#text02 a {
  text-decoration: underline;
}

#text02 a:hover {
  text-decoration: none;
}

#text02 span.p:nth-child(n + 2) {
  margin-top: 1rem;
}

#text01 {
  color: rgba(255, 255, 255, 0.749);
  font-family: "Space Mono", monospace;
  font-size: 1em;
  line-height: 1.55;
  font-weight: 400;
}

#text01 a {
  text-decoration: underline;
}

#text01 a:hover {
  text-decoration: none;
}

#text01 span.p:nth-child(n + 2) {
  margin-top: 1rem;
}

hr {
  border: 0;
  padding: 0;
  position: relative;
  width: 100%;
}

hr:before {
  content: "";
  display: inline-block;
  max-width: 100%;
  vertical-align: middle;
}

#divider02:not(:first-child) {
  margin-top: 0.25rem !important;
}

#divider02:not(:last-child) {
  margin-bottom: 0.25rem !important;
}

#divider02:before {
  width: 3rem;
  border-top: solid 1px rgba(255, 255, 255, 0.392);
  height: 1px;
  margin-top: -0.5px;
}

.icons {
  display: flex;
  flex-wrap: wrap;
  justify-content: var(--flex-alignment);
  letter-spacing: 0;
  padding: 0;
}

.icons li {
  position: relative;
  z-index: 1;
}

.icons li a {
  align-items: center;
  display: flex;
  justify-content: center;
}

.icons li a svg {
  display: block;
  position: relative;
}

.icons li a + svg {
  display: block;
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}

.icons li a .label {
  display: none;
}

#icons01 {
  font-size: 2em;
  gap: 2rem;
}

#icons01:not(:first-child) {
  margin-top: 2.375rem !important;
}

#icons01:not(:last-child) {
  margin-bottom: 2.375rem !important;
}

#icons01 li a {
  height: 1em;
  width: 1em;
  transition: color 0.25s ease, background-color 0.25s ease,
    border-color 0.25s ease;
}

#icons01 li a svg {
  height: 100%;
  width: 100%;
  transition: fill 0.25s ease;
}

#icons01 a svg {
  fill: rgba(255, 255, 255, 0.392);
}

#icons01 a:hover svg {
  fill: #ffffff !important;
}

#icons01 a.icon-stroke svg {
  stroke: rgba(255, 255, 255, 0.392);
}

#icons01 a.icon-stroke:hover svg {
  stroke: #ffffff !important
}

#icons01 li a + svg {
  transition: fill 0.25s ease, stroke 0.25s ease;
}
.cross-cls-2,
.cross-cls-3,
.cross-cls-4,
.cross-cls-5,
.cross-cls-6 {
  stroke-miterlimit: 10;
}

.cross-cls-3 {
  stroke-width: 8px;
}

.cross-cls-3,
.cross-cls-4 {
  fill: none;
}

.cross-cls-4 {
  stroke-width: 6px;
}

.cross-cls-5 {
  stroke-width: 16px;
}
.cross-cls-6 {
  stroke-width: 12px;
}

/* @media(max-width: 3840px) {
  #image01 .frame {
    width: 15rem;
  }
  #text02 {
    font-size: 3em;
    width: 100%;
  }
  #text01 {
    font-size: 1.5em;
  }
  #main > .inner {
    --width: 50rem;
  }

  #icons01 li a {
    height: 1.5em;
    width: 1.5em;
  }
} */

@media (max-width: 1920px) {
}

@media (max-width: 1680px) {
  html {
    font-size: 13pt;
  }
}

@media (max-width: 1280px) {
  html {
    font-size: 13pt;
  }
}

@media (max-width: 1024px) {
}

@media (max-width: 980px) {
  html {
    font-size: 11pt;
  }
}

@media (max-width: 736px) {
  html {
    font-size: 11pt;
  }

  #main > .inner {
    --padding-horizontal: 2rem;
    --padding-vertical: 3.5rem;
    --spacing: 1.625rem;
  }

  #image01 .frame {
    width: 10rem;
  }

  #text02 {
    letter-spacing: 0rem;
    width: 100%;
    font-size: 2.625em;
    line-height: 1.175;
  }

  #text01 {
    letter-spacing: 0rem;
    width: 100%;
    font-size: 1.25em;
    line-height: 1.55;
  }

  #divider02:not(:first-child) {
    margin-top: 0.25rem !important;
  }

  #divider02:not(:last-child) {
    margin-bottom: 0.25rem !important;
  }

  #divider02:before {
    width: 3rem;
  }

  #icons01 {
    font-size: 2em;
    gap: 2rem;
  }

  #icons01:not(:first-child) {
    margin-top: 1.78125rem !important;
  }

  #icons01:not(:last-child) {
    margin-bottom: 1.78125rem !important;
  }
}

@media (max-width: 480px) {
  #main > .inner {
    --spacing: 1.421875rem;
  }
  
  #text02 {
    font-size: 2em;
  }

  #text01 {
    font-size: 1em;
  }
}

@media (max-width: 360px) {
  #main > .inner {
    --padding-horizontal: 1.5rem;
    --padding-vertical: 2.625rem;
    --spacing: 1.21875rem;
  }

  #icons01 {
    gap: 1.5rem;
  }
}

@media(min-width: 600px) {
  .mobile_only {
    display: none;
  }
}

#icons01 li:hover {
  transform:scale(1.02);
}