@charset "utf-8";
* {
/* Remove default margin on everything */
  margin: 0;
/* Remove default padding on everything */
  padding: 0;
/* Calc `em` based line height, bigger line height for smaller font size and smaller line height for bigger font size: https://kittygiraudel.com/2020/05/18/using-calc-to-figure-out-optimal-line-height/ */
}
*,
::before,
::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
*:where(:not(fieldset,
progress,
meter)) {
  border-width: 0;
  border-style: solid;
  background-origin: border-box;
  background-repeat: no-repeat;
}
html {
/* Allow percentage-based heights in the application */
  block-size: 100%;
/* Making sure text size is only controlled by font-size */
  -webkit-text-size-adjust: none;
}
@media (prefers-reduced-motion: no-preference) {
  html:focus-within {
    scroll-behavior: smooth;
  }
}
body {
/* https://marco.org/2012/11/15/text-rendering-optimize-legibility */
  text-rendering: optimizeSpeed;
/* Allow percentage-based heights in the application */
  min-block-size: 100%;
/* https://developer.mozilla.org/en-US/docs/Web/CSS/scrollbar-gutter#example_2 */
/* scrollbar-gutter: stable both-edges; Removed until this bug is fixed: https://bugs.chromium.org/p/chromium/issues/detail?id=1318404#c2 */
}
:where(img,
svg,
video,
canvas,
audio,
iframe,
embed,
object) {
  display: block;
}
:where(img,
svg,
video) {
  block-size: auto;
  max-inline-size: 100%;
}
:where(svg) {
  stroke: none;
  fill: currentColor;
}
:where(svg):where(:not([fill])) {
/* Remove fill and set stroke colour to the inherited font colour */
  stroke: currentColor;
  fill: none;
/* Rounded stroke */
  stroke-linecap: round;
  stroke-linejoin: round;
}
:where(svg):where(:not([width])) {
  inline-size: 5rem;
}
:where(input,
button,
textarea,
select),
:where(input[type="file"])::-webkit-file-upload-button {
  color: inherit;
  font: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  word-spacing: inherit;
}
:where(textarea) {
  resize: vertical;
}
@supports (resize: block) {
  :where(textarea) {
    resize: block;
  }
}
:where(p,
h1,
h2,
h3,
h4,
h5,
h6) {
  overflow-wrap: break-word;
}
h1 {
  font-size: 2em;
}
:where(ul,
ol) {
  list-style-position: inside;
}
:where(ul,
ol)[role="list"] {
  list-style: none;
}
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}
:where(a[href],
area,
button,
input,
label[for],
select,
summary,
textarea,
[tabindex]:not([tabindex*="-"])) {
  cursor: pointer;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}
