/*
! tailwindcss v3.3.3 | MIT License | https://tailwindcss.com
*/

/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box;
  /* 1 */
  border-width: 0;
  /* 2 */
  border-style: solid;
  /* 2 */
  border-color: #e5e7eb;
  /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
*/

html {
  line-height: 1.5;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -moz-tab-size: 4;
  /* 3 */
  -o-tab-size: 4;
     tab-size: 4;
  /* 3 */
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  /* 4 */
  font-feature-settings: normal;
  /* 5 */
  font-variation-settings: normal;
  /* 6 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0;
  /* 1 */
  line-height: inherit;
  /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0;
  /* 1 */
  color: inherit;
  /* 2 */
  border-top-width: 1px;
  /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

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

/*
Remove the default font size and weight for headings.
*/

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

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

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

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font family by default.
2. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0;
  /* 1 */
  border-color: inherit;
  /* 2 */
  border-collapse: collapse;
  /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-feature-settings: inherit;
  /* 1 */
  font-variation-settings: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  font-weight: inherit;
  /* 1 */
  line-height: inherit;
  /* 1 */
  color: inherit;
  /* 1 */
  margin: 0;
  /* 2 */
  padding: 0;
  /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
[type='button'],
[type='reset'],
[type='submit'] {
  -webkit-appearance: button;
  /* 1 */
  background-color: transparent;
  /* 2 */
  background-image: none;
  /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

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

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

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

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

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

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

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

/*
Reset default styling for dialogs.
*/

dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1;
  /* 1 */
  color: #9ca3af;
  /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1;
  /* 1 */
  color: #9ca3af;
  /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/

:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

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

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

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

/* Make elements with the HTML hidden attribute stay hidden by default */

[hidden] {
  display: none;
}

*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
}

.container {
  width: 100%;
}

@media (min-width: 640px) {
  .container {
    max-width: 640px;
  }
}

@media (min-width: 768px) {
  .container {
    max-width: 768px;
  }
}

@media (min-width: 1024px) {
  .container {
    max-width: 1024px;
  }
}

@media (min-width: 1280px) {
  .container {
    max-width: 1280px;
  }
}

@media (min-width: 1440px) {
  .container {
    max-width: 1440px;
  }
}

@media (min-width: 1536px) {
  .container {
    max-width: 1536px;
  }
}

body {
  --tw-bg-opacity: 1;
  background-color: rgb(245 247 251 / var(--tw-bg-opacity));
  font-size: 0.8125rem;
  line-height: 1.125rem;
  line-height: 1.75;
  letter-spacing: 0em;
}

@media (min-width: 640px) {
  body {
    font-size: 0.875rem;
    line-height: 1.25rem;
    line-height: 1.75;
  }
}

@media (min-width: 768px) {
  body {
    font-size: 1rem;
    line-height: 1.5rem;
    line-height: 1.75;
  }
}

body {
  /*-----------Memo　モノトーン基準を　Slateか　grayか　grayか　あとで絞る*/
}

/*
  body.sitetop #news .container {
    @apply max-w-screen-xxl;
  }
  body.category2nd .container {
    @apply max-w-3xl mx-auto xl:max-w-screen-xl;
  }
*/

/*----------------------
  header --> common.css
----------------------*/

/*----------------------
  footer
----------------------*/

/*footer {
    @apply bg-neutral-800;-----common.css
  }*/

/*nav*/

footer .gr_footer_nav_area {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  padding: 2rem;
}

@media (min-width: 1024px) {
  footer .gr_footer_nav_area {
    max-width: 1920px;
  }
}

footer a.footer_site_name {
  margin-bottom: 1rem;
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  --tw-text-opacity: 1;
  color: rgb(250 250 250 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  footer a.footer_site_name {
    margin-bottom: 0px;
    flex-direction: row;
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}

footer img.footer_site_logo {
  margin-left: auto;
  margin-right: auto;
  width: 33.333333%;
  max-width: 128px;
  opacity: 0.9;
}

@media (min-width: 1024px) {
  footer img.footer_site_logo {
    margin-left: 0px;
    margin-right: 0px;
    width: 50%;
    max-width: 192px;
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

footer .navBox {
  /*@apply flex flex-col flex-wrap md:flex-row md:flex-nowrap justify-between;*/
  position: relative;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  max-width: 1440px;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
  padding-bottom: 24rem;
}

@media (min-width: 640px) {
  footer .navBox {
    padding-bottom: 20rem;
  }
}

@media (min-width: 1024px) {
  footer .navBox {
    padding-bottom: 4rem;
  }
}

@media (min-width: 1280px) {
  footer .navBox {
    padding-bottom: 0px;
  }
}

footer .gr_footer_nav_area .bnrBox {
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 1024px;
}

@media (min-width: 1024px) {
  footer .gr_footer_nav_area .bnrBox {
    top: 12rem;
    left: auto;
    right: 0.5rem;
    width: 41.666667%;
  }
}

@media (min-width: 1280px) {
  footer .gr_footer_nav_area .bnrBox {
    right: 0px;
    top: auto;
    width: 55.555555%;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
}

footer .gr_footer_nav_area .bnrBox p.title {
  display: block;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 1.5rem;
  padding-bottom: 0.5rem;
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media (min-width: 1024px) {
  footer .gr_footer_nav_area .bnrBox p.title {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    text-align: left;
  }
}

footer .gr_footer_nav_area .bnrBox p.title span.num {
  --tw-text-opacity: 1;
  color: rgb(112 136 191 / var(--tw-text-opacity));
}

footer .gr_footer_nav_area .bnrBox ul.bnr {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

@media (min-width: 640px) {
  footer .gr_footer_nav_area .bnrBox ul.bnr {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  footer .gr_footer_nav_area .bnrBox ul.bnr {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1280px) {
  footer .gr_footer_nav_area .bnrBox ul.bnr {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

footer .gr_footer_nav_area .bnrBox ul.bnr li a {
  display: block;
  height: 100%;
  border-radius: 0.25rem;
  text-align: center;
  opacity: 0.9;
  background-blend-mode: screen;
}

footer .gr_footer_nav_area .bnrBox ul.bnr li a:hover {
  opacity: 1;
  background-blend-mode: hard-light;
}

footer .gr_footer_nav_area .bnrBox ul.bnr li a img {
  width: 100%;
  border-radius: 0.25rem;
  -o-object-fit: cover;
     object-fit: cover;
}

footer .gr_footer_nav_area .bnrBox ul.bnr li a span.bnr_name {
  display: inline-block;
  font-size: 0.625rem;
  line-height: 1rem;
  font-weight: 400;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  footer .gr_footer_nav_area .bnrBox ul.bnr li a span.bnr_name {
    font-size: 0.75rem;
    line-height: 1rem;
  }
}

footer ul.gr_cmn_nav {
  display: grid;
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media (min-width: 1024px) {
  footer ul.gr_cmn_nav {
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.5rem;
  }
}

@media (min-width: 1280px) {
  footer ul.gr_cmn_nav {
    grid-template-columns: repeat(9, minmax(0, 1fr));
  }
}

footer ul.gr_cmn_nav {
  /*ガイド*/
}

footer ul.gr_cmn_nav > li:first-child {
  grid-column: span 2 / span 2;
}

/**/

footer ul.gr_cmn_nav > li {
  border-top-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(82 82 82 / var(--tw-border-opacity));
  text-align: center;
}

@media (min-width: 1024px) {
  footer ul.gr_cmn_nav > li {
    grid-column: span 2 / span 2;
    border-top-width: 0px;
    text-align: left;
  }

  footer ul.gr_cmn_nav > li a {
    grid-column: span 2 / span 2;
  }

  footer ul.gr_cmn_nav > li.single {
    grid-column: span 1 / span 1;
  }
}

footer ul.gr_cmn_nav > li.single a {
  --tw-text-opacity: 1;
  color: rgb(250 250 250 / var(--tw-text-opacity));
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

footer ul.gr_cmn_nav > li.single a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

/*
  footer ul.gr_cmn_nav > li.single a:hover span.num {
    @apply text-green-200;
  }
*/

footer .gr_cmn_nav_item {
  display: block;
  width: 100%;
  padding: 0.5rem;
}

@media (min-width: 1024px) {
  footer .gr_cmn_nav_item {
    padding: 1rem;
  }
}

footer p.gr_cmn_nav_item {
  padding-bottom: 0px;
}

footer .gr_cmn_nav_item span.num {
  margin-left: 0.125rem;
  margin-top: 0.25rem;
  display: block;
  --tw-text-opacity: 1;
  color: rgb(112 136 191 / var(--tw-text-opacity));
}

footer .gr_cmn_nav_item span.category_title {
  display: none;
}

footer div.gr_mm_content img {
  display: none;
}

/*
  footer ul.gr_mm_inner {
    @apply ;
  }
  */

footer ul.gr_mm_inner li {
  display: none;
}

@media (min-width: 1024px) {
  footer ul.gr_mm_inner li {
    display: block;
  }
}

/*
  footer ul.gr_mm_inner li:last-child {
    @apply ;
  }*/

footer ul.gr_mm_inner li a {
  display: block;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  padding-right: 1rem;
  --tw-text-opacity: 1;
  color: rgb(250 250 250 / var(--tw-text-opacity));
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

footer ul.gr_mm_inner li a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

footer ul.gr_mm_inner li div.no_link {
  display: block;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  padding-right: 1rem;
  --tw-text-opacity: 1;
  color: rgb(250 250 250 / var(--tw-text-opacity));
}

footer ul.gr_mm_inner li.category_top {
  margin-top: -0.5rem;
  display: block;
  border-width: 0px;
  border-style: solid;
  --tw-border-opacity: 1;
  border-color: rgb(82 82 82 / var(--tw-border-opacity));
  padding-top: 0px;
  font-weight: 500;
}

@media (min-width: 640px) {
  footer ul.gr_mm_inner li.category_top {
    grid-column: span 2 / span 2;
  }
}

@media (min-width: 1024px) {
  footer ul.gr_mm_inner li.category_top {
    margin-bottom: 1rem;
    border-bottom-width: 1px;
    padding-bottom: 0.5rem;
  }
}

@media (min-width: 1280px) {
  footer ul.gr_mm_inner li.category_top {
    grid-column: span 3 / span 3;
  }
}

footer ul.gr_mm_inner li.category_top a {
  margin-left: -0.5rem;
  --tw-text-opacity: 1;
  color: rgb(250 250 250 / var(--tw-text-opacity));
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

footer ul.gr_mm_inner li.category_top a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  footer ul.gr_mm_inner li.category_top a {
    margin-left: 0px;
    display: inline-block;
    min-width: 33.333333%;
  }
}

footer ul.gr_mm_inner li.category_top span.category_top_mark {
  display: none;
}

footer ul.gr_mm_inner li ul {
  margin-bottom: 0.5rem;
  display: none;
}

/*
  footer ul.gr_mm_inner li ul li {
    @apply ;
  }

  footer ul.gr_mm_inner li ul li:first-child {
    @apply ;
  }
  */

footer ul.gr_mm_inner li ul li:last-child {
  border-bottom-width: 0px;
}

footer ul.gr_mm_inner li ul li a {
  padding: 0.25rem;
  font-size: 0.75rem;
  line-height: 1rem;
}

body.footer_nav_none > footer ul.gr_cmn_nav {
  /*sitemap.html*/
  display: none;
}

body.footer_nav_none > footer div.bnrBox {
  /*sitemap.html*/
  display: none;
}

/*group_link*/

footer .gr_footer_group {
  --tw-bg-opacity: 1;
  background-color: rgb(213 222 238 / var(--tw-bg-opacity));
}

footer .groupBox {
  margin-left: auto;
  margin-right: auto;
  padding: 1rem;
}

@media (min-width: 1024px) {
  footer .groupBox {
    max-width: 1920px;
  }
}

/*
  footer .gr_footer_group_title {
    @apply text-md text-center bg-blue-700 py-1 text-white;
  }
  */

footer ul.group {
  display: flex;
  flex-wrap: wrap;
}

footer ul.group li {
  width: 50%;
  padding: 0.5rem;
  text-align: center;
}

@media (min-width: 640px) {
  footer ul.group li {
    width: 33.333333%;
  }
}

@media (min-width: 1280px) {
  footer ul.group li {
    width: 25%;
  }
}

@media (min-width: 1440px) {
  footer ul.group li {
    width: 16.666667%;
  }
}

footer ul.group li a {
  display: block;
  height: 100%;
  border-radius: 0.25rem;
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity));
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  padding-right: 1rem;
}

footer ul.group li a:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

footer ul.group li a img.company_logo {
  margin-left: auto;
  margin-right: auto;
  margin-top: 0.25rem;
  height: 2rem;
}

footer ul.group li a span.company_name {
  display: inline-block;
  font-size: 0.625rem;
  line-height: 1rem;
}

@media (min-width: 1024px) {
  footer ul.group li a span.company_name {
    font-size: 0.75rem;
    line-height: 1rem;
  }
}

/*policy_link*/

footer .gr_footer_policy {
  --tw-bg-opacity: 1;
  background-color: rgb(23 23 23 / var(--tw-bg-opacity));
}

footer div.policyBox {
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 1rem;
  --tw-text-opacity: 1;
  color: rgb(250 250 250 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  footer div.policyBox {
    max-width: 1920px;
    flex-direction: row;
  }
}

footer div.policyBox p {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  width: 100%;
  padding-left: 1rem;
  padding-right: 1rem;
  text-align: center;
  font-size: 0.75rem;
  line-height: 1rem;
}

@media (min-width: 1024px) {
  footer div.policyBox p {
    order: 1;
    width: 33.333333%;
  }
}

footer ul.policy {
  margin-bottom: 0.5rem;
  display: flex;
  width: 100%;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
}

@media (min-width: 640px) {
  footer ul.policy {
    flex-direction: row;
  }
}

@media (min-width: 1024px) {
  footer ul.policy {
    order: 2;
    width: 66.666667%;
    justify-content: flex-start;
  }
}

footer ul.policy li {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  --tw-border-opacity: 1;
  border-color: rgb(82 82 82 / var(--tw-border-opacity));
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  text-align: center;
  font-size: 0.75rem;
  line-height: 1rem;
}

@media (min-width: 640px) {
  footer ul.policy li {
    border-left-width: 1px;
  }
}

@media (min-width: 1440px) {
  footer ul.policy li {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

footer ul.policy li a {
  --tw-text-opacity: 1;
  color: rgb(250 250 250 / var(--tw-text-opacity));
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

footer ul.policy li a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

/*----------------------
  sitemap
----------------------*/

#sitemap .container {
  max-width: 1280px;
}

#sitemap ul.gr_cmn_nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (min-width: 1024px) {
  #sitemap ul.gr_cmn_nav {
    -moz-column-gap: 0.5rem;
         column-gap: 0.5rem;
  }
}

@media (min-width: 1280px) {
  #sitemap ul.gr_cmn_nav {
    -moz-column-gap: 1rem;
         column-gap: 1rem;
  }
}

#sitemap ul.gr_cmn_nav > li {
  /*直下 = 大カテゴリー*/
  grid-column: span 3 / span 3;
  margin-bottom: 1rem;
}

@media (min-width: 1024px) {
  #sitemap ul.gr_cmn_nav > li {
    margin-bottom: 2rem;
  }
}

#sitemap ul.gr_cmn_nav > li.single {
  grid-column: span 3 / span 3;
  margin-bottom: 0px;
}

@media (min-width: 1024px) {
  #sitemap ul.gr_cmn_nav > li.single {
    grid-column: span 1 / span 1;
  }
}

#sitemap ul.gr_cmn_nav > li.single a {
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 500;
}

#sitemap ul.gr_cmn_nav > li.single a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  #sitemap ul.gr_cmn_nav > li.single a {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}

/*#sitemap ul.gr_cmn_nav > li.single a:hover span.num {
    @apply ;
  }*/

#sitemap .gr_cmn_nav_item {
  display: block;
  width: 100%;
  padding: 0.5rem;
}

@media (min-width: 1024px) {
  #sitemap .gr_cmn_nav_item {
    padding: 1rem;
  }
}

#sitemap ul li a.gr_cmn_nav_item {
  border-bottom-width: 4px;
  --tw-border-opacity: 1;
  border-color: rgb(112 136 191 / var(--tw-border-opacity));
}

#sitemap p.gr_cmn_nav_item {
  padding-bottom: 0px;
}

#sitemap .gr_cmn_nav_item span.num {
  margin-left: 0.125rem;
  margin-top: 0.25rem;
  display: block;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 500;
  --tw-text-opacity: 1;
  color: rgb(112 136 191 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  #sitemap .gr_cmn_nav_item span.num {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
}

#sitemap .gr_cmn_nav_item span.category_title {
  display: none;
}

#sitemap div.gr_mm_content img {
  display: none;
}

#sitemap ul.gr_mm_inner {
  display: grid;
  gap: 0px;
  border-bottom-width: 0px;
}

@media (min-width: 640px) {
  #sitemap ul.gr_mm_inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1280px) {
  #sitemap ul.gr_mm_inner {
    margin-bottom: 0.5rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
  }
}

