/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-font-weight: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --u-font-sans: "Noto Sans JP", sans-serif;
    --u-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --u-spacing: .25rem;
    --u-font-weight-bold: 700;
    --u-radius-lg: .5rem;
    --u-default-font-family: var(--u-font-sans);
    --u-default-mono-font-family: var(--u-font-mono);
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
      -o-tab-size: 4;
         tab-size: 4;
    line-height: 1.5;
    font-family: var(--u-default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--u-default-font-feature-settings, normal);
    font-variation-settings: var(--u-default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }

  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }

  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }

  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }

  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    -webkit-text-decoration: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }

  b, strong {
    font-weight: bolder;
  }

  code, kbd, samp, pre {
    font-family: var(--u-default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--u-default-mono-font-feature-settings, normal);
    font-variation-settings: var(--u-default-mono-font-variation-settings, normal);
    font-size: 1em;
  }

  small {
    font-size: 80%;
  }

  sub, sup {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative;
  }

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.5em;
  }

  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

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

  img, svg, video, canvas, audio, iframe, embed, object {
    vertical-align: middle;
    display: block;
  }

  img, video {
    max-width: 100%;
    height: auto;
  }

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  ::file-selector-button {
    margin-inline-end: 4px;
  }

  ::-moz-placeholder {
    opacity: 1;
  }

  ::placeholder {
    opacity: 1;
  }

  @supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px) {
    ::-moz-placeholder {
      color: currentColor;
    }
    ::placeholder {
      color: currentColor;
    }

    @supports (color: color-mix(in lab, red, red)) {
      ::-moz-placeholder {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
      ::placeholder {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }

  textarea {
    resize: vertical;
  }

  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }

  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }

  ::-webkit-datetime-edit {
    display: inline-flex;
  }

  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }

  ::-webkit-datetime-edit {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }

  :-moz-ui-invalid {
    box-shadow: none;
  }

  button, input:where([type="button"], [type="reset"], [type="submit"]) {
    -webkit-appearance: button;
       -moz-appearance: button;
            appearance: button;
  }

  ::file-selector-button {
    -webkit-appearance: button;
       -moz-appearance: button;
            appearance: button;
  }

  ::-webkit-inner-spin-button {
    height: auto;
  }

  ::-webkit-outer-spin-button {
    height: auto;
  }

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }

  html {
    scroll-behavior: smooth;
    scroll-padding-top: 6.875rem;
    overflow: hidden scroll;
  }

  html:lang(zh-CN) {
    font-family: Noto Sans SC, sans-serif;
  }

  @media (max-width: 768px) {
    html {
      scroll-padding-top: 3.125rem;
    }
  }

  body {
    color: #0c141e;
    background: #e4edec;
    overflow-x: hidden;
  }

  body.is-open {
    width: 100%;
    position: fixed;
    left: 0;
  }

  a, button {
    transition: color .3s, background-color .3s, opacity .3s, border-color .3s;
  }

  :is(a, button) img {
    transition: opacity .3s;
  }
}

@layer components {
  .headingLv2 {
    text-align: center;
    margin-bottom: clamp(1.5rem, 3.12907vw, 2rem);
    font-size: clamp(2rem, 4.1721vw, 2.5rem);
    font-weight: 700;
  }

  .button {
    background: #05d1e8;
    border: 2px solid;
    border-radius: 3.875rem;
    justify-content: center;
    align-items: center;
    width: -moz-fit-content;
    width: fit-content;
    min-width: min(352px, 100% - 1rem);
    padding: 1.1875rem 1rem 1.125rem;
    font-size: 1.125rem;
    font-weight: 700;
    line-height: 1.44444;
    display: flex;
  }

  @media (hover) {
    .button:hover {
      color: #05d1e8;
      background: #0c141e;
    }
  }

  .button:focus {
    color: #05d1e8;
    background: #0c141e;
  }

  .arrowLink {
    color: #001cd2;
    padding-right: 1.75rem;
    text-decoration: underline;
    display: inline;
    position: relative;
  }

  .arrowLink:before, .arrowLink:after {
    content: "";
    height: auto;
    transition: background-color .3s, border-color .3s;
    position: absolute;
  }

  .arrowLink:before {
    aspect-ratio: 1;
    background: #05d1e8;
    border: 2px solid #0c141e;
    border-radius: 50%;
    width: 1.25rem;
    bottom: calc(.5lh - .75rem);
    right: 0;
  }

  .arrowLink:after {
    aspect-ratio: 5 / 8;
    background: #0c141e;
    width: .3125rem;
    bottom: calc(.5lh - .375rem);
    right: .4375rem;
    -webkit-mask-image: url("/glga/2027/ico_arrow01.svg");
    mask-image: url("/glga/2027/ico_arrow01.svg");
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
  }

  @media (hover) {
    .arrowLink:hover {
      text-decoration: none;
    }

    .arrowLink:hover:before {
      background: #0c141e;
      border-color: #05d1e8;
    }

    .arrowLink:hover:after {
      background: #05d1e8;
    }
  }

  .email {
    text-decoration: underline;
    display: inline-block;
  }

  @media (hover) {
    .email:hover {
      color: #05d1e8;
    }
  }

  .email i {
    font-style: normal;
  }

  .email i:after {
    content: "@";
  }
}