:where(input[type="file"]) {
  cursor: auto;
}
:where(input[type="file"])::-webkit-file-upload-button {
  cursor: pointer;
}
:where(input[type="file"])::-webkit-file-upload-button,
:where(input[type="file"])::file-selector-button {
  cursor: pointer;
}
@media (prefers-reduced-motion: no-preference) {
  :focus-visible {
    -webkit-transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
    transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
  }
  :where(:not(:active)):focus-visible {
    -webkit-transition-duration: 0.25s;
            transition-duration: 0.25s;
  }
}
:where(:not(:active)):focus-visible {
  outline-offset: 5px;
}
:where(input[type="file"])::-webkit-file-upload-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
          user-select: none;
  text-align: center;
}
:where(button,
button[type],
input[type="button"],
input[type="submit"],
input[type="reset"]),
:where(input[type="file"])::-webkit-file-upload-button,
:where(input[type="file"])::file-selector-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
          user-select: none;
  text-align: center;
}
:where(button,
button[type],
input[type="button"],
input[type="submit"],
input[type="reset"])[disabled] {
  cursor: not-allowed;
}
@font-face {
  font-family: 'Noto Sans JP';
  src: url("../fonts/NotoSansJP-VariableFont_wght.ttf");
  font-weight: 400;
}
@font-face {
  font-family: 'Noto Sans JP';
  src: url("../fonts/NotoSansJP-VariableFont_wght.ttf");
  font-weight: 700;
}
* {
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  -webkit-touch-callout: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
html {
  font-size: 62.5%;
  height: 100%;
  scroll-behavior: smooth;
}
body {
  font-size: 1.4rem;
  font-weight: 400;
  height: 100%;
  background: #fff;
  color: #000;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
}
ul {
  list-style: none;
}
input,
button,
select,
textarea {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
a:not(:disabled),
button:not(:disabled),
select:not(:disabled),
input[type=submit]:not(:disabled),
input[type=button]:not(:disabled),
input[type=reset]:not(:disabled),
input[type=file]:not(:disabled),
input[type=radio]:not(:disabled),
input[type=checkbox]:not(:disabled),
label[for]:not(:disabled) {
  cursor: pointer;
}
*:disabled,
*.is-disabled {
  pointer-events: none;
}
*[readOnly] {
  cursor: not-allowed !important;
}
em {
  font-style: normal;
}
::-ms-reveal {
  display: none;
}
.l-container {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  width: 100%;
  height: 100vh;
  font-family: 'Noto Sans JP', sans-serif;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: 70px 1fr 24px;
  grid-template-rows: 70px 1fr 24px;
  min-width: 1280px;
}
.l-header {
  position: relative;
  width: 100%;
  height: 70px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.l-header__inner {
  padding: 0 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
  width: 100%;
}
.l-header__inner h1 {
  color: #000;
  font-size: 2.8rem;
  font-weight: 900;
}
.l-footer {
  position: relative;
  width: 100%;
  background: #2c3642;
  color: #f2f2f2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 24px;
}
.l-footer__inner {
  text-align: center;
}
.l-footer__inner p {
  font-size: 1.2rem;
}
.l-main {
  position: relative;
  background: #fff;
  overflow: hidden;
  text-align: left;
  width: 100%;
}
.l-main--error {
  background: #f2f2f2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.l-main__inner {
  width: 100%;
  height: 100%;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[2];
  grid-template-columns: repeat(2, 1fr);
  -ms-grid-rows: (1fr)[2];
  grid-template-rows: repeat(2, 1fr);
}
.l-main__inner > *:nth-child(1) {
-ms-grid-row: 1;
-ms-grid-column: 1;
}
.l-main__inner > *:nth-child(2) {
-ms-grid-row: 1;
-ms-grid-column: 2;
}
.l-main__inner > *:nth-child(3) {
-ms-grid-row: 2;
-ms-grid-column: 1;
}
.l-main__inner > *:nth-child(4) {
-ms-grid-row: 2;
-ms-grid-column: 2;
}
.c-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-decoration: none;
  text-align: center;
  line-height: 1.4;
  overflow: hidden;
  font-family: 'Noto Sans JP', sans-serif;
}
.c-button {
  border-radius: 8px;
  font-size: clamp(1.2rem, 1.3vw, 2rem);
  background: #fff;
  color: #000;
  padding: 0.5em;
  aspect-ratio: 16/5;
  width: clamp(160px, 15vw, 260px);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.c-button:active {
  -webkit-transform: translate(0, 0.15em);
          transform: translate(0, 0.15em);
}
.c-button--primary {
  -webkit-box-shadow: 0px 0px 10px 0px #3160ad;
          box-shadow: 0px 0px 10px 0px #3160ad;
}
.c-button--primary:hover {
  background: #3160ad;
  color: #fff;
}
.c-button--secondary {
  -webkit-box-shadow: 0px 0px 10px 0px #f9e987;
          box-shadow: 0px 0px 10px 0px #f9e987;
}
.c-button--secondary:hover {
  background: #f9e987;
}
.c-button--tertiary {
  -webkit-box-shadow: 0px 0px 10px 0px #91cfdb;
          box-shadow: 0px 0px 10px 0px #91cfdb;
}
.c-button--tertiary:hover {
  background: #91cfdb;
  color: #fff;
}
.c-button--quaternary {
  -webkit-box-shadow: 0px 0px 10px 0px #bdbdbd;
          box-shadow: 0px 0px 10px 0px #bdbdbd;
}
.c-button--quaternary:hover {
  background: #bdbdbd;
}
.c-button__wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0.5em 2em;
}
.c-button-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 3vw 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 3vw;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-error {
  color: #000;
  text-align: center;
  display: -ms-grid;
  display: grid;
  place-content: center;
  place-items: center;
  gap: 32px;
}
.c-error-title {
  font-size: 4.4rem;
  font-weight: 700;
}
.c-error-text {
  font-size: 2rem;
}
.c-logo {
  position: relative;
  display: block;
  width: 39px;
}
.c-section {
  position: relative;
  width: 100%;
  background: rgba(250,247,249,0.98);
  border-width: 12px;
  border-style: solid;
  overflow-y: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-section--primary {
  border-color: #3160ad;
}
.c-section--secondary {
  border-color: #f9e987;
}
.c-section--tertiary {
  border-color: #91cfdb;
}
.c-section--quaternary {
  border-color: #bdbdbd;
}
.c-section__wrap {
  position: relative;
  height: 100%;
  display: -ms-grid;
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1em;
}
.c-tooltip {
  display: none;
}
.tippy-content {
  padding: 1.5em;
  font-size: 1.1rem;
  line-height: 1.6;
}
@media print {
  * html body {
    zoom: 0.7;
  }
  body {
    -webkit-print-color-adjust: exact;
  }
}