#sitemap ul.gr_mm_inner li {
  width: 100%;
  padding: 0.25rem;
}

#sitemap ul.gr_mm_inner li:last-child {
  border-bottom-width: 0px;
}

#sitemap ul.gr_mm_inner li.no_line {
  /*ページ出揃うまで*/
  border-bottom-width: 0px;
}

#sitemap ul.gr_mm_inner li a {
  display: block;
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 1rem;
  padding-right: 2rem;
}

#sitemap ul.gr_mm_inner li a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  #sitemap ul.gr_mm_inner li a {
    padding: 1rem;
  }
}

#sitemap ul.gr_mm_inner li div.no_link {
  display: block;
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 1rem;
  padding-right: 2rem;
}

#sitemap ul.gr_mm_inner li div.no_link:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  #sitemap ul.gr_mm_inner li div.no_link {
    padding: 1rem;
  }
}

#sitemap ul.gr_mm_inner li.category_top {
  margin-top: -0.75rem;
  border-top-width: 0px;
  border-bottom-width: 4px;
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
  padding-top: 0px;
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 500;
}

@media (min-width: 640px) {
  #sitemap ul.gr_mm_inner li.category_top {
    grid-column: span 2 / span 2;
  }
}

@media (min-width: 1024px) {
  #sitemap ul.gr_mm_inner li.category_top {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}

@media (min-width: 1280px) {
  #sitemap ul.gr_mm_inner li.category_top {
    grid-column: span 3 / span 3;
  }
}

#sitemap ul.gr_mm_inner li.category_top a {
  margin-left: -0.75rem;
}

#sitemap ul.gr_mm_inner li.category_top a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  #sitemap ul.gr_mm_inner li.category_top a {
    margin-left: -0.25rem;
    display: inline-block;
    min-width: 33.333333%;
  }
}

#sitemap ul.gr_mm_inner li.category_top a {
  /*ガイド*/
}

#sitemap ul.gr_mm_inner li.category_top span.category_top_mark {
  display: none;
}

#sitemap ul.gr_mm_inner li ul {
  margin: 0px;
  border-left-width: 1px;
  border-right-width: 1px;
  border-bottom-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.375rem;
  padding-bottom: 0.75rem;
}

@media (min-width: 1280px) {
  #sitemap ul.gr_mm_inner li ul {
    margin-bottom: 0.5rem;
  }
}

#sitemap ul.gr_mm_inner li ul li {
  font-size: 0.75rem;
  line-height: 1rem;
}

@media (min-width: 1024px) {
  #sitemap ul.gr_mm_inner li ul li {
    font-size: 0.9375rem;
    line-height: 1.375rem;
  }
}

#sitemap ul.gr_mm_inner li ul li:first-child {
  /*@apply border-t border-asort_color;*/
}

#sitemap ul.gr_mm_inner li ul li:last-child {
  border-bottom-width: 0px;
}

#sitemap ul.gr_mm_inner li ul li a {
  padding: 0.5rem;
}

#sitemap div.policyBox {
  margin-top: 2rem;
  width: 100%;
  border-top-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
}

@media (min-width: 1024px) {
  #sitemap div.policyBox {
    margin-top: 4rem;
  }
}

#sitemap ul.policy {
  display: grid;
}

@media (min-width: 640px) {
  #sitemap ul.policy {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  #sitemap ul.policy {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    -moz-column-gap: 0.5rem;
         column-gap: 0.5rem;
  }
}

@media (min-width: 1280px) {
  #sitemap ul.policy {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    -moz-column-gap: 1rem;
         column-gap: 1rem;
  }
}

#sitemap ul.policy li {
  width: 100%;
  border-bottom-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
}

#sitemap ul.policy li a {
  display: block;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  padding-left: 0.5rem;
  padding-right: 2rem;
}

#sitemap ul.policy li a:hover {
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  #sitemap ul.policy li a {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

#sitemap ul.gr_mm_inner li.about_top:last-child {
  border-bottom-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
}

/*----------------------
  contact
----------------------*/

#contact .container {
  max-width: 1280px;
}

#contact .contact_card {
  position: relative;
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: flex-start;
  border-radius: 0.25rem;
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
  padding: 1rem;
}

@media (min-width: 768px) {
  #contact .contact_card {
    padding: 2rem;
  }
}

#contact .contact_card div.title {
  display: flex;
  flex-direction: row;
  align-items: center;
}

#contact .contact_card .text {
  margin-top: 1rem;
  margin-bottom: 4rem;
  padding-bottom: 0px;
}

@media (min-width: 1024px) {
  #contact .contact_card .text {
    margin-bottom: 5rem;
  }
}