@layer utilities {
  .u\:sr-only {
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    border-width: 0 !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
    padding: 0 !important;
    position: absolute !important;
    overflow: hidden !important;
  }

  .u\:mx-0 {
    margin-inline: calc(var(--u-spacing) * 0) !important;
  }

  .u\:mx-auto {
    margin-inline: auto !important;
  }

  .u\:my-11 {
    margin-block: calc(var(--u-spacing) * 11) !important;
  }

  .u\:mt-1 {
    margin-top: calc(var(--u-spacing) * 1) !important;
  }

  .u\:mt-2 {
    margin-top: calc(var(--u-spacing) * 2) !important;
  }

  .u\:mt-2\.5 {
    margin-top: calc(var(--u-spacing) * 2.5) !important;
  }

  .u\:mt-10 {
    margin-top: calc(var(--u-spacing) * 10) !important;
  }

  .u\:mt-\[1lh\] {
    margin-top: 1lh !important;
  }

  .u\:block {
    display: block !important;
  }

  .u\:flex {
    display: flex !important;
  }

  .u\:inline-block {
    display: inline-block !important;
  }

  .u\:w-auto {
    width: auto !important;
  }

  .u\:flex-wrap {
    flex-wrap: wrap !important;
  }

  .u\:items-center {
    align-items: center !important;
  }

  .u\:gap-x-6 {
    -moz-column-gap: calc(var(--u-spacing) * 6) !important;
         column-gap: calc(var(--u-spacing) * 6) !important;
  }

  .u\:gap-x-10 {
    -moz-column-gap: calc(var(--u-spacing) * 10) !important;
         column-gap: calc(var(--u-spacing) * 10) !important;
  }

  .u\:gap-y-3 {
    row-gap: calc(var(--u-spacing) * 3) !important;
  }

  .u\:gap-y-4 {
    row-gap: calc(var(--u-spacing) * 4) !important;
  }

  .u\:rounded-t-none {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
  }

  .u\:py-0 {
    padding-block: calc(var(--u-spacing) * 0) !important;
  }

  .u\:text-center {
    text-align: center !important;
  }

  .u\:text-right {
    text-align: right !important;
  }

  .u\:text-\[90\%\] {
    font-size: 90% !important;
  }

  .u\:text-\[160\%\] {
    font-size: 160% !important;
  }

  .u\:font-bold {
    --tw-font-weight: var(--u-font-weight-bold) !important;
    font-weight: var(--u-font-weight-bold) !important;
  }

  @media (hover: hover) {
    .u\:hover\:underline:hover {
      text-decoration-line: underline !important;
    }

    .u\:hover\:opacity-50:hover {
      opacity: .5 !important;
    }

    .u\:hover\:opacity-70:hover {
      opacity: .7 !important;
    }
  }

  @media not all and (min-width: 1601px) {
    .u\:max-2xl\:mt-6 {
      margin-top: calc(var(--u-spacing) * 6) !important;
    }

    .u\:max-2xl\:mb-6 {
      margin-bottom: calc(var(--u-spacing) * 6) !important;
    }

    .u\:max-2xl\:ml-auto {
      margin-left: auto !important;
    }
  }

  @media not all and (min-width: 769px) {
    .u\:max-md\:mx-auto {
      margin-inline: auto !important;
    }

    .u\:max-md\:mt-6 {
      margin-top: calc(var(--u-spacing) * 6) !important;
    }

    .u\:max-md\:mb-4 {
      margin-bottom: calc(var(--u-spacing) * 4) !important;
    }

    .u\:max-md\:hidden {
      display: none !important;
    }

    .u\:max-md\:w-full {
      width: 100% !important;
    }

    .u\:max-md\:px-6 {
      padding-inline: calc(var(--u-spacing) * 6) !important;
    }

    .u\:max-md\:py-15 {
      padding-block: calc(var(--u-spacing) * 15) !important;
    }

    .u\:max-md\:pr-10 {
      padding-right: calc(var(--u-spacing) * 10) !important;
    }
  }

  @media not all and (min-width: 451px) {
    .u\:max-sm\:w-full {
      width: 100% !important;
    }

    .u\:max-sm\:flex-col {
      flex-direction: column !important;
    }
  }

  @media (min-width: 451px) {
    .u\:sm\:mt-2 {
      margin-top: calc(var(--u-spacing) * 2) !important;
    }

    .u\:sm\:w-\[5em\] {
      width: 5em !important;
    }

    .u\:sm\:text-center {
      text-align: center !important;
    }
  }

  @media (min-width: 769px) {
    .u\:md\:absolute {
      position: absolute !important;
    }

    .u\:md\:block {
      display: block !important;
    }

    .u\:md\:hidden {
      display: none !important;
    }

    .u\:md\:max-w-\[30vw\] {
      max-width: 30vw !important;
    }

    .u\:md\:min-w-\[253px\] {
      min-width: 253px !important;
    }
  }

  @media (min-width: 1601px) {
    .u\:2xl\:absolute {
      position: absolute !important;
    }
  }

  @media (min-width: 1841px) {
    .u\:3xl\:ml-\[-10px\] {
      margin-left: -10px !important;
    }

    .u\:3xl\:rounded-\[8px\] {
      border-radius: 8px !important;
    }

    .u\:3xl\:rounded-b-lg {
      border-bottom-right-radius: var(--u-radius-lg) !important;
      border-bottom-left-radius: var(--u-radius-lg) !important;
    }
  }
}