#contact .contact_card .text dl dd {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

#contact .contact_card .title h2 {
  font-weight: 500;
  line-height: 1.5;
}

/*
  #contact .contact_card .title h2 span.title_s {
    @apply block py-1 px-2 bg-indigo-50 text-indigo-500 text-xs font-medium tracking-wider text-center max-w-fit;
  } 
  */

#contact .contact_card .card_footer {
  position: absolute;
  bottom: 0px;
  right: 0px;
  width: -moz-fit-content;
  width: fit-content;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 1rem;
}

@media (min-width: 768px) {
  #contact .contact_card .card_footer {
    padding-left: 2rem;
    padding-right: 2rem;
    padding-bottom: 2rem;
  }
}

/*----------------------
    section_list
  ----------------------*/

#gr_contents div.section_list div.section {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0px;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

@media (min-width: 1280px) {
  #gr_contents div.section_list div.section {
    padding-bottom: 6rem;
  }
}

#gr_contents div.section_list div.section {
  /*py-8 ページ内スクロールの緩衝*/
}

/*#gr_contents div.section_list div.section:nth-child(2n) {
    @apply bg-neutral-100;
  }*/

#gr_contents div.section_list div.section h2 {
  font-weight: 700;
}

/*----------------------
    contents_base
  ----------------------*/

#gr_contents .base {
  /*あとでcommon全体に移動*/
  margin-bottom: 1rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

@media (min-width: 768px) {
  #gr_contents .base {
    margin-bottom: 4rem;
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
}

#gr_contents .base_inner {
  /*あとでcommon全体に移動*/
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 1280px;
  padding: 2rem;
}

#gr_contents .base_inner_l {
  /*あとでcommon全体に移動*/
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 768px;
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 768px) {
  #gr_contents .base_inner_l {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

@media (min-width: 1024px) {
  #gr_contents .base_inner_l {
    max-width: 1024px;
  }
}

@media (min-width: 1280px) {
  #gr_contents .base_inner_l {
    max-width: 1536px;
  }
}

#gr_contents .base p.deco {
  /*あとでcommon全体に移動*/
  margin-bottom: -1rem;
  margin-top: 1rem;
  font-size: 1.25rem;
  line-height: 1.75rem;
  --tw-text-opacity: 1;
  color: rgb(147 165 207 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  #gr_contents .base p.deco {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
}

/*
  #gr_contents .base p.deco span.num {あとでcommon全体に移動
    @apply ;
  }*/

/*----------------------
    contents_list_box
  ----------------------*/

.contents_list_box {
  display: flex;
  flex-direction: column;
  padding-top: 1rem;
}

@media (min-width: 640px) {
  .contents_list_box {
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 1024px) {
  .contents_list_box {
    flex-direction: row;
  }
}

.contents_list_box a {
  line-height: 1.75;
}

.contents_item {
  display: flex;
  width: 100%;
  flex-direction: column;
  padding-bottom: 1rem;
}

@media (min-width: 1024px) {
  .contents_item {
    padding-left: 1rem;
    padding-bottom: 2rem;
    padding-right: 2rem;
  }
}

.contents_item {
  /*lg:w-999---各自設定*/
}

.contents_img {
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  overflow: hidden;
  /*lg:w-999---各自設定*/
}

.contents_solution {
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  overflow: hidden;
  /*lg:w-999---各自設定*/
}

.contents_item h2 {
  flex-direction: column;
  align-items: flex-start;
}

/*
.contents_item h2 span {
  @apply block text-base ml-0.5 mt-1 lg:mb-4 lg:text-xl xl:text-2xl text-asort_color font-bold;
}
*/

.contents_item p.title {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  display: inline-block;
  width: 100%;
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 500;
}

@media (min-width: 1024px) {
  .contents_item p.title {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }
}

.contents_item p.title span.title_s {
  display: inline-block;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media (min-width: 1024px) {
  .contents_item p.title span.title_s {
    font-size: 0.9375rem;
    line-height: 1.375rem;
  }
}

.contents_item p.title span.title_l {
  display: inline-block;
  padding-top: 0.25rem;
  padding-bottom: 0.75rem;
  font-size: 1.25rem;
  line-height: 1.75rem;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .contents_item p.title span.title_l {
    font-size: 1.5rem;
    line-height: 2rem;
  }
}

.contents_item p.text {
  /*p ul span 共通*/
  margin-bottom: 2rem;
}

@media (min-width: 640px) {
  .contents_item p.text {
    margin-bottom: 1.5rem;
  }
}

.contents_item p.text span.text_l {
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .contents_item p.text span.text_l {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}

.contents_item ul.category_nav {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2rem;
  display: flex;
  width: 100%;
  flex-direction: column;
  justify-content: center;
  border-bottom-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity));
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 1280px) {
  .contents_item ul.category_nav {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

.contents_item ul.category_nav li {
  margin: 0px;
  font-weight: 500;
}

@media (min-width: 1024px) {
  .contents_item ul.category_nav li {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }
}

.contents_item ul.category_nav li a {
  border-bottom-width: 0px;
}

.contents_img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.contents_img a img {
  /*イメージにリンクありの場合*/
  height: 100%;
  width: 100%;
  overflow: hidden;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0.8;
  mix-blend-mode: overlay;
  --tw-grayscale: grayscale(100%);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.contents_img a img:hover {
  --tw-scale-x: 1.1;
  --tw-scale-y: 1.1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  opacity: 1;
  mix-blend-mode: normal;
  --tw-grayscale: grayscale(0);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.contents_img a {
  position: relative;
  z-index: 0;
  display: block;
  overflow: hidden;
  border-radius: 0.125rem;
  font-size: 0.625rem;
  line-height: 1rem;
  letter-spacing: 0.05em;
}

@media (min-width: 768px) {
  .contents_img a {
    font-size: 0.75rem;
    line-height: 1rem;
  }
}

@media (min-width: 1024px) {
  .contents_img a {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
}

.contents_img a div.cel {
  /*背景色指定-->common.css*/
  position: absolute;
  bottom: 0px;
  height: 100%;
  width: 100%;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.contents_img a p.title {
  pointer-events: none;
  position: absolute;
  bottom: 0px;
  z-index: 10;
  display: flex;
  background-color: rgb(0 0 0 / var(--tw-bg-opacity));
  --tw-bg-opacity: 0.5;
  padding: 0.5rem;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}

.contents_img a div.more {
  position: absolute;
  bottom: 0px;
  z-index: 10;
  margin: 1rem;
  display: flex;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}

.contents_img a div.extlink {
  position: absolute;
  bottom: 0px;
  z-index: 10;
  margin: 1rem;
  display: flex;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}

/*暫定

.about_top ul.category_nav {
  @apply flex flex-col justify-center w-full mx-auto mb-8 px-4 xl:px-8;
}

.about_top ul.category_nav li {
  @apply m-0 font-medium lg:text-lg border-b border-asort_color;
}

.about_top ul.category_nav li a {
  @apply border-b-0;
}

*/

/*----------------------
    table
  ----------------------*/

table.table_plain {
  width: 100%;
  border-collapse: collapse;
  align-items: center;
  border-width: 1px;
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

table.table_plain th {
  white-space: nowrap;
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity));
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity));
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  text-align: left;
  vertical-align: middle;
  font-weight: 600;
}

table.table_plain tr.head th {
  text-align: center;
}

table.table_plain td {
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity));
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  text-align: left;
  vertical-align: middle;
}

table.table_plain td.number {
  text-align: right;
}

table.table_plain td.start {
  vertical-align: top;
}

table.table_plain td ul {
  display: flex;
  flex-wrap: wrap;
}

table.table_plain td ul li {
  list-style-position: outside;
  list-style-type: disc;
}

table.table_list {
  width: 100%;
  border-collapse: collapse;
  align-items: center;
}

table.table_list th {
  white-space: nowrap;
  border-top-width: 1px;
  border-bottom-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity));
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 2rem;
  padding-bottom: 2rem;
  text-align: left;
  vertical-align: top;
  font-weight: 600;
}

table.table_list td {
  border-top-width: 1px;
  border-bottom-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity));
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 2rem;
  padding-bottom: 2rem;
  text-align: left;
  vertical-align: top;
}

table.table_plain td ul {
  display: flex;
  flex-wrap: wrap;
}

table.table_list td ul li {
  margin-right: 1rem;
  list-style-position: outside;
  list-style-type: disc;
  padding-right: 2rem;
}

/*----------------------
    card
  ----------------------*/

/*cmn_card*/

.cmn_card {
  /*リンクなし*/
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
}

@media (min-width: 1024px) {
  .cmn_card {
    display: block;
  }
}

a.cmn_card {
  /*リンクあり*/
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

@media (min-width: 1024px) {
  a.cmn_card {
    display: block;
  }
}

.cmn_card img.card_img {
  margin-right: 1rem;
  aspect-ratio: 1 / 1;
  width: 25%;
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
  -o-object-fit: cover;
     object-fit: cover;
}

@media (min-width: 640px) {
  .cmn_card img.card_img {
    aspect-ratio: 3 / 2;
    width: 40%;
  }
}

@media (min-width: 1024px) {
  .cmn_card img.card_img {
    margin: 0px;
    aspect-ratio: 16 / 9;
    width: 100%;
  }
}

.cmn_card picture {
  /*picture*/
  margin-right: 1rem;
  width: 25%;
}

@media (min-width: 640px) {
  .cmn_card picture {
    width: 40%;
  }
}

@media (min-width: 1024px) {
  .cmn_card picture {
    margin: 0px;
    width: 100%;
  }
}

.cmn_card picture img.card_img {
  /*picture内の画像*/
  margin-left: 0px;
  aspect-ratio: 1 / 1;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

@media (min-width: 640px) {
  .cmn_card picture img.card_img {
    aspect-ratio: 3 / 2;
  }
}

@media (min-width: 1024px) {
  .cmn_card picture img.card_img {
    aspect-ratio: 16 / 9;
  }
}

.cmn_card div.card_box {
  width: 75%;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 4rem;
}

@media (min-width: 640px) {
  .cmn_card div.card_box {
    width: 60%;
  }
}

@media (min-width: 1024px) {
  .cmn_card div.card_box {
    width: 100%;
    padding-top: 0.75rem;
  }
}

.cmn_card div.card_box.no_img {
  width: 100%;
  padding: 1rem;
}

@media (min-width: 1024px) {
  .cmn_card div.card_box.no_img {
    padding-left: 2rem;
    padding-right: 2rem;
    padding-top: 2rem;
  }
}

.cmn_card div.card_box img.new {
  margin-top: -0.25rem;
  height: 2.25rem;
}

.cmn_card p.title {
  margin-top: 0.5rem;
  margin-bottom: 1rem;
  display: inline-block;
  width: 100%;
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 500;
}

@media (min-width: 1024px) {
  .cmn_card p.title {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }
}

.cmn_card p.title span.title_s {
  display: inline-block;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media (min-width: 1024px) {
  .cmn_card p.title span.title_s {
    font-size: 0.9375rem;
    line-height: 1.375rem;
  }
}

.cmn_card p.title span.title_l {
  display: inline-block;
  padding-top: 0.25rem;
  padding-bottom: 0.75rem;
  font-size: 1.25rem;
  line-height: 1.75rem;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .cmn_card p.title span.title_l {
    font-size: 1.5rem;
    line-height: 2rem;
  }
}

.cmn_card .text {
  /*p ul span 共通*/
  margin-bottom: 2rem;
}

@media (min-width: 640px) {
  .cmn_card .text {
    margin-bottom: 1.5rem;
  }
}

.cmn_card .text span.text_l {
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .cmn_card .text span.text_l {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}

.cmn_card .card_footer {
  position: absolute;
  bottom: 0px;
  right: 0px;
  width: -moz-fit-content;
  width: fit-content;
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

/*----------------------
    simple_card
  ----------------------*/

.simple_card {
  position: relative;
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: flex-start;
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 1024px) {
  .simple_card {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

.simple_card div.title {
  width: -moz-fit-content;
  width: fit-content;
}

.simple_card div.title h2 {
  margin-bottom: 0.25rem;
  border-bottom-width: 3px;
  --tw-border-opacity: 1;
  border-color: rgb(112 136 191 / var(--tw-border-opacity));
  padding-bottom: 0.25rem;
}

.simple_card p.title {
  margin-top: 0.5rem;
  margin-bottom: 1rem;
  display: inline-block;
  width: 100%;
  border-bottom-width: 3px;
  --tw-border-opacity: 1;
  border-color: rgb(112 136 191 / var(--tw-border-opacity));
  padding-bottom: 0.5rem;
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .simple_card p.title {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}

.simple_card p.text {
  margin-top: 0px;
  margin-bottom: 4rem;
}

@media (min-width: 1024px) {
  .simple_card p.text {
    margin-bottom: 6rem;
  }
}

.simple_card .card_footer {
  position: absolute;
  bottom: 0px;
  right: 0px;
  width: -moz-fit-content;
  width: fit-content;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 1rem;
}

@media (min-width: 768px) {
  .simple_card .card_footer {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

@media (min-width: 1024px) {
  .simple_card .card_footer {
    padding-bottom: 2rem;
  }
}

/*company site image*/

/*aboutから移動*/

.site_card {
  /*リンクなし*/
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
  padding: 1rem;
}

@media (min-width: 640px) {
  .site_card {
    flex-direction: row;
  }
}

@media (min-width: 768px) {
  .site_card {
    padding: 2rem;
  }
}

@media (min-width: 1280px) {
  .site_card {
    padding: 2.5rem;
  }
}

@media (min-width: 1440px) {
  .site_card {
    padding: 4rem;
  }
}

a.site_card {
  /*リンクあり*/
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  border-width: 1px;
  --tw-border-opacity: 1;
  border-color: rgb(213 222 238 / var(--tw-border-opacity));
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
  padding: 1rem;
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

a.site_card:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

@media (min-width: 640px) {
  a.site_card {
    flex-direction: row;
  }
}

@media (min-width: 768px) {
  a.site_card {
    padding: 2rem;
  }
}

@media (min-width: 1280px) {
  a.site_card {
    padding: 2.5rem;
  }
}

@media (min-width: 1440px) {
  a.site_card {
    padding: 4rem;
  }
}

.site_card.title {
  margin-top: 1rem;
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity));
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.type_2nd .site_card {
  align-items: center;
  padding: 1rem;
}

@media (min-width: 640px) {
  .type_2nd .site_card {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

@media (min-width: 768px) {
  .type_2nd .site_card {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}

.site_card div.card_img {
  width: 100%;
}

@media (min-width: 640px) {
  .site_card div.card_img {
    width: 40%;
  }
}

.type_2nd .site_card div.card_img {
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
  margin-bottom: 1rem;
  width: 100%;
}

@media (min-width: 640px) {
  .type_2nd .site_card div.card_img {
    width: 33.333333%;
  }
}

.type_2nd .site_card div.card_img div.case_img_box {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.125rem;
}

.type_2nd .site_card div.card_img div.case_img_box img {
  aspect-ratio: 4 / 3;
  -o-object-fit: cover;
     object-fit: cover;
}

.site_card div.card_img img.site {
  aspect-ratio: 16 / 9;
  -o-object-fit: cover;
     object-fit: cover;
}

.site_card div.card_img img.site_logo {
  aspect-ratio: 3 / 2;
  -o-object-fit: contain;
     object-fit: contain;
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.site_card div.card_img img.logo {
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
  margin-bottom: 1rem;
  display: block;
  aspect-ratio: 3 / 1;
  max-height: 2.5rem;
  width: 80%;
  -o-object-fit: contain;
     object-fit: contain;
}

@media (min-width: 1280px) {
  .site_card div.card_img img.logo {
    display: none;
  }
}

.site_card div.card_img img.logo_long {
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
  margin-bottom: 1rem;
  display: block;
  aspect-ratio: 4 / 1;
  max-height: 2.5rem;
  width: 80%;
  -o-object-fit: contain;
     object-fit: contain;
}

@media (min-width: 1280px) {
  .site_card div.card_img img.logo_long {
    display: none;
  }
}

.site_card img.logo {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  display: none;
  max-height: 2.5rem;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

@media (min-width: 640px) {
  .site_card img.logo {
    margin-top: 0px;
    margin-bottom: 0px;
  }
}

@media (min-width: 1280px) {
  .site_card img.logo {
    display: block;
  }
}

.site_card img.logo_long {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  display: none;
  max-height: 2rem;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

@media (min-width: 640px) {
  .site_card img.logo_long {
    margin-top: 0px;
    margin-bottom: 0px;
  }
}

@media (min-width: 1280px) {
  .site_card img.logo_long {
    display: block;
  }
}

/*
.site_card picture {picture
  @apply w-1/4 mr-4 lg:w-full lg:m-0;
} */

/*
.site_card picture img.card_img {picture内の画像
  @apply aspect-video w-full object-contain ml-0 bg-white;
} 
*/

.site_card div.card_box {
  width: 100%;
  padding: 1rem;
}

@media (min-width: 640px) {
  .site_card div.card_box {
    width: 60%;
    padding-left: 2rem;
    padding-right: 0px;
  }
}

@media (min-width: 1024px) {
  .site_card div.card_box {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
}

@media (min-width: 1280px) {
  .site_card div.card_box {
    padding-left: 5rem;
    padding-right: 2rem;
  }
}

.type_2nd .site_card div.card_box {
  margin-top: -1rem;
  width: 100%;
  padding: 0px;
}

@media (min-width: 640px) {
  .type_2nd .site_card div.card_box {
    margin-top: 0.5rem;
    width: 66.666667%;
    padding-left: 2rem;
  }
}

@media (min-width: 768px) {
  .type_2nd .site_card div.card_box {
    margin-top: 0px;
  }
}

.type_2nd .site_card div.card_box div.card_tag {
  padding-bottom: 0.25rem;
}

.site_card div.card_box img.new {
  margin-top: -0.25rem;
  height: 2.25rem;
}

.site_card p.title {
  margin-bottom: 1rem;
  width: 100%;
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 600;
}

@media (min-width: 1024px) {
  .site_card p.title {
    margin-bottom: 1.5rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    font-size: 1.125rem;
    line-height: 1.75rem;
  }
}

.type_2nd .site_card p.title {
  margin-bottom: 1rem;
}

@media (min-width: 1024px) {
  .type_2nd .site_card p.title {
    margin-bottom: 1rem;
  }
}

.site_card p.title span.title_s {
  display: inline-block;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media (min-width: 1024px) {
  .site_card p.title span.title_s {
    font-size: 0.9375rem;
    line-height: 1.375rem;
  }
}

.site_card p.title span.title_l {
  display: inline-block;
  font-size: 1.25rem;
  line-height: 1.75rem;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .site_card p.title span.title_l {
    font-size: 1.5rem;
    line-height: 2rem;
  }
}

.site_card .text {
  /*p ul span 共通*/
  margin-bottom: 1rem;
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  font-size: 0.875rem;
  line-height: 1.25rem;
  line-height: 1.625;
}

@media (min-width: 1024px) {
  .site_card .text {
    font-size: 0.9375rem;
    line-height: 1.375rem;
    line-height: 1.625;
  }
}

.type_2nd .site_card .text {
  /*p ul span 共通*/
  margin-bottom: 0px;
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  font-size: 0.875rem;
  line-height: 1.25rem;
  line-height: 1.625;
}

@media (min-width: 1024px) {
  .type_2nd .site_card .text {
    font-size: 0.9375rem;
    line-height: 1.375rem;
    line-height: 1.625;
  }
}

.type_2nd a.site_card:hover .text {
  --tw-text-opacity: 1;
  color: rgb(37 52 142 / var(--tw-text-opacity));
}

.type_2nd a.site_card p.text span.url {
  margin-top: 0.25rem;
  display: inline-block;
}

.type_2nd a.site_card:hover p.text span.url {
  text-decoration-line: underline;
}

.site_card p.text {
  /*p.textのみ*/
  line-height: 1.75;
}

.site_card span.text_l {
  font-size: 1rem;
  line-height: 1.5rem;
}

@media (min-width: 1024px) {
  .site_card span.text_l {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }
}

.site_card span.text_s {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

@media (min-width: 1024px) {
  .site_card span.text_s {
    font-size: 0.9375rem;
    line-height: 1.375rem;
  }
}

/*extlink btn --> groupsite_add.css*/

.site_card .btn_icon_extlink {
  width: 100%;
  justify-content: flex-start;
  --tw-bg-opacity: 1;
  background-color: rgb(64 64 64 / var(--tw-bg-opacity));
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  padding-left: 0.5rem;
  padding-right: 1rem;
}

.site_card .btn_icon_extlink span.num {
  font-weight: 400;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}

.site_card .btn_icon_extlink_s {
  margin-top: 1rem;
  margin-bottom: 1rem;
  width: 100%;
  justify-content: flex-start;
  overflow: hidden;
  text-overflow: ellipsis;
  background-color: rgb(37 52 142 / var(--tw-bg-opacity));
  --tw-bg-opacity: 0.9;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  padding-left: 0.5rem;
  padding-right: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.site_card .btn_icon_extlink_s:hover {
  --tw-bg-opacity: 0.5;
}

.site_card .btn_icon_extlink_s span.num {
  font-weight: 400;
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}

/*----------------------
    process
  ----------------------*/

#gr_contents ul.process {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 1280px;
}

#gr_contents ul.process li {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  border-radius: 0.25rem;
  border-width: 2px;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
  --tw-border-opacity: 0.5;
  padding: 0.5rem;
  text-align: center;
  font-weight: 700;
}

@media (min-width: 1024px) {
  #gr_contents ul.process li {
    flex-direction: column;
    justify-content: flex-start;
  }
}

#gr_contents ul.process li img {
  margin-right: 2rem;
  height: auto;
  width: 6rem;
}

@media (min-width: 1024px) {
  #gr_contents ul.process li img {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1rem;
    width: 10rem;
  }
}

#gr_contents ul.process li span.process {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  text-align: left;
  line-height: 1.5;
}

@media (min-width: 1024px) {
  #gr_contents ul.process li span.process {
    text-align: center;
  }
}

#gr_contents ul.process02 {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 1280px;
}

#gr_contents ul.process02 li {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 0.25rem;
  border-width: 2px;
  border-color: rgb(15 118 110 / var(--tw-border-opacity));
  --tw-border-opacity: 0.7;
  padding: 0.5rem;
  text-align: center;
  font-weight: 700;
}

@media (min-width: 1024px) {
  #gr_contents ul.process02 li {
    justify-content: flex-start;
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}

#gr_contents ul.process02 li img.logo {
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
  height: 2rem;
}

#gr_contents ul.process02 li img.logo_long {
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
  height: 2.25rem;
  max-width: 256px;
}

@media (min-width: 1024px) {
  #gr_contents ul.process02 li img.logo_long {
    max-width: 100%;
  }
}

#gr_contents ul.process02 li span.process {
  display: block;
  width: 100%;
  text-align: center;
}

/*----------------------
    btn
  ----------------------*/

.btn_normal {
  display: flex;
  height: -moz-fit-content;
  height: fit-content;
  width: -moz-fit-content;
  width: fit-content;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

@media (min-width: 1024px) {
  .btn_normal {
    font-size: 0.9375rem;
    line-height: 1.375rem;
  }
}

.btn_normal_s {
  display: flex;
  height: -moz-fit-content;
  height: fit-content;
  width: -moz-fit-content;
  width: fit-content;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 500;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

@media (min-width: 1024px) {
  .btn_normal_s {
    font-size: 0.8125rem;
    line-height: 1.125rem;
  }
}

.btn_normal div.extlink {
  /*add common.css -- > more btn icon */
  margin-top: auto;
  margin-bottom: auto;
}

.btn_normal div.more {
  /*add common.css -- > extlink btn icon */
  margin-top: auto;
  margin-bottom: auto;
}

.pointer-events-none {
  pointer-events: none;
}

.visible {
  visibility: visible;
}

.collapse {
  visibility: collapse;
}

.static {
  position: static;
}

.fixed {
  position: fixed;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.inset-0 {
  inset: 0px;
}

.inset-x-0 {
  left: 0px;
  right: 0px;
}

.bottom-0 {
  bottom: 0px;
}

.left-1\/8 {
  left: 12.5%;
}

.left-12 {
  left: 3rem;
}

.top-0 {
  top: 0px;
}

.top-12 {
  top: 3rem;
}

.-z-10 {
  z-index: -10;
}

.z-10 {
  z-index: 10;
}

.order-1 {
  order: 1;
}

.order-2 {
  order: 2;
}

.order-first {
  order: -9999;
}

.col-span-1 {
  grid-column: span 1 / span 1;
}

.col-span-2 {
  grid-column: span 2 / span 2;
}

.m-2 {
  margin: 0.5rem;
}

.m-8 {
  margin: 2rem;
}

.m-auto {
  margin: auto;
}

.-mx-2 {
  margin-left: -0.5rem;
  margin-right: -0.5rem;
}

.-mx-4 {
  margin-left: -1rem;
  margin-right: -1rem;
}

.-mx-6 {
  margin-left: -1.5rem;
  margin-right: -1.5rem;
}

.-my-4 {
  margin-top: -1rem;
  margin-bottom: -1rem;
}

.mx-1 {
  margin-left: 0.25rem;
  margin-right: 0.25rem;
}

.mx-4 {
  margin-left: 1rem;
  margin-right: 1rem;
}

.mx-8 {
  margin-left: 2rem;
  margin-right: 2rem;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.my-0 {
  margin-top: 0px;
  margin-bottom: 0px;
}

.my-16 {
  margin-top: 4rem;
  margin-bottom: 4rem;
}

.my-2 {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

.my-3 {
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
}

.my-4 {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.my-8 {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.-mb-0 {
  margin-bottom: -0px;
}

.-mb-0\.5 {
  margin-bottom: -0.125rem;
}

.-mb-1 {
  margin-bottom: -0.25rem;
}

.-mb-4 {
  margin-bottom: -1rem;
}

.-ml-12 {
  margin-left: -3rem;
}

.-ml-2 {
  margin-left: -0.5rem;
}

.-ml-4 {
  margin-left: -1rem;
}

.-ml-5 {
  margin-left: -1.25rem;
}

.-ml-6 {
  margin-left: -1.5rem;
}

.-mt-0 {
  margin-top: -0px;
}

.-mt-0\.5 {
  margin-top: -0.125rem;
}

.-mt-1 {
  margin-top: -0.25rem;
}

.-mt-4 {
  margin-top: -1rem;
}

.-mt-48 {
  margin-top: -12rem;
}

.-mt-6 {
  margin-top: -1.5rem;
}

.-mt-8 {
  margin-top: -2rem;
}

.mb-0 {
  margin-bottom: 0px;
}

.mb-1 {
  margin-bottom: 0.25rem;
}

.mb-14 {
  margin-bottom: 3.5rem;
}

.mb-2 {
  margin-bottom: 0.5rem;
}

.mb-3 {
  margin-bottom: 0.75rem;
}

.mb-4 {
  margin-bottom: 1rem;
}

.mb-5 {
  margin-bottom: 1.25rem;
}

.mb-6 {
  margin-bottom: 1.5rem;
}

.mb-64 {
  margin-bottom: 16rem;
}

.mb-8 {
  margin-bottom: 2rem;
}

.ml-0 {
  margin-left: 0px;
}

.ml-1 {
  margin-left: 0.25rem;
}

.ml-2 {
  margin-left: 0.5rem;
}

.ml-3 {
  margin-left: 0.75rem;
}

.ml-4 {
  margin-left: 1rem;
}

.ml-auto {
  margin-left: auto;
}

.mr-0 {
  margin-right: 0px;
}

.mr-1 {
  margin-right: 0.25rem;
}

.mr-2 {
  margin-right: 0.5rem;
}

.mr-3 {
  margin-right: 0.75rem;
}

.mr-4 {
  margin-right: 1rem;
}

.mr-6 {
  margin-right: 1.5rem;
}

.mr-8 {
  margin-right: 2rem;
}

.mt-0 {
  margin-top: 0px;
}

.mt-0\.5 {
  margin-top: 0.125rem;
}

.mt-1 {
  margin-top: 0.25rem;
}

.mt-12 {
  margin-top: 3rem;
}

.mt-14 {
  margin-top: 3.5rem;
}

.mt-2 {
  margin-top: 0.5rem;
}

.mt-3 {
  margin-top: 0.75rem;
}

.mt-4 {
  margin-top: 1rem;
}

.mt-6 {
  margin-top: 1.5rem;
}

.mt-8 {
  margin-top: 2rem;
}

.mt-auto {
  margin-top: auto;
}

.mb-16 {
  margin-bottom: 4rem;
}

.-mt-16 {
  margin-top: -4rem;
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.inline {
  display: inline;
}

.flex {
  display: flex;
}

.table {
  display: table;
}

.grid {
  display: grid;
}

.contents {
  display: contents;
}

.hidden {
  display: none;
}

.aspect-3\/1 {
  aspect-ratio: 3 / 1;
}

.aspect-3\/2 {
  aspect-ratio: 3 / 2;
}

.aspect-4\/1 {
  aspect-ratio: 4 / 1;
}

.aspect-auto {
  aspect-ratio: auto;
}

.aspect-square {
  aspect-ratio: 1 / 1;
}

.aspect-video {
  aspect-ratio: 16 / 9;
}

.h-10 {
  height: 2.5rem;
}

.h-14 {
  height: 3.5rem;
}

.h-160 {
  height: 40rem;
}

.h-20 {
  height: 5rem;
}

.h-4 {
  height: 1rem;
}

.h-5 {
  height: 1.25rem;
}

.h-52 {
  height: 13rem;
}

.h-6 {
  height: 1.5rem;
}

.h-8 {
  height: 2rem;
}

.h-fit {
  height: -moz-fit-content;
  height: fit-content;
}

.h-full {
  height: 100%;
}

.max-h-72 {
  max-height: 18rem;
}

.min-h-35vh {
  min-height: 35vh;
}

.w-0 {
  width: 0px;
}

.w-0\.5 {
  width: 0.125rem;
}

.w-1 {
  width: 0.25rem;
}

.w-1\/2 {
  width: 50%;
}

.w-1\/3 {
  width: 33.333333%;
}

.w-1\/4 {
  width: 25%;
}

.w-1\/5 {
  width: 20%;
}

.w-12 {
  width: 3rem;
}

.w-2\/3 {
  width: 66.666667%;
}

.w-20 {
  width: 5rem;
}

.w-3\/4 {
  width: 75%;
}

.w-3\/8 {
  width: 37.5%;
}

.w-32 {
  width: 8rem;
}

.w-4 {
  width: 1rem;
}

.w-4\/5 {
  width: 80%;
}

.w-5 {
  width: 1.25rem;
}

.w-5\/6 {
  width: 83.333333%;
}

.w-56 {
  width: 14rem;
}

.w-6 {
  width: 1.5rem;
}

.w-64 {
  width: 16rem;
}

.w-72 {
  width: 18rem;
}

.w-8 {
  width: 2rem;
}

.w-80 {
  width: 20rem;
}

.w-96 {
  width: 24rem;
}

.w-auto {
  width: auto;
}

.w-fit {
  width: -moz-fit-content;
  width: fit-content;
}

.w-full {
  width: 100%;
}

.min-w-1\/3 {
  min-width: 33.333333%;
}

.min-w-3\/4 {
  min-width: 75%;
}

.min-w-3\/5 {
  min-width: 60%;
}

.max-w-2xl {
  max-width: 42rem;
}

.max-w-3xl {
  max-width: 48rem;
}

.max-w-5xl {
  max-width: 64rem;
}

.max-w-lg {
  max-width: 32rem;
}

.max-w-md {
  max-width: 28rem;
}

.max-w-screen-2xl {
  max-width: 1536px;
}

.max-w-screen-3xl {
  max-width: 1536px;
}

.max-w-screen-lg {
  max-width: 1024px;
}

.max-w-screen-md {
  max-width: 768px;
}

.max-w-screen-xl {
  max-width: 1280px;
}

.max-w-screen-xxl {
  max-width: 1440px;
}

.max-w-sm {
  max-width: 24rem;
}

.max-w-xl {
  max-width: 36rem;
}

.max-w-xs {
  max-width: 20rem;
}

.flex-grow {
  flex-grow: 1;
}

.border-collapse {
  border-collapse: collapse;
}

.-rotate-90 {
  --tw-rotate: -90deg;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.resize {
  resize: both;
}

.list-inside {
  list-style-position: inside;
}

.list-circle {
  list-style-type: circle;
}

.list-disc {
  list-style-type: disc;
}

.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-cols-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.flex-row {
  flex-direction: row;
}

.flex-col {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.items-start {
  align-items: flex-start;
}

.items-center {
  align-items: center;
}

.justify-start {
  justify-content: flex-start;
}

.justify-end {
  justify-content: flex-end;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.justify-around {
  justify-content: space-around;
}

.gap-0 {
  gap: 0px;
}

.gap-1 {
  gap: 0.25rem;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-8 {
  gap: 2rem;
}

.overflow-auto {
  overflow: auto;
}

.overflow-hidden {
  overflow: hidden;
}

.overflow-scroll {
  overflow: scroll;
}

.overflow-x-scroll {
  overflow-x: scroll;
}

.whitespace-nowrap {
  white-space: nowrap;
}

.rounded {
  border-radius: 0.25rem;
}

.rounded-full {
  border-radius: 9999px;
}

.rounded-lg {
  border-radius: 0.5rem;
}

.rounded-xl {
  border-radius: 0.75rem;
}

.border {
  border-width: 1px;
}

.border-2 {
  border-width: 2px;
}

.border-4 {
  border-width: 4px;
}

.border-x-4 {
  border-left-width: 4px;
  border-right-width: 4px;
}

.border-y {
  border-top-width: 1px;
  border-bottom-width: 1px;
}

.border-b {
  border-bottom-width: 1px;
}

.border-b-2 {
  border-bottom-width: 2px;
}

.border-b-3 {
  border-bottom-width: 3px;
}

.border-b-4 {
  border-bottom-width: 4px;
}

.border-l {
  border-left-width: 1px;
}

.border-l-8 {
  border-left-width: 8px;
}

.border-r {
  border-right-width: 1px;
}

.border-r-2 {
  border-right-width: 2px;
}

.border-t {
  border-top-width: 1px;
}

.border-t-2 {
  border-top-width: 2px;
}

.border-t-4 {
  border-top-width: 4px;
}

.border-dashed {
  border-style: dashed;
}

.border-dotted {
  border-style: dotted;
}

.border-accent_color {
  --tw-border-opacity: 1;
  border-color: rgb(112 136 191 / var(--tw-border-opacity));
}

.border-asort_color {
  --tw-border-opacity: 1;
  border-color: rgb(147 165 207 / var(--tw-border-opacity));
}

.border-gray-500 {
  --tw-border-opacity: 1;
  border-color: rgb(107 114 128 / var(--tw-border-opacity));
}

.border-indigo-200 {
  --tw-border-opacity: 1;
  border-color: rgb(199 210 254 / var(--tw-border-opacity));
}

.border-indigo-300 {
  --tw-border-opacity: 1;
  border-color: rgb(165 180 252 / var(--tw-border-opacity));
}

.border-neutral-200 {
  --tw-border-opacity: 1;
  border-color: rgb(229 229 229 / var(--tw-border-opacity));
}

.border-neutral-400 {
  --tw-border-opacity: 1;
  border-color: rgb(163 163 163 / var(--tw-border-opacity));
}

.border-neutral-500 {
  --tw-border-opacity: 1;
  border-color: rgb(115 115 115 / var(--tw-border-opacity));
}

.border-red-400 {
  --tw-border-opacity: 1;
  border-color: rgb(248 113 113 / var(--tw-border-opacity));
}

.border-red-500 {
  --tw-border-opacity: 1;
  border-color: rgb(239 68 68 / var(--tw-border-opacity));
}

.border-stone-500 {
  --tw-border-opacity: 1;
  border-color: rgb(120 113 108 / var(--tw-border-opacity));
}

.border-white {
  --tw-border-opacity: 1;
  border-color: rgb(255 255 255 / var(--tw-border-opacity));
}

.border-l-asort_color {
  --tw-border-opacity: 1;
  border-left-color: rgb(147 165 207 / var(--tw-border-opacity));
}

.border-opacity-80 {
  --tw-border-opacity: 0.8;
}

.bg-accent_color {
  --tw-bg-opacity: 1;
  background-color: rgb(112 136 191 / var(--tw-bg-opacity));
}

.bg-asort_color {
  --tw-bg-opacity: 1;
  background-color: rgb(147 165 207 / var(--tw-bg-opacity));
}

.bg-base_color {
  --tw-bg-opacity: 1;
  background-color: rgb(245 247 251 / var(--tw-bg-opacity));
}

.bg-base_color02 {
  --tw-bg-opacity: 1;
  background-color: rgb(231 236 245 / var(--tw-bg-opacity));
}

.bg-blue-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(219 234 254 / var(--tw-bg-opacity));
}

.bg-blue-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(191 219 254 / var(--tw-bg-opacity));
}

.bg-blue-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(239 246 255 / var(--tw-bg-opacity));
}

.bg-gray-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(229 231 235 / var(--tw-bg-opacity));
}

.bg-gray-300 {
  --tw-bg-opacity: 1;
  background-color: rgb(209 213 219 / var(--tw-bg-opacity));
}

.bg-indigo-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(224 231 255 / var(--tw-bg-opacity));
}

.bg-indigo-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(238 242 255 / var(--tw-bg-opacity));
}

.bg-indigo-900 {
  --tw-bg-opacity: 1;
  background-color: rgb(49 46 129 / var(--tw-bg-opacity));
}

.bg-neutral-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity));
}

.bg-neutral-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity));
}

.bg-neutral-300 {
  --tw-bg-opacity: 1;
  background-color: rgb(212 212 212 / var(--tw-bg-opacity));
}

.bg-neutral-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(115 115 115 / var(--tw-bg-opacity));
}

.bg-paper {
  --tw-bg-opacity: 1;
  background-color: rgb(245 247 251 / var(--tw-bg-opacity));
}

.bg-purple-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(233 213 255 / var(--tw-bg-opacity));
}

.bg-purple-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(168 85 247 / var(--tw-bg-opacity));
}

.bg-red-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 202 202 / var(--tw-bg-opacity));
}

.bg-stone-800 {
  --tw-bg-opacity: 1;
  background-color: rgb(41 37 36 / var(--tw-bg-opacity));
}

.bg-stone-900 {
  --tw-bg-opacity: 1;
  background-color: rgb(28 25 23 / var(--tw-bg-opacity));
}

.bg-teal-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(13 148 136 / var(--tw-bg-opacity));
}

.bg-transparent {
  background-color: transparent;
}

.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

.bg-yellow-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 240 138 / var(--tw-bg-opacity));
}