@layer animation {
  @keyframes nav-before01 {
    0% {
      transform: rotate(0);
    }

    50% {
      transform: translateY(.4375rem);
    }

    100% {
      transform: translateY(0);
    }
  }

  @keyframes nav-after01 {
    0% {
      transform: rotate(0);
    }

    50% {
      transform: translateY(-.4375rem);
    }

    100% {
      transform: translateY(0);
    }
  }

  @keyframes nav-before02 {
    0% {
      transform: rotate(0);
    }

    50% {
      top: 50%;
      transform: rotate(0);
    }

    100% {
      top: 50%;
      transform: translateY(-50%) rotate(45deg);
    }
  }

  @keyframes nav-after02 {
    0% {
      transform: rotate(0);
    }

    50% {
      bottom: 50%;
      transform: rotate(0);
    }

    100% {
      bottom: 50%;
      transform: translateY(50%) rotate(-45deg);
    }
  }
}

@layer layout {
  header {
    z-index: 2;
    background: #e4edec;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
  }

  header .inner {
    justify-content: space-between;
    align-items: center;
    gap: clamp(20px, 2.60756vw, 44px);
    max-width: 1880px;
    padding: 1.375rem clamp(16px, 2.08605vw, 20px) 1.3125rem;
    display: flex;
  }

  @media (max-width: 768px) {
    header .inner {
      padding-top: 0;
      padding-bottom: 0;
      padding-right: 0;
    }
  }

  header .logo {
    width: clamp(140px, 18.2529vw, 218px);
  }

  header .links {
    align-items: center;
    gap: clamp(24px, 3.12907vw, 44px);
    display: flex;
  }

  header .langList {
    align-items: center;
    gap: clamp(12px, 1.56454vw, 30px);
    display: flex;
  }

  header .langItem a {
    padding-block: 7px 12px;
    display: block;
    position: relative;
  }

  header .langItem a:before {
    content: "";
    background: #8200cc;
    width: 0;
    height: 3px;
    transition: width .3s;
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
  }

  header .langItem a[aria-current="page"]:before {
    width: 100%;
  }

  header .langItem a:not([href]) img {
    filter: opacity(55%);
  }

  @media (hover) {
    header .langItem a[href]:hover:before {
      width: 100%;
    }
  }

  @media (max-width: 768px) {
    header .navButton {
      aspect-ratio: 1;
      cursor: pointer;
      background: #0c141e;
      border: 2px solid #0c141e;
      place-content: center;
      width: 3.125rem;
      height: auto;
      display: grid;
    }

    header .navButton span {
      background: #05d1e8;
      width: 1.5625rem;
      height: 2px;
    }

    header .navButton span:before, header .navButton span:after {
      content: "";
      background: #05d1e8;
      width: 1.5625rem;
      height: 2px;
      transition: background-color .3s;
      display: block;
      position: absolute;
    }

    header .navButton span:before {
      animation: .75s nav-before01;
      top: 1rem;
    }

    header .navButton span:after {
      animation: .75s nav-after01;
      bottom: 1rem;
    }

    header .navButton[aria-expanded="true"] {
      background: #05d1e8;
    }

    header .navButton[aria-expanded="true"] span {
      background: none;
    }

    header .navButton[aria-expanded="true"] span:before {
      background: #0c141e;
      animation: .75s forwards nav-before02;
    }

    header .navButton[aria-expanded="true"] span:after {
      background: #0c141e;
      animation: .75s forwards nav-after02;
    }

    header .nav {
      z-index: 1;
      background: #e4edec;
      width: 100%;
      max-height: calc(100svh - 3.125rem);
      transition: left .5s;
      display: none;
      position: absolute;
      top: 3.125rem;
      left: 100%;
      overflow-y: auto;
    }

    header .nav.is-active {
      left: 0;
    }

    header .overlay {
      opacity: .3;
      background: #0c141e;
      width: 100%;
      height: 100svh;
      display: none;
      position: absolute;
      top: 3.125rem;
      left: 0;
    }

    header .menuList a {
      background: #afced1;
      border-bottom: 1px solid #fff;
      padding: 1rem;
      font-size: 1.125rem;
      font-weight: 700;
      display: block;
    }

    header .cta {
      background: #0c141e;
      padding: 1.5rem;
    }

    header .button {
      margin-inline: auto;
    }
  }

  main {
    padding-block: 6.875rem 2.5rem;
  }

  @media (max-width: 768px) {
    main {
      padding-block: 3.125rem 0;
    }
  }

  footer {
    background: #fff;
  }

  footer .fixedContent {
    z-index: 1;
    position: fixed;
    bottom: 0;
    right: 0;
  }

  footer .pagetop {
    aspect-ratio: 1;
    background: #0c141e;
    border: 2px solid #05d1e8;
    border-radius: 2px;
    place-content: center;
    width: clamp(2.5rem, 5.21512vw, 3.75rem);
    height: auto;
    margin: 10px 10px 10px auto;
    display: grid;
  }

  footer .pagetop:before {
    aspect-ratio: 8 / 16;
    content: "";
    background: #05d1e8;
    width: clamp(.375rem, .782269vw, .5rem);
    height: auto;
    transition: background-color .3s;
    display: block;
    transform: rotate(90deg);
    -webkit-mask-image: url("/glga/2027/ico_arrow02.svg");
    mask-image: url("/glga/2027/ico_arrow02.svg");
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
  }

  @media (hover) {
    footer .pagetop:hover {
      background: #05d1e8;
      border-color: #0c141e;
    }

    footer .pagetop:hover:before {
      background: #0c141e;
    }
  }

  footer .pagetop:focus {
    background: #05d1e8;
    border-color: #0c141e;
  }

  footer .pagetop:focus:before {
    background: #0c141e;
  }

  footer .content {
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1.25rem 2.5rem;
    padding-block: 2.5rem;
    display: flex;
  }

  footer .nav {
    flex-wrap: wrap;
    align-items: center;
    gap: 1.25rem 2.5rem;
    display: flex;
  }

  footer .menuList {
    flex-wrap: wrap;
    gap: 1rem 1.25rem;
    display: flex;
  }

  footer .menuItem {
    border-right: 1px solid #cdcdcd;
    padding-right: 1.25rem;
    font-size: .875rem;
    font-weight: 700;
    line-height: 1;
  }

  footer .menuItem:last-child {
    border: none;
  }

  footer .copyright {
    font-size: .75rem;
    font-weight: 500;
    line-height: 1.5;
  }

  .inner {
    max-width: 1840px;
    margin-inline: auto;
  }

  .content {
    max-width: 1160px;
    margin-inline: auto;
    padding: clamp(2.5rem, 5.21512vw, 6.25rem) clamp(16px, 2.08605vw, 20px);
  }

  .content.-sm {
    max-width: 987px;
  }

  .content.-lg {
    max-width: 1680px;
  }
}