.bg-opacity-10 {
  --tw-bg-opacity: 0.1;
}

.bg-opacity-20 {
  --tw-bg-opacity: 0.2;
}

.bg-opacity-40 {
  --tw-bg-opacity: 0.4;
}

.bg-opacity-50 {
  --tw-bg-opacity: 0.5;
}

.bg-opacity-60 {
  --tw-bg-opacity: 0.6;
}

.bg-opacity-70 {
  --tw-bg-opacity: 0.7;
}

.bg-opacity-80 {
  --tw-bg-opacity: 0.8;
}

.stroke-orange-50 {
  stroke: #fff7ed;
}

.object-contain {
  -o-object-fit: contain;
     object-fit: contain;
}

.object-cover {
  -o-object-fit: cover;
     object-fit: cover;
}

.object-bottom {
  -o-object-position: bottom;
     object-position: bottom;
}

.object-center {
  -o-object-position: center;
     object-position: center;
}

.object-left {
  -o-object-position: left;
     object-position: left;
}

.object-right {
  -o-object-position: right;
     object-position: right;
}

.object-right-bottom {
  -o-object-position: right bottom;
     object-position: right bottom;
}

.object-top {
  -o-object-position: top;
     object-position: top;
}

.p-0 {
  padding: 0px;
}

.p-1 {
  padding: 0.25rem;
}

.p-2 {
  padding: 0.5rem;
}

.p-3 {
  padding: 0.75rem;
}

.p-4 {
  padding: 1rem;
}

.p-5 {
  padding: 1.25rem;
}

.p-6 {
  padding: 1.5rem;
}

.p-8 {
  padding: 2rem;
}

.px-1 {
  padding-left: 0.25rem;
  padding-right: 0.25rem;
}

.px-12 {
  padding-left: 3rem;
  padding-right: 3rem;
}

.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.px-3 {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}

.px-5 {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.px-8 {
  padding-left: 2rem;
  padding-right: 2rem;
}

.py-1 {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

.py-2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.py-24 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.py-8 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.pb-1 {
  padding-bottom: 0.25rem;
}

.pb-16 {
  padding-bottom: 4rem;
}

.pb-2 {
  padding-bottom: 0.5rem;
}

.pb-24 {
  padding-bottom: 6rem;
}

.pb-3 {
  padding-bottom: 0.75rem;
}

.pb-4 {
  padding-bottom: 1rem;
}

.pb-5 {
  padding-bottom: 1.25rem;
}

.pb-8 {
  padding-bottom: 2rem;
}

.pl-0 {
  padding-left: 0px;
}

.pl-12 {
  padding-left: 3rem;
}

.pl-2 {
  padding-left: 0.5rem;
}

.pl-3 {
  padding-left: 0.75rem;
}

.pl-5 {
  padding-left: 1.25rem;
}

.pl-6 {
  padding-left: 1.5rem;
}

.pl-8 {
  padding-left: 2rem;
}

.pr-0 {
  padding-right: 0px;
}

.pr-2 {
  padding-right: 0.5rem;
}

.pr-5 {
  padding-right: 1.25rem;
}

.pt-0 {
  padding-top: 0px;
}

.pt-0\.5 {
  padding-top: 0.125rem;
}

.pt-1 {
  padding-top: 0.25rem;
}

.pt-16 {
  padding-top: 4rem;
}

.pt-2 {
  padding-top: 0.5rem;
}

.pt-3 {
  padding-top: 0.75rem;
}

.pt-4 {
  padding-top: 1rem;
}

.pt-6 {
  padding-top: 1.5rem;
}

.pt-8 {
  padding-top: 2rem;
}

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.-indent-2 {
  text-indent: -0.5rem;
}

.-indent-4 {
  text-indent: -1rem;
}

.align-text-bottom {
  vertical-align: text-bottom;
}

.text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}

.text-3xl {
  font-size: 1.875rem;
  line-height: 2.25rem;
}

.text-5xl {
  font-size: 3rem;
  line-height: 1;
}

.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.text-md {
  font-size: 0.9375rem;
  line-height: 1.375rem;
}

.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}

.text-xxs {
  font-size: 0.625rem;
  line-height: 1rem;
}