@layer project {
  .mv {
    padding-block: clamp(3.375rem, 7.04042vw, 4.5rem) clamp(2.5rem, 5.21512vw, 2.0625rem);
  }

  .mv .content {
    grid-template-columns: 42% 48%;
    justify-content: space-between;
    align-items: center;
    row-gap: 3.125rem;
    display: grid;
  }

  @media (max-width: 1024px) {
    .mv .content {
      grid-template-columns: auto;
      justify-content: center;
    }
  }

  .mv .lead {
    font-size: clamp(1.25rem, 2.60756vw, 1.5625rem);
    font-weight: 700;
    line-height: 1.44;
  }

  .mv .info {
    flex-wrap: wrap;
    align-items: center;
    gap: clamp(1.5rem, 3.12907vw, 2rem);
    margin-top: clamp(1.5625rem, 3.25945vw, 2.5rem);
    display: flex;
  }

  .mv .venue {
    color: #c4f9ff;
    text-align: center;
    background: #0c141e;
    border-radius: 4px;
    width: 12.25rem;
    padding: .25rem 1rem;
    font-size: clamp(1.5rem, 3.12907vw, 1.875rem);
    font-weight: 700;
    line-height: 1;
  }

  .mv .row {
    align-items: start;
    width: 100%;
    display: grid;
  }

  @media (min-width: 451px) {
    .mv .row {
      grid-template-columns: auto 1fr;
    }
  }

  .mv .row dt {
    border-top: 2px solid;
    padding: .25rem clamp(.5rem, 1.04302vw, .875rem) .5rem;
    font-size: clamp(1rem, 2.08605vw, 1.25rem);
    font-weight: 700;
    line-height: 1.5;
    position: relative;
  }

  @media (min-width: 451px) {
    .mv .row dt {
      border-top: none;
      border-left: 4px solid;
      padding-block: 0;
    }

    .mv .row dt:after {
      content: "";
      background: #0c141e;
      width: 1px;
      height: 66.6667%;
      display: block;
      position: absolute;
      top: 50%;
      right: 0;
      transform: translateY(-50%);
    }
  }

  .mv .row dd {
    border-top: 1px solid;
    padding-block: .25rem .5rem;
    font-size: clamp(1.125rem, 2.34681vw, 1.375rem);
    font-weight: 500;
    line-height: 1.36364;
  }

  @media (min-width: 451px) {
    .mv .row dd {
      padding-block: 0;
      border-top: none;
      padding-left: clamp(.5rem, 1.04302vw, .875rem);
      transform: translateY(-2px);
    }
  }

  .mv .image {
    margin-top: clamp(2.5rem, 5.21512vw, 5.25rem);
    position: relative;
  }

  .mv .image .-deco1 {
    top: 48.5%;
    left: -36px;
  }

  .mv .image .-deco2 {
    top: 37%;
    left: 49%;
  }

  .mv .image .-deco3 {
    bottom: 15%;
    right: -17px;
  }

  .message {
    background: #d0e0e2;
    position: relative;
  }

  .message .-deco1 {
    top: 14.5%;
    left: 3.3%;
  }

  .message .-deco2 {
    bottom: 34%;
    right: 1.5%;
  }

  .message .content p {
    z-index: 1;
    margin-inline: clamp(.5rem, 1.04302vw, .625rem);
    font-size: clamp(1.125rem, 2.34681vw, 1.25rem);
    line-height: 2.4;
    position: relative;
  }

  .overview .list {
    font-size: clamp(1.125rem, 2.34681vw, 1.25rem);
    font-weight: 500;
    line-height: 1.5;
    display: grid;
  }

  @media (min-width: 769px) {
    .overview .list {
      grid-template-columns: 10.5rem 1fr;
    }

    .overview .list:lang(en) {
      grid-template-columns: 15rem 1fr;
    }

    .overview .list:lang(zh-CN) {
      grid-template-columns: 12.5rem 1fr;
    }
  }

  .overview .list dt, .overview .list dd {
    border-top: 1px solid #bbb;
    align-content: center;
    padding: 1rem .5rem;
  }

  :is(.overview .list dt, .overview .list dd):last-of-type {
    border-bottom: 1px solid #bbb;
  }

  @media (max-width: 768px) {
    .overview .list dt {
      padding: 1rem 0 .5rem;
    }

    .overview .list dt:last-of-type {
      border-bottom: none;
    }

    .overview .list dd {
      border: none;
      padding: 0 0 1rem;
    }
  }

  .inquiry {
    background: url("/glga/2027/bg_inquiry.jpg") center / cover no-repeat;
  }

  @media (max-width: 768px) {
    .inquiry {
      background-image: url("/glga/2027/bg_inquiry__sp.jpg");
    }
  }

  .inquiry .lead {
    color: #afced1;
    text-align: center;
    font-size: clamp(1rem, 2.08605vw, 1.125rem);
    font-weight: 500;
    line-height: 1.8;
  }

  .inquiry .headingLv2 {
    color: #fff;
    margin-bottom: 1rem;
    font-size: clamp(1.625rem, 3.38983vw, 2.25rem);
    font-weight: 500;
  }

  .inquiry .contact {
    color: #fff;
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(1.5rem, 3.12907vw, 2.5rem);
    font-size: clamp(1.125rem, 2.34681vw, 1.5rem);
    display: flex;
  }

  .inquiry .data {
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-end;
    gap: clamp(.5rem, 1.04302vw, .625rem);
    display: flex;
  }

  .inquiry .label {
    text-align: center;
    background: #0c141e;
    border: 1px solid #fff;
    border-radius: 4px;
    padding: .25rem 1.375rem;
    font-size: 1rem;
    line-height: 1.5;
    display: inline-block;
  }

  @media (max-width: 450px) {
    .inquiry .label {
      width: min(400px, 100%);
    }
  }
}