.font-bold {
  font-weight: 700;
}

.font-medium {
  font-weight: 500;
}

.font-normal {
  font-weight: 400;
}

.font-semibold {
  font-weight: 600;
}

.uppercase {
  text-transform: uppercase;
}

.italic {
  font-style: italic;
}

.leading-10 {
  line-height: 2.5rem;
}

.leading-loose {
  line-height: 2;
}

.leading-more_relaxed {
  line-height: 1.75;
}

.leading-normal {
  line-height: 1.5;
}

.leading-relaxed {
  line-height: 1.625;
}

.leading-snug {
  line-height: 1.375;
}

.tracking-tight {
  letter-spacing: -0.025em;
}

.tracking-tighter {
  letter-spacing: -0.05em;
}

.tracking-wide {
  letter-spacing: 0.025em;
}

.tracking-widest {
  letter-spacing: 0.1em;
}

.text-accent_color {
  --tw-text-opacity: 1;
  color: rgb(112 136 191 / var(--tw-text-opacity));
}

.text-blue-600 {
  --tw-text-opacity: 1;
  color: rgb(37 99 235 / var(--tw-text-opacity));
}

.text-blue-900 {
  --tw-text-opacity: 1;
  color: rgb(30 58 138 / var(--tw-text-opacity));
}

.text-gray-600 {
  --tw-text-opacity: 1;
  color: rgb(75 85 99 / var(--tw-text-opacity));
}

.text-gray-800 {
  --tw-text-opacity: 1;
  color: rgb(31 41 55 / var(--tw-text-opacity));
}

.text-indigo-700 {
  --tw-text-opacity: 1;
  color: rgb(67 56 202 / var(--tw-text-opacity));
}

.text-neutral-600 {
  --tw-text-opacity: 1;
  color: rgb(82 82 82 / var(--tw-text-opacity));
}

.text-neutral-800 {
  --tw-text-opacity: 1;
  color: rgb(38 38 38 / var(--tw-text-opacity));
}

.text-paper {
  --tw-text-opacity: 1;
  color: rgb(245 247 251 / var(--tw-text-opacity));
}

.text-red-500 {
  --tw-text-opacity: 1;
  color: rgb(239 68 68 / var(--tw-text-opacity));
}

.text-sky-600 {
  --tw-text-opacity: 1;
  color: rgb(2 132 199 / var(--tw-text-opacity));
}

.text-stone-300 {
  --tw-text-opacity: 1;
  color: rgb(214 211 209 / var(--tw-text-opacity));
}

.text-ta_blue {
  --tw-text-opacity: 1;
  color: rgb(37 52 142 / var(--tw-text-opacity));
}

.text-ta_red {
  --tw-text-opacity: 1;
  color: rgb(229 0 18 / var(--tw-text-opacity));
}

.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}

.text-yellow-300 {
  --tw-text-opacity: 1;
  color: rgb(253 224 71 / var(--tw-text-opacity));
}

.text-yellow-400 {
  --tw-text-opacity: 1;
  color: rgb(250 204 21 / var(--tw-text-opacity));
}

.text-opacity-30 {
  --tw-text-opacity: 0.3;
}

.underline {
  text-decoration-line: underline;
}

.opacity-40 {
  opacity: 0.4;
}

.opacity-50 {
  opacity: 0.5;
}

.opacity-70 {
  opacity: 0.7;
}

.opacity-80 {
  opacity: 0.8;
}

.bg-blend-multiply {
  background-blend-mode: multiply;
}

.shadow-lg {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-xl {
  --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.outline-none {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.outline {
  outline-style: solid;
}

.ring-indigo-300 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(165 180 252 / var(--tw-ring-opacity));
}

.brightness-150 {
  --tw-brightness: brightness(1.5);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.brightness-75 {
  --tw-brightness: brightness(.75);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.drop-shadow {
  --tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / 0.1)) drop-shadow(0 1px 1px rgb(0 0 0 / 0.06));
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.grayscale {
  --tw-grayscale: grayscale(100%);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.-hue-rotate-60 {
  --tw-hue-rotate: hue-rotate(-60deg);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.hue-rotate-30 {
  --tw-hue-rotate: hue-rotate(30deg);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.saturate-50 {
  --tw-saturate: saturate(.5);
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.duration-100 {
  transition-duration: 100ms;
}

.ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

p.lead {
  margin-bottom: 1rem;
  line-height: 1.75;
}

@media (min-width: 1024px) {
  p.lead {
    margin-bottom: 2rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    line-height: 1.75;
  }
}

a.link_basic {
  --tw-text-opacity: 1;
  color: rgb(78 107 174 / var(--tw-text-opacity));
  text-decoration-line: underline;
  text-underline-offset: 4px;
}

a.link_basic:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
  --tw-text-opacity: 1;
  color: rgb(30 64 175 / var(--tw-text-opacity));
}

hr {
  border-left-width: 0px;
  border-right-width: 0px;
  border-bottom-width: 0px;
  border-top-width: 3px;
  --tw-border-opacity: 1;
  border-top-color: rgb(147 165 207 / var(--tw-border-opacity));
}

hr.thin {
  border-left-width: 0px;
  border-right-width: 0px;
  border-bottom-width: 0px;
  border-top-width: 1px;
  --tw-border-opacity: 1;
  border-top-color: rgb(147 165 207 / var(--tw-border-opacity));
}

hr.light {
  border-left-width: 0px;
  border-right-width: 0px;
  border-bottom-width: 0px;
  border-top-width: 3px;
  border-top-color: rgb(147 165 207 / var(--tw-border-opacity));
  --tw-border-opacity: 0.5;
}

hr.light_thin {
  border-left-width: 0px;
  border-right-width: 0px;
  border-bottom-width: 0px;
  border-top-width: 1px;
  border-top-color: rgb(147 165 207 / var(--tw-border-opacity));
  --tw-border-opacity: 0.5;
}

hr.dashed {
  border-left-width: 0px;
  border-right-width: 0px;
  border-bottom-width: 0px;
  border-top-width: 3px;
  border-style: dashed;
  --tw-border-opacity: 1;
  border-top-color: rgb(147 165 207 / var(--tw-border-opacity));
}

hr.light_dashed {
  border-left-width: 0px;
  border-right-width: 0px;
  border-bottom-width: 0px;
  border-top-width: 3px;
  border-style: dashed;
  border-top-color: rgb(147 165 207 / var(--tw-border-opacity));
  --tw-border-opacity: 0.5;
}

/*
  figure {
    @apply ;
  }*/

figcaption {
  margin-top: 0.25rem;
  margin-bottom: 0.25rem;
  display: flex;
  justify-content: center;
  font-size: 0.75rem;
  line-height: 1rem;
  --tw-text-opacity: 1;
  color: rgb(64 64 64 / var(--tw-text-opacity));
}

@media (min-width: 1024px) {
  figcaption {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
}

br.br_sp {
  display: inline-block;
}

@media (min-width: 1024px) {
  br.br_sp {
    display: none;
  }
}

/*components*/

/*utilities*/

.hover\:scale-105:hover {
  --tw-scale-x: 1.05;
  --tw-scale-y: 1.05;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:bg-gray-100:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(243 244 246 / var(--tw-bg-opacity));
}

.hover\:bg-neutral-100:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(245 245 245 / var(--tw-bg-opacity));
}

.hover\:bg-slate-100:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(241 245 249 / var(--tw-bg-opacity));
}

.hover\:bg-white:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

.hover\:text-stone-500:hover {
  --tw-text-opacity: 1;
  color: rgb(120 113 108 / var(--tw-text-opacity));
}

.focus-visible\:ring:focus-visible {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.active\:bg-gray-200:active {
  --tw-bg-opacity: 1;
  background-color: rgb(229 231 235 / var(--tw-bg-opacity));
}

.active\:bg-neutral-200:active {
  --tw-bg-opacity: 1;
  background-color: rgb(229 229 229 / var(--tw-bg-opacity));
}

@media (min-width: 640px) {
  .sm\:order-1 {
    order: 1;
  }

  .sm\:order-2 {
    order: 2;
  }

  .sm\:order-none {
    order: 0;
  }

  .sm\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .sm\:col-span-3 {
    grid-column: span 3 / span 3;
  }

  .sm\:-ml-4\/5 {
    margin-left: -80%;
  }

  .sm\:-ml-6 {
    margin-left: -1.5rem;
  }

  .sm\:-mt-5 {
    margin-top: -1.25rem;
  }

  .sm\:ml-0 {
    margin-left: 0px;
  }

  .sm\:ml-5 {
    margin-left: 1.25rem;
  }

  .sm\:mr-2 {
    margin-right: 0.5rem;
  }

  .sm\:mt-0 {
    margin-top: 0px;
  }

  .sm\:mt-1 {
    margin-top: 0.25rem;
  }

  .sm\:block {
    display: block;
  }

  .sm\:grid {
    display: grid;
  }

  .sm\:h-auto {
    height: auto;
  }

  .sm\:w-1\/2 {
    width: 50%;
  }

  .sm\:w-1\/3 {
    width: 33.333333%;
  }

  .sm\:w-3\/5 {
    width: 60%;
  }

  .sm\:max-w-3xl {
    max-width: 48rem;
  }

  .sm\:max-w-full {
    max-width: 100%;
  }

  .sm\:max-w-sm {
    max-width: 24rem;
  }

  .sm\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sm\:flex-row {
    flex-direction: row;
  }

  .sm\:border-b {
    border-bottom-width: 1px;
  }

  .sm\:border-l {
    border-left-width: 1px;
  }

  .sm\:p-8 {
    padding: 2rem;
  }

  .sm\:py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }

  .sm\:pl-6 {
    padding-left: 1.5rem;
  }

  .sm\:pr-4 {
    padding-right: 1rem;
  }

  .sm\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }

  .sm\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }

  .sm\:text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }

  .sm\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }

  .sm\:leading-none {
    line-height: 1;
  }
}

@media (min-width: 768px) {
  .md\:left-16 {
    left: 4rem;
  }

  .md\:top-16 {
    top: 4rem;
  }

  .md\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .md\:my-8 {
    margin-top: 2rem;
    margin-bottom: 2rem;
  }

  .md\:mb-16 {
    margin-bottom: 4rem;
  }

  .md\:mb-4 {
    margin-bottom: 1rem;
  }

  .md\:mb-8 {
    margin-bottom: 2rem;
  }

  .md\:mt-8 {
    margin-top: 2rem;
  }

  .md\:grid {
    display: grid;
  }

  .md\:aspect-video {
    aspect-ratio: 16 / 9;
  }

  .md\:w-1\/3 {
    width: 33.333333%;
  }

  .md\:w-1\/6 {
    width: 16.666667%;
  }

  .md\:w-2\/3 {
    width: 66.666667%;
  }

  .md\:w-5\/6 {
    width: 83.333333%;
  }

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

  .md\:max-w-none {
    max-width: none;
  }

  .md\:grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .md\:flex-row {
    flex-direction: row;
  }

  .md\:flex-col {
    flex-direction: column;
  }

  .md\:items-start {
    align-items: flex-start;
  }

  .md\:object-right {
    -o-object-position: right;
       object-position: right;
  }

  .md\:p-8 {
    padding: 2rem;
  }

  .md\:px-24 {
    padding-left: 6rem;
    padding-right: 6rem;
  }

  .md\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .md\:py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .md\:pb-4 {
    padding-bottom: 1rem;
  }

  .md\:text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }

  .md\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }

  .md\:text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
}

@media (min-width: 1024px) {
  .lg\:z-0 {
    z-index: 0;
  }

  .lg\:order-1 {
    order: 1;
  }

  .lg\:order-2 {
    order: 2;
  }

  .lg\:order-3 {
    order: 3;
  }

  .lg\:col-span-1 {
    grid-column: span 1 / span 1;
  }

  .lg\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .lg\:-mx-4 {
    margin-left: -1rem;
    margin-right: -1rem;
  }

  .lg\:-mx-8 {
    margin-left: -2rem;
    margin-right: -2rem;
  }

  .lg\:mx-0 {
    margin-left: 0px;
    margin-right: 0px;
  }

  .lg\:mx-24 {
    margin-left: 6rem;
    margin-right: 6rem;
  }

  .lg\:mx-auto {
    margin-left: auto;
    margin-right: auto;
  }

  .lg\:my-16 {
    margin-top: 4rem;
    margin-bottom: 4rem;
  }

  .lg\:my-8 {
    margin-top: 2rem;
    margin-bottom: 2rem;
  }

  .lg\:-ml-3\/4 {
    margin-left: -75%;
  }

  .lg\:-ml-4 {
    margin-left: -1rem;
  }

  .lg\:-ml-8 {
    margin-left: -2rem;
  }

  .lg\:-mt-3 {
    margin-top: -0.75rem;
  }

  .lg\:-mt-4 {
    margin-top: -1rem;
  }

  .lg\:-mt-8 {
    margin-top: -2rem;
  }

  .lg\:mb-12 {
    margin-bottom: 3rem;
  }

  .lg\:mb-16 {
    margin-bottom: 4rem;
  }

  .lg\:mb-2 {
    margin-bottom: 0.5rem;
  }

  .lg\:mb-4 {
    margin-bottom: 1rem;
  }

  .lg\:mb-6 {
    margin-bottom: 1.5rem;
  }

  .lg\:mb-8 {
    margin-bottom: 2rem;
  }

  .lg\:mr-0 {
    margin-right: 0px;
  }

  .lg\:mr-6 {
    margin-right: 1.5rem;
  }

  .lg\:mr-8 {
    margin-right: 2rem;
  }

  .lg\:mt-0 {
    margin-top: 0px;
  }

  .lg\:mt-12 {
    margin-top: 3rem;
  }

  .lg\:mt-16 {
    margin-top: 4rem;
  }

  .lg\:mt-24 {
    margin-top: 6rem;
  }

  .lg\:mt-4 {
    margin-top: 1rem;
  }

  .lg\:mt-8 {
    margin-top: 2rem;
  }

  .lg\:-mt-16 {
    margin-top: -4rem;
  }

  .lg\:block {
    display: block;
  }

  .lg\:inline-block {
    display: inline-block;
  }

  .lg\:inline {
    display: inline;
  }

  .lg\:hidden {
    display: none;
  }

  .lg\:h-12 {
    height: 3rem;
  }

  .lg\:h-20 {
    height: 5rem;
  }

  .lg\:h-5 {
    height: 1.25rem;
  }

  .lg\:min-h-35vh {
    min-height: 35vh;
  }

  .lg\:w-1\/3 {
    width: 33.333333%;
  }

  .lg\:w-1\/4 {
    width: 25%;
  }

  .lg\:w-1\/6 {
    width: 16.666667%;
  }

  .lg\:w-2\/3 {
    width: 66.666667%;
  }

  .lg\:w-2\/5 {
    width: 40%;
  }

  .lg\:w-3\/4 {
    width: 75%;
  }

  .lg\:w-3\/5 {
    width: 60%;
  }

  .lg\:w-5 {
    width: 1.25rem;
  }

  .lg\:w-5\/12 {
    width: 41.666667%;
  }

  .lg\:w-5\/6 {
    width: 83.333333%;
  }

  .lg\:w-7\/12 {
    width: 58.333333%;
  }

  .lg\:w-9\/12 {
    width: 75%;
  }

  .lg\:w-96 {
    width: 24rem;
  }

  .lg\:w-full {
    width: 100%;
  }

  .lg\:max-w-custom {
    max-width: 1920px;
  }

  .lg\:max-w-full {
    max-width: 100%;
  }

  .lg\:max-w-none {
    max-width: none;
  }

  .lg\:grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .lg\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lg\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .lg\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .lg\:flex-row {
    flex-direction: row;
  }

  .lg\:flex-col {
    flex-direction: column;
  }

  .lg\:justify-start {
    justify-content: flex-start;
  }

  .lg\:justify-center {
    justify-content: center;
  }

  .lg\:justify-between {
    justify-content: space-between;
  }

  .lg\:gap-0 {
    gap: 0px;
  }

  .lg\:gap-12 {
    gap: 3rem;
  }

  .lg\:gap-4 {
    gap: 1rem;
  }

  .lg\:gap-5 {
    gap: 1.25rem;
  }

  .lg\:gap-8 {
    gap: 2rem;
  }

  .lg\:p-12 {
    padding: 3rem;
  }

  .lg\:p-16 {
    padding: 4rem;
  }

  .lg\:p-4 {
    padding: 1rem;
  }

  .lg\:p-8 {
    padding: 2rem;
  }

  .lg\:px-12 {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .lg\:px-16 {
    padding-left: 4rem;
    padding-right: 4rem;
  }

  .lg\:px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .lg\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .lg\:py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .lg\:py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .lg\:py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }

  .lg\:py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .lg\:pb-12 {
    padding-bottom: 3rem;
  }

  .lg\:pb-4 {
    padding-bottom: 1rem;
  }

  .lg\:pb-5 {
    padding-bottom: 1.25rem;
  }

  .lg\:pb-8 {
    padding-bottom: 2rem;
  }

  .lg\:pr-8 {
    padding-right: 2rem;
  }

  .lg\:pt-16 {
    padding-top: 4rem;
  }

  .lg\:pt-4 {
    padding-top: 1rem;
  }

  .lg\:pt-8 {
    padding-top: 2rem;
  }

  .lg\:text-left {
    text-align: left;
  }

  .lg\:text-center {
    text-align: center;
  }

  .lg\:text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }

  .lg\:text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }

  .lg\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }

  .lg\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }

  .lg\:text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }

  .lg\:text-md {
    font-size: 0.9375rem;
    line-height: 1.375rem;
  }

  .lg\:text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }

  .lg\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }

  .lg\:text-xs {
    font-size: 0.75rem;
    line-height: 1rem;
  }

  .lg\:tracking-normal {
    letter-spacing: 0em;
  }

  .lg\:opacity-90 {
    opacity: 0.9;
  }
}

@media (min-width: 1280px) {
  .xl\:order-1 {
    order: 1;
  }

  .xl\:order-2 {
    order: 2;
  }

  .xl\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .xl\:-mx-0 {
    margin-left: -0px;
    margin-right: -0px;
  }

  .xl\:mx-16 {
    margin-left: 4rem;
    margin-right: 4rem;
  }

  .xl\:mx-4 {
    margin-left: 1rem;
    margin-right: 1rem;
  }

  .xl\:-mb-5 {
    margin-bottom: -1.25rem;
  }

  .xl\:mb-16 {
    margin-bottom: 4rem;
  }

  .xl\:ml-0 {
    margin-left: 0px;
  }

  .xl\:ml-1\/5 {
    margin-left: 20%;
  }

  .xl\:mt-0 {
    margin-top: 0px;
  }

  .xl\:mt-5 {
    margin-top: 1.25rem;
  }

  .xl\:-mt-16 {
    margin-top: -4rem;
  }

  .xl\:block {
    display: block;
  }

  .xl\:inline-block {
    display: inline-block;
  }

  .xl\:aspect-3\/2 {
    aspect-ratio: 3 / 2;
  }

  .xl\:aspect-square {
    aspect-ratio: 1 / 1;
  }

  .xl\:h-full {
    height: 100%;
  }

  .xl\:max-h-none {
    max-height: none;
  }

  .xl\:w-1\/2 {
    width: 50%;
  }

  .xl\:w-1\/3 {
    width: 33.333333%;
  }

  .xl\:w-1\/6 {
    width: 16.666667%;
  }

  .xl\:w-2\/3 {
    width: 66.666667%;
  }

  .xl\:w-2\/5 {
    width: 40%;
  }

  .xl\:w-3\/5 {
    width: 60%;
  }

  .xl\:w-4\/5 {
    width: 80%;
  }

  .xl\:w-5\/6 {
    width: 83.333333%;
  }

  .xl\:w-auto {
    width: auto;
  }

  .xl\:max-w-screen-lg {
    max-width: 1024px;
  }

  .xl\:grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .xl\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .xl\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .xl\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .xl\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .xl\:flex-row {
    flex-direction: row;
  }

  .xl\:gap-8 {
    gap: 2rem;
  }

  .xl\:rounded-full {
    border-radius: 9999px;
  }

  .xl\:p-8 {
    padding: 2rem;
  }

  .xl\:px-16 {
    padding-left: 4rem;
    padding-right: 4rem;
  }

  .xl\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .xl\:py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }

  .xl\:py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .xl\:pl-8 {
    padding-left: 2rem;
  }

  .xl\:text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }

  .xl\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }

  .xl\:leading-loose {
    line-height: 2;
  }
}

@media (min-width: 1440px) {
  .xxl\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .xxl\:col-span-3 {
    grid-column: span 3 / span 3;
  }

  .xxl\:-mx-16 {
    margin-left: -4rem;
    margin-right: -4rem;
  }

  .xxl\:-mx-24 {
    margin-left: -6rem;
    margin-right: -6rem;
  }

  .xxl\:ml-28 {
    margin-left: 7rem;
  }

  .xxl\:w-4\/5 {
    width: 80%;
  }

  .xxl\:-rotate-3 {
    --tw-rotate: -3deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }

  .xxl\:rotate-3 {
    --tw-rotate: 3deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }

  .xxl\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .xxl\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .xxl\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .xxl\:gap-12 {
    gap: 3rem;
  }

  .xxl\:gap-16 {
    gap: 4rem;
  }

  .xxl\:gap-6 {
    gap: 1.5rem;
  }

  .xxl\:gap-8 {
    gap: 2rem;
  }

  .xxl\:text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }

  .xxl\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}