@layer bp {
  .bpPrivacy {
    color: #000;
    background: #fff;
    border-top: 4px solid #1e4d84;
    width: 440px;
    margin-top: 10px;
    padding: 16px;
    display: none;
    box-shadow: 0 2px 8px #0000003d;
  }

  .bpPrivacy_message {
    font-size: 14px;
    font-weight: 500;
    line-height: 1.65;
  }

  .bpPrivacy_buttons {
    justify-content: flex-end;
    margin-top: 12px;
    display: flex;
  }

  .bpPrivacy_button-detail, .bpPrivacy_button-close {
    white-space: nowrap;
    vertical-align: bottom;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
         user-select: none;
    justify-content: center;
    align-items: center;
    height: 40px;
    padding: 0 12px;
    font-size: 14px;
    line-height: 1.65;
    text-decoration: none;
    display: inline-flex;
  }

  .bpPrivacy_button-detail {
    color: #333;
    background-color: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 2px;
    font-weight: 500;
  }

  .bpPrivacy_button-detail:hover {
    background-color: #3333330f;
  }

  .bpPrivacy_button-close {
    color: #fff;
    background-color: #0068bc;
    border: none;
    margin-left: 15px;
    font-weight: 700;
  }

  .bpPrivacy_button-close:hover {
    background-color: #0076d6e6;
  }

  @media (max-width: 768px) {
    .bpPrivacy {
      z-index: 100;
      width: 100%;
      margin-top: 1rem;
      padding: 16px 16px 20px;
      display: none;
      bottom: 0;
      left: 0;
      box-shadow: 0 0 5px #0000003d;
    }

    .bpPrivacy_message {
      font-size: 14px;
      font-weight: 400;
      line-height: 1.65;
    }

    .bpPrivacy_buttons {
      justify-content: flex-end;
      margin-top: 10px;
      display: flex;
    }

    .bpPrivacy_button-detail, .bpPrivacy_button-close {
      white-space: nowrap;
      vertical-align: bottom;
      cursor: pointer;
      -webkit-user-select: none;
      -moz-user-select: none;
           user-select: none;
      justify-content: center;
      align-items: center;
      height: 40px;
      padding: 0 12px;
      font-size: 14px;
      line-height: 1.65;
      text-decoration: none;
      display: inline-flex;
    }

    .bpPrivacy_button-detail {
      color: #333;
      background-color: #fff;
      border: 1px solid #e8e8e8;
      border-radius: 2px;
      font-weight: 500;
    }

    .bpPrivacy_button-detail:hover {
      background-color: #3333330f;
    }

    .bpPrivacy_button-close {
      color: #fff;
      background-color: #0068bc;
      border: none;
      margin-left: 15px;
      font-weight: 700;
    }

    .bpPrivacy_button-close:hover {
      background-color: #0076d6e6;
    }
  }
}

@property --tw-font-weight {
  syntax: "*";
  inherits: false
}
