*, ::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:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::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:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

/*
! tailwindcss v3.4.14 | 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.
7. Disable tap highlights on iOS
*/

html,
:host {
  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, 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 */
  -webkit-tap-highlight-color: transparent;
  /* 7 */
}

/*
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. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. 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-feature-settings: normal;
  /* 2 */
  font-variation-settings: normal;
  /* 3 */
  font-size: 1em;
  /* 4 */
}

/*
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 */
  letter-spacing: 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,
input:where([type='button']),
input:where([type='reset']),
input:where([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]:where(:not([hidden="until-found"])) {
  display: none;
}

html {
  font-size: 16px;
  color-scheme: light;
}

html.dark {
  color-scheme: dark;
}

body {
  font-size: 16px;
  line-height: 1.625;
  background: var(--color-bg);
  color: var(--color-text);
}

a,
  a:hover,
  a:focus,
  a:active,
  a:visited {
  text-decoration: none !important;
  text-decoration-line: none !important;
}

.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: 1536px) {
  .container {
    max-width: 1536px;
  }
}

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

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

.invisible {
  visibility: hidden;
}

.fixed {
  position: fixed;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.sticky {
  position: sticky;
}

.inset-0 {
  inset: 0px;
}

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

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

.bottom-0 {
  bottom: 0px;
}

.left-0 {
  left: 0px;
}

.left-8 {
  left: 2rem;
}

.left-\[145px\] {
  left: 145px;
}

.left-\[92px\] {
  left: 92px;
}

.right-0 {
  right: 0px;
}

.right-2 {
  right: 0.5rem;
}

.top-0 {
  top: 0px;
}

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

.top-20 {
  top: 5rem;
}

.top-28 {
  top: 7rem;
}

.top-full {
  top: 100%;
}

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

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

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

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

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

.float-right {
  float: right;
}

.mx-12 {
  margin-left: 3rem;
  margin-right: 3rem;
}

.mx-14 {
  margin-left: 3.5rem;
  margin-right: 3.5rem;
}

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

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

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

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

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

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

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

.mb-1\.5 {
  margin-bottom: 0.375rem;
}

.mb-10 {
  margin-bottom: 2.5rem;
}

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

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

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

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

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

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

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

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

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

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

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

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

.mt-10 {
  margin-top: 2.5rem;
}

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

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

.mt-20 {
  margin-top: 5rem;
}

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

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

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

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

.ml-1\.5 {
  margin-left: 0.375rem;
}

.box-border {
  box-sizing: border-box;
}

.line-clamp-2 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.line-clamp-3 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.line-clamp-6 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 6;
}

.block {
  display: block;
}

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

.inline {
  display: inline;
}

.flex {
  display: flex;
}

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

.table {
  display: table;
}

.grid {
  display: grid;
}

.hidden {
  display: none;
}

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

.aspect-\[16\/10\] {
  aspect-ratio: 16/10;
}

.aspect-\[233\/144\] {
  aspect-ratio: 233/144;
}

.aspect-\[3\/4\] {
  aspect-ratio: 3/4;
}

.aspect-\[325\/375\] {
  aspect-ratio: 325/375;
}

.aspect-\[4\/3\] {
  aspect-ratio: 4/3;
}

.aspect-\[6\/5\] {
  aspect-ratio: 6/5;
}

.aspect-\[8\/5\] {
  aspect-ratio: 8/5;
}

.aspect-golden {
  aspect-ratio: 1 / 0.618;
}

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

.h-10 {
  height: 2.5rem;
}

.h-12 {
  height: 3rem;
}

.h-14 {
  height: 3.5rem;
}

.h-16 {
  height: 4rem;
}

.h-20 {
  height: 5rem;
}

.h-4 {
  height: 1rem;
}

.h-5 {
  height: 1.25rem;
}

.h-6 {
  height: 1.5rem;
}

.h-60 {
  height: 15rem;
}

.h-64 {
  height: 16rem;
}

.h-7 {
  height: 1.75rem;
}

.h-8 {
  height: 2rem;
}

.h-9 {
  height: 2.25rem;
}

.h-\[150px\] {
  height: 150px;
}

.h-\[300px\] {
  height: 300px;
}

.h-\[42\%\] {
  height: 42%;
}

.h-\[calc\(100vh-6rem\)\] {
  height: calc(100vh - 6rem);
}

.h-auto {
  height: auto;
}

.h-full {
  height: 100%;
}

.max-h-16 {
  max-height: 4rem;
}

.max-h-44 {
  max-height: 11rem;
}

.max-h-\[5\.5rem\] {
  max-height: 5.5rem;
}

.min-h-0 {
  min-height: 0px;
}

.min-h-28 {
  min-height: 7rem;
}

.min-h-36 {
  min-height: 9rem;
}

.min-h-8 {
  min-height: 2rem;
}

.min-h-\[160px\] {
  min-height: 160px;
}

.min-h-\[170px\] {
  min-height: 170px;
}

.min-h-\[230px\] {
  min-height: 230px;
}

.min-h-\[240px\] {
  min-height: 240px;
}

.min-h-\[320px\] {
  min-height: 320px;
}

.min-h-\[88px\] {
  min-height: 88px;
}

.min-h-full {
  min-height: 100%;
}

.min-h-screen {
  min-height: 100vh;
}

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

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

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

.w-10 {
  width: 2.5rem;
}

.w-16 {
  width: 4rem;
}

.w-2\/5 {
  width: 40%;
}

.w-20 {
  width: 5rem;
}

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

.w-4 {
  width: 1rem;
}

.w-5 {
  width: 1.25rem;
}

.w-6 {
  width: 1.5rem;
}

.w-8 {
  width: 2rem;
}

.w-80 {
  width: 20rem;
}

.w-9 {
  width: 2.25rem;
}

.w-\[150px\] {
  width: 150px;
}

.w-\[200px\] {
  width: 200px;
}

.w-\[240px\] {
  width: 240px;
}

.w-\[300px\] {
  width: 300px;
}

.w-\[7\.5rem\] {
  width: 7.5rem;
}

.w-\[96vw\] {
  width: 96vw;
}

.w-\[calc\(100\%-2rem\)\] {
  width: calc(100% - 2rem);
}

.w-auto {
  width: auto;
}

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

.w-full {
  width: 100%;
}

.w-px {
  width: 1px;
}

.min-w-0 {
  min-width: 0px;
}

.min-w-\[10rem\] {
  min-width: 10rem;
}

.min-w-\[120px\] {
  min-width: 120px;
}

.min-w-\[12rem\] {
  min-width: 12rem;
}

.min-w-\[2\.25rem\] {
  min-width: 2.25rem;
}

.min-w-full {
  min-width: 100%;
}

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

.max-w-\[11rem\] {
  max-width: 11rem;
}

.max-w-\[1400px\] {
  max-width: 1400px;
}

.max-w-\[800px\] {
  max-width: 800px;
}

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

.flex-1 {
  flex: 1 1 0%;
}

.flex-none {
  flex: none;
}

.flex-shrink-0 {
  flex-shrink: 0;
}

.shrink-0 {
  flex-shrink: 0;
}

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

.basis-1\/4 {
  flex-basis: 25%;
}

.basis-1\/5 {
  flex-basis: 20%;
}

.basis-3\/4 {
  flex-basis: 75%;
}

.basis-3\/5 {
  flex-basis: 60%;
}

.-translate-y-1\/2 {
  --tw-translate-y: -50%;
  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));
}

.-translate-y-4 {
  --tw-translate-y: -1rem;
  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));
}

.translate-y-1 {
  --tw-translate-y: 0.25rem;
  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));
}

.-scale-x-100 {
  --tw-scale-x: -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));
}

.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));
}

.cursor-pointer {
  cursor: pointer;
}

.select-none {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

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

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

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

.grid-rows-\[1fr_auto\] {
  grid-template-rows: 1fr auto;
}

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

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

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

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

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

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

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

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

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

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

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

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

.gap-1 {
  gap: 0.25rem;
}

.gap-1\.5 {
  gap: 0.375rem;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-3 {
  gap: 0.75rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-5 {
  gap: 1.25rem;
}

.gap-6 {
  gap: 1.5rem;
}

.gap-7 {
  gap: 1.75rem;
}

.gap-8 {
  gap: 2rem;
}

.gap-x-3 {
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
}

.gap-x-4 {
  -moz-column-gap: 1rem;
       column-gap: 1rem;
}

.gap-x-5 {
  -moz-column-gap: 1.25rem;
       column-gap: 1.25rem;
}

.gap-x-6 {
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
}

.gap-y-1 {
  row-gap: 0.25rem;
}

.gap-y-2 {
  row-gap: 0.5rem;
}

.space-x-12 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-right: calc(3rem * var(--tw-space-x-reverse));
  margin-left: calc(3rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-x-4 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-right: calc(1rem * var(--tw-space-x-reverse));
  margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse)));
}

.space-y-2 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}

.space-y-3 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
}

.space-y-4 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}

.space-y-6 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}

.space-y-8 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(2rem * var(--tw-space-y-reverse));
}

.divide-y > :not([hidden]) ~ :not([hidden]) {
  --tw-divide-y-reverse: 0;
  border-top-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
  border-bottom-width: calc(1px * var(--tw-divide-y-reverse));
}

.divide-\[var\(--color-border\)\] > :not([hidden]) ~ :not([hidden]) {
  border-color: var(--color-border);
}

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

.self-end {
  align-self: flex-end;
}

.overflow-hidden {
  overflow: hidden;
}

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

.overflow-y-auto {
  overflow-y: auto;
}

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

.text-ellipsis {
  text-overflow: ellipsis;
}

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

.rounded {
  border-radius: 0.25rem;
}

.rounded-2xl {
  border-radius: 1rem;
}

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

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

.rounded-md {
  border-radius: 0.375rem;
}

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

.rounded-b-full {
  border-bottom-right-radius: 9999px;
  border-bottom-left-radius: 9999px;
}

.rounded-b-md {
  border-bottom-right-radius: 0.375rem;
  border-bottom-left-radius: 0.375rem;
}

.rounded-l-full {
  border-top-left-radius: 9999px;
  border-bottom-left-radius: 9999px;
}

.rounded-r-full {
  border-top-right-radius: 9999px;
  border-bottom-right-radius: 9999px;
}

.border {
  border-width: 1px;
}

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

.border-\[4px\] {
  border-width: 4px;
}

.border-\[5px\] {
  border-width: 5px;
}

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

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

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

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

.border-\[\#EEE\] {
  --tw-border-opacity: 1;
  border-color: rgb(238 238 238 / var(--tw-border-opacity));
}

.border-\[var\(--color-primary\)\] {
  border-color: var(--color-primary);
}

.border-black\/10 {
  border-color: rgb(0 0 0 / 0.1);
}

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

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

.border-primary {
  --tw-border-opacity: 1;
  border-color: rgb(187 18 18 / var(--tw-border-opacity));
}

.border-transparent {
  border-color: transparent;
}

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

.border-white\/70 {
  border-color: rgb(255 255 255 / 0.7);
}

.bg-\[color-mix\(in_srgb\2c var\(--color-primary\)_30\%\2c transparent\)\] {
  background-color: color-mix(in srgb,var(--color-primary) 30%,transparent);
}

.bg-\[color-mix\(in_srgb\2c var\(--color-primary\)_6\%\2c white\)\] {
  background-color: color-mix(in srgb,var(--color-primary) 6%,white);
}

.bg-\[rgba\(0\2c 0\2c 0\2c 0\.35\)\] {
  background-color: rgba(0,0,0,0.35);
}

.bg-\[var\(--color-overlay\)\] {
  background-color: var(--color-overlay);
}

.bg-\[var\(--color-primary\)\] {
  background-color: var(--color-primary);
}

.bg-\[var\(--color-surface\)\] {
  background-color: var(--color-surface);
}

.bg-black\/15 {
  background-color: rgb(0 0 0 / 0.15);
}

.bg-black\/30 {
  background-color: rgb(0 0 0 / 0.3);
}

.bg-black\/40 {
  background-color: rgb(0 0 0 / 0.4);
}

.bg-black\/5 {
  background-color: rgb(0 0 0 / 0.05);
}

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

.bg-gray-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(249 250 251 / var(--tw-bg-opacity));
}

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

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

.bg-slate-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(226 232 240 / var(--tw-bg-opacity));
}

.bg-slate-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(248 250 252 / var(--tw-bg-opacity));
}

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

.bg-white\/10 {
  background-color: rgb(255 255 255 / 0.1);
}

.bg-white\/15 {
  background-color: rgb(255 255 255 / 0.15);
}

.bg-white\/60 {
  background-color: rgb(255 255 255 / 0.6);
}

.bg-white\/70 {
  background-color: rgb(255 255 255 / 0.7);
}

.bg-white\/80 {
  background-color: rgb(255 255 255 / 0.8);
}

.bg-white\/95 {
  background-color: rgb(255 255 255 / 0.95);
}

.bg-yellow-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 252 232 / var(--tw-bg-opacity));
}

.bg-\[url\(\'\.\.\/img\/notice_bg\.jpg\'\)\] {
  background-image: url('../img/notice_bg.jpg');
}

.bg-gradient-to-b {
  background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}

.bg-gradient-to-r {
  background-image: linear-gradient(to right, var(--tw-gradient-stops));
}

.bg-gradient-to-t {
  background-image: linear-gradient(to top, var(--tw-gradient-stops));
}

.from-\[var\(--color-primary\)\] {
  --tw-gradient-from: var(--color-primary) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/0 {
  --tw-gradient-from: rgb(0 0 0 / 0) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/70 {
  --tw-gradient-from: rgb(0 0 0 / 0.7) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-black\/75 {
  --tw-gradient-from: rgb(0 0 0 / 0.75) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.via-black\/0 {
  --tw-gradient-to: rgb(0 0 0 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), rgb(0 0 0 / 0) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-black\/40 {
  --tw-gradient-to: rgb(0 0 0 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), rgb(0 0 0 / 0.4) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.via-black\/45 {
  --tw-gradient-to: rgb(0 0 0 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), rgb(0 0 0 / 0.45) var(--tw-gradient-via-position), var(--tw-gradient-to);
}

.to-\[\#7DDFAE\] {
  --tw-gradient-to: #7DDFAE var(--tw-gradient-to-position);
}

.to-black\/25 {
  --tw-gradient-to: rgb(0 0 0 / 0.25) var(--tw-gradient-to-position);
}

.to-transparent {
  --tw-gradient-to: transparent var(--tw-gradient-to-position);
}

.bg-contain {
  background-size: contain;
}

.bg-cover {
  background-size: cover;
}

.bg-center {
  background-position: center;
}

.bg-no-repeat {
  background-repeat: no-repeat;
}

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

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

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

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

.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-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-6 {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

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

.py-0 {
  padding-top: 0px;
  padding-bottom: 0px;
}

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

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

.py-1\.5 {
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
}

.py-10 {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

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

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

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

.py-2\.5 {
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

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

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

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

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

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

.pb-10 {
  padding-bottom: 2.5rem;
}

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

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

.pb-2\.5 {
  padding-bottom: 0.625rem;
}

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

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

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

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

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

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

.pl-4 {
  padding-left: 1rem;
}

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

.pl-\[102px\] {
  padding-left: 102px;
}

.pl-\[170px\] {
  padding-left: 170px;
}

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

.pr-14 {
  padding-right: 3.5rem;
}

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

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

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

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

.pt-10 {
  padding-top: 2.5rem;
}

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

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

.pt-20 {
  padding-top: 5rem;
}

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

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

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

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

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

.pr-6 {
  padding-right: 1.5rem;
}

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

.pr-12 {
  padding-right: 3rem;
}

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

.pr-3 {
  padding-right: 0.75rem;
}

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

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

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

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

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

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

.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}

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

.text-\[11px\] {
  font-size: 11px;
}

.text-\[15px\] {
  font-size: 15px;
}

.text-\[16px\] {
  font-size: 16px;
}

.text-\[18px\] {
  font-size: 18px;
}

.text-\[32px\] {
  font-size: 32px;
}

.text-\[64px\] {
  font-size: 64px;
}

.text-\[68px\] {
  font-size: 68px;
}

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

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

.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;
}

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

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

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

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

.not-italic {
  font-style: normal;
}

.leading-5 {
  line-height: 1.25rem;
}

.leading-7 {
  line-height: 1.75rem;
}

.leading-8 {
  line-height: 2rem;
}

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

.leading-none {
  line-height: 1;
}

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

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

.leading-tight {
  line-height: 1.25;
}

.text-\[\#666\] {
  --tw-text-opacity: 1;
  color: rgb(102 102 102 / var(--tw-text-opacity));
}

.text-\[var\(--color-primary\)\] {
  color: var(--color-primary);
}

.text-\[var\(--color-text\)\] {
  color: var(--color-text);
}

.text-\[var\(--color-text-muted\)\] {
  color: var(--color-text-muted);
}

.text-blue-deep {
  color: rgba(14,13,63,0.67);
}

.text-gray-400 {
  --tw-text-opacity: 1;
  color: rgb(156 163 175 / var(--tw-text-opacity));
}

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

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

.text-gray-700 {
  --tw-text-opacity: 1;
  color: rgb(55 65 81 / var(--tw-text-opacity));
}

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

.text-gray-light {
  --tw-text-opacity: 1;
  color: rgb(245 245 245 / var(--tw-text-opacity));
}

.text-inherit {
  color: inherit;
}

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

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

.text-primary {
  --tw-text-opacity: 1;
  color: rgb(187 18 18 / var(--tw-text-opacity));
}

.text-red-600 {
  --tw-text-opacity: 1;
  color: rgb(220 38 38 / var(--tw-text-opacity));
}

.text-red-700 {
  --tw-text-opacity: 1;
  color: rgb(185 28 28 / var(--tw-text-opacity));
}

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

.text-white\/85 {
  color: rgb(255 255 255 / 0.85);
}

.text-white\/90 {
  color: rgb(255 255 255 / 0.9);
}

.text-white\/95 {
  color: rgb(255 255 255 / 0.95);
}

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

.placeholder-white\/60::-moz-placeholder {
  color: rgb(255 255 255 / 0.6);
}

.placeholder-white\/60::placeholder {
  color: rgb(255 255 255 / 0.6);
}

.accent-\[var\(--color-primary\)\] {
  accent-color: var(--color-primary);
}

.opacity-0 {
  opacity: 0;
}

.opacity-45 {
  opacity: 0.45;
}

.opacity-50 {
  opacity: 0.5;
}

.opacity-70 {
  opacity: 0.7;
}

.opacity-90 {
  opacity: 0.9;
}

.shadow {
  --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px 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-\[0_14px_44px_rgba\(15\2c 23\2c 42\2c 0\.16\)\] {
  --tw-shadow: 0 14px 44px rgba(15,23,42,0.16);
  --tw-shadow-colored: 0 14px 44px 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-\[0_4px_12px_rgba\(15\2c 23\2c 42\2c 0\.08\)\] {
  --tw-shadow: 0 4px 12px rgba(15,23,42,0.08);
  --tw-shadow-colored: 0 4px 12px 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-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-sm {
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 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;
}

.ring-1 {
  --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(1px + 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);
}

.ring-\[var\(--color-border\)\] {
  --tw-ring-color: var(--color-border);
}

.ring-white\/20 {
  --tw-ring-color: rgb(255 255 255 / 0.2);
}

.drop-shadow-\[0_1px_2px_rgba\(0\2c 0\2c 0\2c 0\.85\)\] {
  --tw-drop-shadow: drop-shadow(0 1px 2px rgba(0,0,0,0.85));
  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-sm {
  --tw-drop-shadow: drop-shadow(0 1px 1px rgb(0 0 0 / 0.05));
  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);
}

.backdrop-blur-md {
  --tw-backdrop-blur: blur(12px);
  -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.backdrop-blur-sm {
  --tw-backdrop-blur: blur(4px);
  -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.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-\[transform\2c box-shadow\] {
  transition-property: transform,box-shadow;
  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;
}

.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

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

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

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

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

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

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

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

:root {
  /* 首页各板块主标题（校园动态、通知公告等） */
  --section-title-size: 28px;
  --section-title-icon-size: 32px;
  --color-primary: #1d5234;
  --color-primary-2: #006633;
  --color-primary-deeper: #153b26;
  --color-bg: #ffffff;
  --color-surface: rgba(255, 255, 255, 0.9);
  --color-text: #0f172a;
  --color-text-muted: #475569;
  /* 日期、弱提示文字（浅灰） */
  --color-gray-light: #999;
  /* 与 .bg-gray-light 配套：页面浅灰底 */
  --color-bg-gray-light: #f2f2f2;
  --color-border: rgba(15, 23, 42, 0.12);
  --color-overlay: rgba(0, 0, 0, 0.45);
  /* 首屏 Banner 轮播分页：未选中 / 选中（半透明） */
  --color-mid: rgba(255, 255, 255, 0.42);
  --color-dark-trans: rgba(29, 82, 52, 0.88);
}

/* 首页板块主标题字号，与 --section-title-size 一致 */

.home-section-title {
  font-size: var(--section-title-size);
}

/* 首页板块主标题前 iconfont，与 --section-title-icon-size 一致 */

.home-section-title-icon {
  font-size: var(--section-title-icon-size);
}

.home-news-title {
  font-size: 16px;
}

.home-news-date {
  font-size: 14px;
}

@media (max-width: 767px) {
  .home-section-title {
    font-size: 22px;
  }

  .home-section-title-icon {
    font-size: 24px;
  }

  .group-map-title {
    font-size: 24px !important;
    line-height: 1.25;
  }

  .group-map-subtitle {
    font-size: 18px !important;
  }

  .home-news-title {
    font-size: 15px;
  }

  .home-news-date {
    font-size: 13px;
  }
}

.dark {
  --color-bg: #0d2b1b;
  --color-surface: rgba(13, 43, 27, 0.78);
  --color-text: #f3f4f6;
  --color-text-muted: #d1d5db;
  --color-gray-light: #d1d5db;
  --color-border: rgba(243, 244, 246, 0.18);
  --color-overlay: rgba(0, 0, 0, 0.65);
}

.bg-primary-trans {
  background-color: var(--color-primary-deeper);
}

/* 深色模式：首页与二级页背景、标题、图标统一适配 */

.dark .bg-white {
  background-color: rgba(16, 52, 33, 0.82) !important;
}

.dark .bg-white\/80 {
  background-color: rgba(16, 52, 33, 0.74) !important;
}

.dark .bg-white\/90,
.dark .bg-white\/95 {
  background-color: rgba(16, 52, 33, 0.86) !important;
}

.dark [class*="bg-[color-mix(in_srgb,var(--color-primary)_6%,white)]"],
.dark [class*="bg-[color-mix(in_srgb,var(--color-primary)_30%,transparent)]"] {
  background-color: rgba(18, 57, 37, 0.92) !important;
}

.dark .home-section-title,
.dark .home-section-title-icon,
.dark .master-style-title {
  color: #ecfff4 !important;
}

.dark section h2.text-\[var\(--color-primary\)\],
.dark section i.text-\[var\(--color-primary\)\] {
  color: #ecfff4 !important;
}

.dark .inner-section-title {
  color: #ecfff4;
  background: linear-gradient(90deg, rgba(125, 223, 174, 0.5), rgba(125, 223, 174, 0.14));
}

.dark .inner-card {
  background: rgba(16, 52, 33, 0.82);
  border-color: rgba(236, 255, 244, 0.16);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.35);
}

.dark .main,
.dark .line-bg {
  background-color: #0f2f1e;
}

.dark main {
  background-color: #0f2f1e;
}

.dark .inner-hero {
  background: linear-gradient(180deg, rgba(6, 26, 16, 0.45), rgba(6, 26, 16, 0.8)),
          linear-gradient(120deg, #113323, #0d2b1b);
}

.dark .notice-section-bg {
  background-image: none !important;
  background-color: #123925;
}

/* 深色模式：首页「更多」、通知公告翻页箭头、集团/校历副标题 */

.dark .home-section-more {
  color: rgba(255, 255, 255, 0.7) !important;
}

.dark .home-section-more:hover {
  color: rgba(255, 255, 255, 0.9) !important;
}

.dark .notice-nav-prev,
.dark .notice-nav-next {
  color: rgba(255, 255, 255, 0.7) !important;
}

.dark .notice-nav-prev:hover,
.dark .notice-nav-next:hover {
  color: rgba(255, 255, 255, 0.9) !important;
}

/* 站内搜索页 · 深色模式 */

.dark .site-search-input {
  background-color: rgba(255, 255, 255, 0.25);
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.35);
}

.dark .site-search-input::-moz-placeholder {
  color: rgba(255, 255, 255, 0.55);
}

.dark .site-search-input::placeholder {
  color: rgba(255, 255, 255, 0.55);
}

.dark .site-search-summary,
.dark .site-search-sidebar-title {
  color: rgba(255, 255, 255, 0.75);
}

.dark .site-search-highlight {
  color: #9de9c0;
}

.dark .site-search-advanced-link {
  color: #9de9c0;
}

.dark .site-search-advanced-link:hover {
  color: #ecfff4;
}

.dark .site-search-channel-tag {
  background-color: rgba(255, 255, 255, 0.25) !important;
  color: rgba(255, 255, 255, 0.85);
}

.dark .site-search-channel-tag:hover {
  background-color: var(--color-primary) !important;
  color: #ffffff !important;
}

.dark .group-map-subtitle {
  color: #fff !important;
  opacity: 0.5 !important;
}

.dark .group-map-wave {
  opacity: 0;
}

.dark .group-map-chart {
  background-color: rgba(255, 255, 255, 0.06) !important;
}

.dark .group-map-chart-title {
  color: rgba(255, 255, 255, 0.75) !important;
}

/* hamburger (match main campus behavior/shape) */

.hamburger {
  width: 30px;
  height: 24px;
  position: relative;
  cursor: pointer;
}

.hamburger div {
  background-color: #fff;
  height: 3px;
  width: 100%;
  position: absolute;
  left: 0;
  transition: all 0.3s ease-in-out;
}

.hamburger .line-top {
  top: 0;
}

.hamburger .line-middle {
  top: 50%;
  transform: translateY(-50%);
}

.hamburger .line-bottom {
  bottom: 0;
}

.is-active .line-top {
  transform: translateY(10px) rotate(45deg);
}

.is-active .line-middle {
  opacity: 0;
}

.is-active .line-bottom {
  transform: translateY(-10px) rotate(-45deg);
}

/* 首屏轮播：占满 100vh - 导航高度 */

.hero-swiper,
.hero-swiper .swiper-wrapper {
  height: 100%;
}

.hero-swiper .swiper-slide {
  height: 100%;
}

.hero-swiper .swiper-slide img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* 首屏 Banner（.banner.hero-swiper）：分页 pill，参考主站样式 */

.banner .swiper-pagination {
  right: 1rem;
  left: auto;
  bottom: 1rem;
  width: auto;
  text-align: right;
}

.banner .swiper-pagination-bullet {
  width: 16px;
  height: 16px;
  border-radius: 8px;
  opacity: 1;
  background: var(--color-mid);
  margin: 0 0.5rem;
  transition:
          width 0.3s ease,
          background 0.3s ease;
}

.banner .swiper-pagination-bullet-active {
  width: 32px;
  background: var(--color-dark-trans);
  border-radius: 8px;
}

/* 竖向分页 + .switch 场景：取消 Swiper 默认位移，与主站一致（预留） */

.switch .swiper-pagination-vertical.swiper-pagination-bullets,
.switch .swiper-vertical > .swiper-pagination-bullets {
  transform: none;
}

.switch .swiper-pagination-bullets .swiper-pagination-bullet {
  margin-right: 1rem;
  background: var(--color-mid);
}

.switch .swiper-pagination-bullets .swiper-pagination-bullet-active {
  background: var(--color-dark-trans);
}

/* 校园动态左侧：大图 + 缩略图在父级内撑满高度 */

.news-left-media {
  min-height: 0;
}

.news-left-media .news-main-swiper,
.news-left-media .news-main-swiper .swiper-wrapper,
.news-left-media .news-main-swiper .swiper-slide {
  height: 100%;
}

.news-left-media .news-main-swiper .swiper-slide img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.news-left-media .news-thumbs-swiper,
.news-left-media .news-thumbs-swiper .swiper-wrapper {
  height: auto;
}

.news-left-media .news-thumbs-swiper .swiper-slide {
  height: auto;
  display: flex;
  align-items: stretch;
  aspect-ratio: 1 / 0.618;
}

.news-left-media .news-thumbs-swiper .swiper-slide .news-thumb-img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1 / 0.618;
}

/* 校园动态缩略图：与主图联动高亮 */

.news-thumbs-swiper .swiper-slide-thumb-active {
  opacity: 1 !important;
}

.news-thumbs-swiper .swiper-slide-thumb-active .news-thumb-img {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.book-bg {
  background-image: url("../img/book.svg");
}

@media (min-width: 768px) {
  .book-bg {
    padding-bottom: 3rem;
  }
}

.dark .book-bg {
  background-image: url("../img/book_dark.svg");
}

@media (max-width: 1023px) {
  .book-bg,
  .dark .book-bg {
    background-image: none !important;
  }
}

@media (max-width: 1400px) {
  .home-news-header {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

@media (max-width: 1023px) {
  .book-bg {
    background-image: none;
  }
}

.bg-gray-light {
  background-color: var(--color-bg-gray-light);
}

.text-gray-light {
  color: var(--color-gray-light);
}

/* 通知公告轮播：宽度随父级，不撑破 max-w-[1400px] */

.notice-swiper {
  max-width: 100%;
}

/* 通知公告轮播：同列卡片等高 */

.notice-swiper .swiper-slide {
  height: auto;
  display: flex;
}

.notice-swiper .swiper-slide > a {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
  min-height: 100%;
}

/* 课程详情页 · 精彩瞬间轮播：图片统一尺寸 */

.course-moments-swiper .swiper-slide img {
  display: block;
  width: 100%;
  height: 200px;
  -o-object-fit: cover;
     object-fit: cover;
}

.notice-nav-prev.swiper-button-disabled,
.notice-nav-next.swiper-button-disabled,
.teacher-nav-prev.swiper-button-disabled,
.teacher-nav-next.swiper-button-disabled {
  opacity: 0.4;
  pointer-events: none;
}

/* 教师风采轮播：固定卡片宽度 240px（与 240×320 配图一致） */

.teacher-swiper .swiper-slide {
  width: 240px;
}

/* 特色课程：气球式圆形课程图容器 */

.course-bubbles-root {
  touch-action: pan-y;
  /* 子项 z-index 最高约 280（按尺寸叠层），会压过 sticky header(z-40)；隔离叠层上下文，保证顶栏始终在上 */
  position: relative;
  z-index: 0;
  isolation: isolate;
}

.course-bubble {
  -webkit-tap-highlight-color: transparent;
  display: block;
  border-radius: 9999px;
  will-change: transform;
}

.course-bubble:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* 桌面端（≥1024px）：绝对定位错落布局。
 * 每个槽位的位置 / 尺寸 / 层级 / 视差系数（--parallax）通过 :nth-child 预设，
 * 不再依赖行内 style 或 data-parallax，模板由 JS 按后端数据遍历渲染。 */

@media (min-width: 1024px) {
  .course-bubbles-root > .course-bubble {
    position: absolute;
    transform: translate(-50%, -50%);
  }

  .course-bubbles-root > .course-bubble:nth-child(1)  {
    left: 69.95%;
    top: 17.76%;
    width: 190px;
    height: 190px;
    z-index: 190;
    --parallax: 0.55;
  }

  .course-bubbles-root > .course-bubble:nth-child(2)  {
    left: 44.78%;
    top: 85.36%;
    width: 145px;
    height: 145px;
    z-index: 145;
    --parallax: 0.35;
  }

  .course-bubbles-root > .course-bubble:nth-child(3)  {
    left: 75.31%;
    top: 57.87%;
    width: 280px;
    height: 280px;
    z-index: 280;
    --parallax: 0.75;
  }

  .course-bubbles-root > .course-bubble:nth-child(4)  {
    left: 52.70%;
    top: 18.03%;
    width: 170px;
    height: 170px;
    z-index: 170;
    --parallax: 0.42;
  }

  .course-bubbles-root > .course-bubble:nth-child(5)  {
    left: 89.81%;
    top: 23.20%;
    width: 240px;
    height: 240px;
    z-index: 240;
    --parallax: 0.62;
  }

  .course-bubbles-root > .course-bubble:nth-child(6)  {
    left: 19.32%;
    top: 84.18%;
    width: 135px;
    height: 135px;
    z-index: 135;
    --parallax: 0.28;
  }

  .course-bubbles-root > .course-bubble:nth-child(7)  {
    left: 35.52%;
    top: 49.89%;
    width: 260px;
    height: 260px;
    z-index: 260;
    --parallax: 0.68;
  }

  .course-bubbles-root > .course-bubble:nth-child(8)  {
    left: 10.29%;
    top: 19.29%;
    width: 180px;
    height: 180px;
    z-index: 180;
    --parallax: 0.48;
  }

  .course-bubbles-root > .course-bubble:nth-child(9)  {
    left: 55.74%;
    top: 58.45%;
    width: 210px;
    height: 210px;
    z-index: 210;
    --parallax: 0.52;
  }

  .course-bubbles-root > .course-bubble:nth-child(10) {
    left: 15.09%;
    top: 54.49%;
    width: 220px;
    height: 220px;
    z-index: 220;
    --parallax: 0.58;
  }
}

/* 移动端 / 平板（<1024px）：切换为网格平铺，气泡等大正方形，关闭错落动画 */

@media (max-width: 1023px) {
  .course-bubbles-root {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 0.875rem;
    place-content: start;
    overflow: visible;
  }

  .course-bubbles-root > .course-bubble {
    position: static;
    transform: none;
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
  }
}

@media (max-width: 767px) {
  .course-bubbles-root {
    grid-template-columns: repeat(2, minmax(92px, 1fr));
    gap: 0.625rem;
  }

  .course-bubbles-root > .course-bubble {
    width: 80%;
    justify-self: center;
  }

  .course-bubbles-root > .course-bubble:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    justify-self: center;
    width: min(109px, 35.2%);
  }
}

/* 特色课程圆形：统一 3px 白色实线边框（避免 ring/border 混用导致粗细不一致） */

.course-bubble-ring {
  box-sizing: border-box;
  border: 3px solid #fff;
  border-radius: 9999px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  container-type: size;
}

.dark .course-bubble-ring {
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
}

/* 特色课程：底部标题条 + 悬停全圆半透明模糊（对齐校园风采动效） */

/* 仅「进入悬停」时淡出底部渐变；移开鼠标时立即恢复 opacity，避免与悬停层同时消失时出现一帧无遮罩高亮闪动 */

.course-bubble-bottom {
  opacity: 1;
  transition: none;
}

.course-bubble:hover .course-bubble-bottom,
.course-bubble:focus-within .course-bubble-bottom {
  opacity: 0;
  transition: opacity 0.25s ease-out;
}

/* 悬停层不用 opacity 过渡：backdrop-filter 在淡入淡出时易在圆角外产生黑边闪动；改为瞬时显隐 + 仅动画内部图标/标题 */

.course-bubble-top {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  /* 与 .course-bubble-ring 同圆角，并用 overflow 裁切模糊层（与父级 overflow:hidden 双保险） */
  border-radius: inherit;
  overflow: hidden;
  transform: translateZ(0);
  backface-visibility: hidden;
}

.course-bubble-icon,
.course-bubble-title-hover {
  transition:
          opacity 0.45s ease-out,
          transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  opacity: 0;
}

.course-bubble-icon {
  transform: translateY(-0.5rem);
  /* 约等于圆直径的 1/3（iconfont 用字号） */
  font-size: 33cqmin;
  line-height: 1;
  color: #fff;
}

.course-bubble-label-bottom,
.course-bubble-title-hover {
  font-size: 16px;
  line-height: 1.35;
}

.course-bubble-title-hover {
  transform: translateY(1rem);
}

.course-bubble:hover .course-bubble-top,
.course-bubble:focus-within .course-bubble-top {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.course-bubble:hover .course-bubble-icon,
.course-bubble:focus-within .course-bubble-icon {
  opacity: 1;
  transform: translateY(0);
}

.course-bubble:hover .course-bubble-title-hover,
.course-bubble:focus-within .course-bubble-title-hover {
  transition-delay: 0.06s;
  opacity: 1;
  transform: translateY(0);
}

/* 校园风采卡片：hover / 键盘聚焦同款动效 */

.campus-showcase-bottom {
  transition: opacity 0.3s ease-out;
}

.campus-showcase-top {
  transition: opacity 0.3s ease-out;
  opacity: 0;
  pointer-events: none;
}

.campus-showcase-icon,
.campus-showcase-title {
  transition:
          opacity 0.45s ease-out,
          transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  opacity: 0;
}

.campus-showcase-icon {
  transform: translateY(-0.8rem);
}

.campus-showcase-title {
  transform: translateY(2.2rem);
}

.campus-showcase-card img {
  transition: transform 0.5s ease-out;
}

.campus-showcase-card:hover img,
.campus-showcase-card:focus-within img {
  transform: scale(1.05);
}

.campus-showcase-card:hover .campus-showcase-bottom,
.campus-showcase-card:focus-within .campus-showcase-bottom {
  opacity: 0;
}

.campus-showcase-card:hover .campus-showcase-top,
.campus-showcase-card:focus-within .campus-showcase-top {
  opacity: 1;
  pointer-events: auto;
}

.campus-showcase-card:hover .campus-showcase-icon,
.campus-showcase-card:focus-within .campus-showcase-icon {
  opacity: 1;
  transform: translateY(0);
}

.campus-showcase-card:hover .campus-showcase-title,
.campus-showcase-card:focus-within .campus-showcase-title {
  transition-delay: 0.06s;
  opacity: 1;
  transform: translateY(0);
}

/* Inner pages */

.inner-hero {
  position: relative;
  height: 25vh;
  min-height: 25vh;
  background:
          linear-gradient(180deg, rgba(8, 20, 12, 0.15), rgba(8, 20, 12, 0.35)),
          linear-gradient(120deg, rgba(0, 102, 51, 0.85), rgba(0, 68, 34, 0.9));
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.inner-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
          radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.2), transparent 40%),
          radial-gradient(circle at 82% 62%, rgba(255, 255, 255, 0.16), transparent 36%);
}

.inner-hero-content {
  position: relative;
  z-index: 1;
}

.inner-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 104px;
  padding: 0.55rem 1.1rem;
  font-size: 15px;
  color: var(--color-text);
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.inner-tab.is-active {
  color: #fff;
  background: var(--color-primary);
}

.inner-section-title {
  display: inline-block;
  min-width: 120px;
  padding: 0.35rem 1rem;
  font-size: 16px;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(90deg, var(--color-primary), rgba(0, 102, 51, 0.25));
}

.inner-card {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.06);
}

/* 新闻列表页 · 推荐阅读侧栏 */

.news-aside-recommend {
  --news-aside-line: rgba(0, 102, 51, 0.24);
  --news-aside-gutter: 2rem;
  /* 32px：竖线距卡片左缘；标题行左内边距 */
}

.news-aside-recommend__head {
  width: 100%;
}

.news-aside-recommend__title-row {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0 1rem 0.75rem var(--news-aside-gutter);
}

.news-aside-recommend__head::after {
  content: "";
  display: block;
  width: 100%;
  border-bottom: 1px solid var(--news-aside-line);
}

.news-aside-recommend__star {
  margin-top: 0.125rem;
}

.news-aside-recommend__title {
  margin: 0;
  padding: 0;
  min-width: 0;
  flex: 1;
  font-size: 16px;
  font-weight: 600;
  color: var(--color-primary);
}

.news-aside-recommend__body {
  position: relative;
}

.news-aside-recommend__body::before {
  content: "";
  position: absolute;
  left: var(--news-aside-gutter);
  top: 1.5rem;
  bottom: 1.5rem;
  width: 1px;
  background: var(--news-aside-line);
  z-index: 0;
}

.news-aside-recommend__list {
  position: relative;
  z-index: 1;
  margin: 0;
  padding: 0.35rem 0 0;
  list-style: none;
}

.news-aside-recommend__item {
  position: relative;
  margin: 0 0 1rem;
  padding: 0 0 0 8px;
}

.news-aside-recommend__item:last-child {
  margin-bottom: 0;
}

/* 圆心落在距卡片左 32px 的竖线上（列表区与竖线同起点 pl-8） */

.news-aside-recommend__item::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 0.4rem;
  z-index: 2;
  width: 14px;
  height: 14px;
  border-radius: 9999px;
  background: #fff;
  box-shadow: 0 0 0 1px rgba(0, 102, 51, 0.12);
}

.news-aside-recommend__link {
  display: block;
  padding-left: 0;
  text-decoration: none;
  color: inherit;
}

.news-aside-recommend__link:hover .news-aside-recommend__text {
  color: var(--color-primary);
}

.dark .news-aside-recommend__text,
.dark .news-aside-recommend__date {
  color: rgb(255 255 255 / 0.8);
}

.dark .news-aside-recommend__link:hover .news-aside-recommend__text,
.dark .news-aside-recommend__link:hover .news-aside-recommend__date {
  color: rgb(255 255 255 / 0.9);
}

.news-aside-recommend__preview {
  margin: 0 0 0.5rem;
  overflow: hidden;
  border-radius: 0.5rem;
  background: rgba(15, 23, 42, 0.04);
}

/* 每条新闻内各有一份预览；默认第一条，悬停显对应条（无过渡，避免侧栏高度跳动） */

.news-aside-recommend__item .news-aside-recommend__preview {
  display: none;
}

.news-aside-recommend__body:not(:has(.news-aside-recommend__item:hover))
.news-aside-recommend__item:first-child
.news-aside-recommend__preview,
.news-aside-recommend__body:has(.news-aside-recommend__item:nth-child(1):hover)
.news-aside-recommend__item:nth-child(1)
.news-aside-recommend__preview,
.news-aside-recommend__body:has(.news-aside-recommend__item:nth-child(2):hover)
.news-aside-recommend__item:nth-child(2)
.news-aside-recommend__preview,
.news-aside-recommend__body:has(.news-aside-recommend__item:nth-child(3):hover)
.news-aside-recommend__item:nth-child(3)
.news-aside-recommend__preview,
.news-aside-recommend__body:has(.news-aside-recommend__item:nth-child(4):hover)
.news-aside-recommend__item:nth-child(4)
.news-aside-recommend__preview {
  display: block;
}

.news-aside-recommend__preview-img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  -o-object-fit: cover;
     object-fit: cover;
}

.news-aside-recommend__date {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  margin: 0 0 0.35rem;
  padding: 0 12px 0 10px;
  font-size: 12px;
  line-height: 1.25;
  color: var(--color-primary);
  background-image: url("../img/tag.svg");
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 100% 100%;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
}

.news-aside-recommend__text {
  display: block;
  font-size: 1rem;
  line-height: 1.5;
  color: #666;
}

.thumb-placeholder {
  background:
          linear-gradient(145deg, rgba(0, 102, 51, 0.18), rgba(0, 68, 34, 0.35)),
          linear-gradient(180deg, #b7d6c4, #7fb08f);
}

@media (min-width: 768px) {
  .inner-hero {
    height: 25vh;
    min-height: 25vh;
  }
}

.breadcrumb {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.5rem;
  line-height: 1.75;
  padding: 0.35rem 0;
  color: rgb(107 114 128);
}

.breadcrumb li + li::before {
  content: "/";
  margin-right: 0.5rem;
  color: rgba(100, 116, 139, 0.9);
}

.breadcrumb li:first-child a {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.dark .breadcrumb,
.dark .breadcrumb li,
.dark .breadcrumb a,
.dark .breadcrumb span {
  color: rgba(255, 255, 255, 0.75) !important;
}

.dark .breadcrumb li + li::before {
  color: rgba(255, 255, 255, 0.75);
}

.breadcrumb li:first-child a::before {
  font-family: "iconfont", "Font Awesome 5 Free", "Font Awesome 6 Free", sans-serif;
  content: "\e65b";
  display: inline-block;
  font-size: 18px;
  line-height: 1;
  width: 1em;
  text-align: center;
  vertical-align: -0.1em;
}

.master-style-title {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 37px;
  padding: 0 1rem;
  font-size: 24px;
  font-weight: 600;
  color: var(--color-primary);
}

.master-style-title::before,
.master-style-title::after {
  content: "";
  width: 202px;
  height: 37px;
}

.master-style-title::before {
  margin-right: 14px;
  background: linear-gradient(270deg, rgba(0, 102, 51, 0.75) 22.6%, rgba(29, 144, 89, 0.57) 52.4%, rgba(59, 168, 115, 0.4) 65.38%, rgba(125, 223, 174, 0) 99.28%);
}

.master-style-title::after {
  margin-left: 14px;
  background: linear-gradient(90deg, rgba(0, 102, 51, 0.75) 22.6%, rgba(29, 144, 89, 0.57) 52.4%, rgba(59, 168, 115, 0.4) 65.38%, rgba(125, 223, 174, 0) 99.28%);
}

/* 图片灯箱（image-lightbox.js）
 * 整体布局都用原生 CSS，避免依赖 Tailwind 的 absolute / left-1 / z-[100] 等工具类被 JIT 扫描或其他布局规则影响。 */

.image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background-color: rgba(0, 0, 0, 0.45);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
}

@media (min-width: 640px) {
  .image-lightbox {
    padding: 1.5rem;
  }
}

.image-lightbox.is-open {
  display: flex;
}

.image-lb-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  cursor: default;
  background: transparent;
  border: 0;
  padding: 0;
}

.image-lb-prev,
.image-lb-next,
.image-lb-close {
  position: absolute;
  z-index: 20;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  color: #fff;
  background: rgba(255, 255, 255, 0.15);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.image-lb-prev:hover,
.image-lb-next:hover,
.image-lb-close:hover {
  background: rgba(255, 255, 255, 0.25);
}

.image-lb-prev,
.image-lb-next {
  top: 50%;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 9999px;
  transform: translateY(-50%);
}

.image-lb-prev {
  left: 0.25rem;
}

.image-lb-next {
  right: 0.25rem;
}

@media (min-width: 640px) {
  .image-lb-prev,
  .image-lb-next {
    width: 3rem;
    height: 3rem;
  }

  .image-lb-prev {
    left: 1rem;
  }

  .image-lb-next {
    right: 1rem;
  }
}

.image-lb-close {
  top: 0.75rem;
  right: 0.25rem;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 9999px;
  font-size: 1.5rem;
  font-weight: 300;
  line-height: 1;
}

@media (min-width: 640px) {
  .image-lb-close {
    right: 1rem;
  }
}

.image-lb-stage {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(96vw, 1200px);
  max-height: 88vh;
  padding: 0 2.5rem;
}

@media (min-width: 640px) {
  .image-lb-stage {
    padding: 0 3.5rem;
  }
}

.image-lb-img {
  max-width: 100%;
  max-height: calc(88vh - 8.5rem);
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: 0.25rem;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.image-lb-caption {
  margin-top: 0.75rem;
  padding: 0 0.5rem;
  max-width: 100%;
  text-align: center;
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.9);
}

.image-lb-caption:empty {
  display: none;
}

.image-lb-thumbs {
  margin-top: 0.75rem;
  width: 100%;
  overflow-x: auto;
  padding-bottom: 0.25rem;
}

.image-lb-thumb-track {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin: 0 auto;
  width: -moz-max-content;
  width: max-content;
  min-width: 100%;
}

.image-lb-thumb {
  flex-shrink: 0;
  width: 5rem;
  height: 3.5rem;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(0, 0, 0, 0.2);
  padding: 0;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.image-lb-thumb:hover {
  border-color: rgba(255, 255, 255, 0.7);
}

.image-lb-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0.75;
  transition: opacity 0.2s ease;
}

.image-lb-thumb:hover img {
  opacity: 1;
}

.image-lb-thumb.is-active {
  border-color: #fff;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.65);
}

.image-lb-thumb.is-active img {
  opacity: 1;
}

.image-lb-prev.is-hidden,
.image-lb-next.is-hidden {
  display: none;
}

/* Unified pager style for FastAdmin pagination markup */

.pager {
  margin: 0;
  padding: 0.75rem 0;
  text-align: center;
}

.pager .pagination {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.pager .pagination > li {
  display: inline-flex;
  margin: 0;
}

.pager .pagination > li > a,
.pager .pagination > li > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 0.75rem;
  border-radius: 0.375rem;
  border: 1px solid rgba(0, 0, 0, 0.1);
  background: #fff;
  color: var(--color-text);
  font-size: 0.875rem;
  line-height: 1;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.pager .pagination > li > a:hover,
.pager .pagination > li > a:focus {
  background: rgba(0, 0, 0, 0.04);
  color: var(--color-text);
  outline: none;
}

.pager .pagination > .active > span,
.pager .pagination > .active > a,
.pager .pagination > .active > span:hover,
.pager .pagination > .active > a:hover {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: #fff;
}

.pager .pagination > .disabled > span,
.pager .pagination > .disabled > a,
.pager .pagination > .disabled > span:hover,
.pager .pagination > .disabled > a:hover {
  border-color: rgba(0, 0, 0, 0.08);
  background: #fff;
  color: rgba(0, 0, 0, 0.35);
  cursor: not-allowed;
}

.dark .pager .pagination > li > a,
.dark .pager .pagination > li > span {
  border-color: rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.26);
  color: var(--color-primary);
}

.dark .pager .pagination > li > a:hover,
.dark .pager .pagination > li > a:focus {
  border-color: rgba(255, 255, 255, 0.36);
  background: rgba(255, 255, 255, 0.34);
  color: var(--color-primary);
}

.dark .pager .pagination > .active > span,
.dark .pager .pagination > .active > a,
.dark .pager .pagination > .active > span:hover,
.dark .pager .pagination > .active > a:hover {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: #fff;
}

.dark .pager .pagination > .disabled > span,
.dark .pager .pagination > .disabled > a,
.dark .pager .pagination > .disabled > span:hover,
.dark .pager .pagination > .disabled > a:hover {
  border-color: rgba(255, 255, 255, 0.4);
  background: rgba(255, 255, 255, 0.4);
  color: rgba(29, 82, 52, 0.55);
}

.last\:border-b-0:last-child {
  border-bottom-width: 0px;
}

.focus-within\:shadow-\[0_20px_50px_rgba\(15\2c 23\2c 42\2c 0\.22\)\]:focus-within {
  --tw-shadow: 0 20px 50px rgba(15,23,42,0.22);
  --tw-shadow-colored: 0 20px 50px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:-translate-y-1:hover {
  --tw-translate-y: -0.25rem;
  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\: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\:scale-110: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));
}

.hover\:bg-\[var\(--color-primary\)\]:hover {
  background-color: var(--color-primary);
}

.hover\:bg-black\/5:hover {
  background-color: rgb(0 0 0 / 0.05);
}

.hover\:bg-black\/\[0\.03\]:hover {
  background-color: rgb(0 0 0 / 0.03);
}

.hover\:bg-black\/\[0\.04\]:hover {
  background-color: rgb(0 0 0 / 0.04);
}

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

.hover\:bg-white\/10:hover {
  background-color: rgb(255 255 255 / 0.1);
}

.hover\:bg-white\/15:hover {
  background-color: rgb(255 255 255 / 0.15);
}

.hover\:bg-white\/20:hover {
  background-color: rgb(255 255 255 / 0.2);
}

.hover\:bg-white\/70:hover {
  background-color: rgb(255 255 255 / 0.7);
}

.hover\:text-\[var\(--color-primary\)\]:hover {
  color: var(--color-primary);
}

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

.hover\:text-white\/80:hover {
  color: rgb(255 255 255 / 0.8);
}

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

.hover\:opacity-100:hover {
  opacity: 1;
}

.hover\:opacity-95:hover {
  opacity: 0.95;
}

.hover\:shadow-\[0_14px_36px_rgba\(15\2c 23\2c 42\2c 0\.14\)\]:hover {
  --tw-shadow: 0 14px 36px rgba(15,23,42,0.14);
  --tw-shadow-colored: 0 14px 36px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_20px_50px_rgba\(15\2c 23\2c 42\2c 0\.22\)\]:hover {
  --tw-shadow: 0 20px 50px rgba(15,23,42,0.22);
  --tw-shadow-colored: 0 20px 50px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_8px_18px_rgba\(15\2c 23\2c 42\2c 0\.12\)\]:hover {
  --tw-shadow: 0 8px 18px rgba(15,23,42,0.12);
  --tw-shadow-colored: 0 8px 18px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-md:hover {
  --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);
}

.focus\:border-\[var\(--color-primary\)\]:focus {
  border-color: var(--color-primary);
}

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

.focus\:ring-1:focus {
  --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(1px + 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);
}

.focus\:ring-2:focus {
  --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(2px + 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);
}

.focus\:ring-\[var\(--color-primary\)\]:focus {
  --tw-ring-color: var(--color-primary);
}

.focus\:ring-white\/50:focus {
  --tw-ring-color: rgb(255 255 255 / 0.5);
}

.focus-visible\:outline:focus-visible {
  outline-style: solid;
}

.focus-visible\:outline-2:focus-visible {
  outline-width: 2px;
}

.focus-visible\:outline-offset-2:focus-visible {
  outline-offset: 2px;
}

.focus-visible\:outline-\[var\(--color-primary\)\]:focus-visible {
  outline-color: var(--color-primary);
}

.focus-visible\:ring-2: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(2px + 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);
}

.focus-visible\:ring-\[var\(--color-primary\)\]:focus-visible {
  --tw-ring-color: var(--color-primary);
}

.focus-visible\:ring-white\/60:focus-visible {
  --tw-ring-color: rgb(255 255 255 / 0.6);
}

.focus-visible\:ring-offset-2:focus-visible {
  --tw-ring-offset-width: 2px;
}

.group:hover .group-hover\:visible {
  visibility: visible;
}

.group:hover .group-hover\:translate-y-0 {
  --tw-translate-y: 0px;
  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));
}

.group:hover .group-hover\:scale-\[1\.02\] {
  --tw-scale-x: 1.02;
  --tw-scale-y: 1.02;
  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));
}

.group:hover .group-hover\:text-\[var\(--color-primary\)\] {
  color: var(--color-primary);
}

.group:hover .group-hover\:text-\[var\(--color-text\)\] {
  color: var(--color-text);
}

.group:hover .group-hover\:underline {
  text-decoration-line: underline;
}

.group:hover .group-hover\:opacity-100 {
  opacity: 1;
}

.group:hover .group-hover\:shadow-md {
  --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);
}

.dark\:border-white\/10:is(.dark *) {
  border-color: rgb(255 255 255 / 0.1);
}

.dark\:bg-\[color-mix\(in_srgb\2c var\(--color-primary\)_18\%\2c var\(--color-bg\)\)\]:is(.dark *) {
  background-color: color-mix(in srgb,var(--color-primary) 18%,var(--color-bg));
}

.dark\:bg-black\/20:is(.dark *) {
  background-color: rgb(0 0 0 / 0.2);
}

.dark\:bg-black\/60:is(.dark *) {
  background-color: rgb(0 0 0 / 0.6);
}

.dark\:bg-white\/10:is(.dark *) {
  background-color: rgb(255 255 255 / 0.1);
}

.dark\:bg-white\/25:is(.dark *) {
  background-color: rgb(255 255 255 / 0.25);
}

.dark\:bg-white\/5:is(.dark *) {
  background-color: rgb(255 255 255 / 0.05);
}

.dark\:text-red-400:is(.dark *) {
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity));
}

.dark\:text-white\/45:is(.dark *) {
  color: rgb(255 255 255 / 0.45);
}

.dark\:text-white\/50:is(.dark *) {
  color: rgb(255 255 255 / 0.5);
}

.dark\:text-white\/55:is(.dark *) {
  color: rgb(255 255 255 / 0.55);
}

.dark\:text-white\/60:is(.dark *) {
  color: rgb(255 255 255 / 0.6);
}

.dark\:text-white\/65:is(.dark *) {
  color: rgb(255 255 255 / 0.65);
}

.dark\:text-white\/70:is(.dark *) {
  color: rgb(255 255 255 / 0.7);
}

.dark\:text-white\/75:is(.dark *) {
  color: rgb(255 255 255 / 0.75);
}

.dark\:text-white\/80:is(.dark *) {
  color: rgb(255 255 255 / 0.8);
}

.dark\:text-white\/85:is(.dark *) {
  color: rgb(255 255 255 / 0.85);
}

.dark\:text-white\/90:is(.dark *) {
  color: rgb(255 255 255 / 0.9);
}

.dark\:text-white\/95:is(.dark *) {
  color: rgb(255 255 255 / 0.95);
}

.dark\:shadow-\[0_14px_44px_rgba\(0\2c 0\2c 0\2c 0\.45\)\]:is(.dark *) {
  --tw-shadow: 0 14px 44px rgba(0,0,0,0.45);
  --tw-shadow-colored: 0 14px 44px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.dark\:focus-within\:shadow-\[0_20px_50px_rgba\(0\2c 0\2c 0\2c 0\.55\)\]:focus-within:is(.dark *) {
  --tw-shadow: 0 20px 50px rgba(0,0,0,0.55);
  --tw-shadow-colored: 0 20px 50px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.dark\:hover\:bg-white\/10:hover:is(.dark *) {
  background-color: rgb(255 255 255 / 0.1);
}

.dark\:hover\:bg-white\/5:hover:is(.dark *) {
  background-color: rgb(255 255 255 / 0.05);
}

.dark\:hover\:shadow-\[0_20px_50px_rgba\(0\2c 0\2c 0\2c 0\.55\)\]:hover:is(.dark *) {
  --tw-shadow: 0 20px 50px rgba(0,0,0,0.55);
  --tw-shadow-colored: 0 20px 50px 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) {
  .sm\:left-\[145px\] {
    left: 145px;
  }

  .sm\:mx-16 {
    margin-left: 4rem;
    margin-right: 4rem;
  }

  .sm\:h-16 {
    height: 4rem;
  }

  .sm\:h-24 {
    height: 6rem;
  }

  .sm\:h-\[260px\] {
    height: 260px;
  }

  .sm\:h-\[4rem\] {
    height: 4rem;
  }

  .sm\:h-full {
    height: 100%;
  }

  .sm\:min-h-0 {
    min-height: 0px;
  }

  .sm\:min-h-\[230px\] {
    min-height: 230px;
  }

  .sm\:min-h-\[320px\] {
    min-height: 320px;
  }

  .sm\:min-h-full {
    min-height: 100%;
  }

  .sm\:w-16 {
    width: 4rem;
  }

  .sm\:w-\[260px\] {
    width: 260px;
  }

  .sm\:w-\[calc\(50\%-0\.75rem\)\] {
    width: calc(50% - 0.75rem);
  }

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

  .sm\:grid-cols-\[200px_1fr\] {
    grid-template-columns: 200px 1fr;
  }

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

  .sm\:items-end {
    align-items: flex-end;
  }

  .sm\:items-stretch {
    align-items: stretch;
  }

  .sm\:gap-7 {
    gap: 1.75rem;
  }

  .sm\:border-\[5px\] {
    border-width: 5px;
  }

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

  .sm\:p-5 {
    padding: 1.25rem;
  }

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

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

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

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

  .sm\:py-10 {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }

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

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

  .sm\:pb-14 {
    padding-bottom: 3.5rem;
  }

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

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

  .sm\:pb-6 {
    padding-bottom: 1.5rem;
  }

  .sm\:pl-\[170px\] {
    padding-left: 170px;
  }

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

  .sm\:pt-12 {
    padding-top: 3rem;
  }

  .sm\:pt-5 {
    padding-top: 1.25rem;
  }

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

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

  .sm\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }

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

  .sm\:text-\[32px\] {
    font-size: 32px;
  }

  .sm\:text-\[68px\] {
    font-size: 68px;
  }

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

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

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

@media (min-width: 768px) {
  .md\:bottom-4 {
    bottom: 1rem;
  }

  .md\:left-20 {
    left: 5rem;
  }

  .md\:mb-12 {
    margin-bottom: 3rem;
  }

  .md\:inline {
    display: inline;
  }

  .md\:flex {
    display: flex;
  }

  .md\:h-12 {
    height: 3rem;
  }

  .md\:h-80 {
    height: 20rem;
  }

  .md\:min-h-12 {
    min-height: 3rem;
  }

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

  .md\:w-\[calc\(100\%-5rem\)\] {
    width: calc(100% - 5rem);
  }

  .md\:basis-1\/2 {
    flex-basis: 50%;
  }

  .md\:basis-1\/4 {
    flex-basis: 25%;
  }

  .md\:-translate-y-5 {
    --tw-translate-y: -1.25rem;
    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));
  }

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

  .md\:items-baseline {
    align-items: baseline;
  }

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

  .md\:gap-10 {
    gap: 2.5rem;
  }

  .md\:space-x-8 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-right: calc(2rem * var(--tw-space-x-reverse));
    margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse)));
  }

  .md\:space-x-9 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-right: calc(2.25rem * var(--tw-space-x-reverse));
    margin-left: calc(2.25rem * calc(1 - var(--tw-space-x-reverse)));
  }

  .md\:space-y-0 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0px * var(--tw-space-y-reverse));
  }

  .md\:p-12 {
    padding: 3rem;
  }

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

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

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

  .md\:py-0 {
    padding-top: 0px;
    padding-bottom: 0px;
  }

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

  .md\:py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

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

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

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

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

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

  .md\:pt-12 {
    padding-top: 3rem;
  }

  .md\:pl-2\.5 {
    padding-left: 0.625rem;
  }

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

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

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

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

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

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

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

@media (min-width: 1024px) {
  .lg\:mb-4 {
    margin-bottom: 1rem;
  }

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

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

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

  .lg\:flex {
    display: flex;
  }

  .lg\:hidden {
    display: none;
  }

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

  .lg\:h-\[320px\] {
    height: 320px;
  }

  .lg\:h-\[350px\] {
    height: 350px;
  }

  .lg\:h-\[360px\] {
    height: 360px;
  }

  .lg\:h-\[450px\] {
    height: 450px;
  }

  .lg\:h-\[740px\] {
    height: 740px;
  }

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

  .lg\:h-full {
    height: 100%;
  }

  .lg\:max-h-\[740px\] {
    max-height: 740px;
  }

  .lg\:min-h-0 {
    min-height: 0px;
  }

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

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

  .lg\:w-1\/6 {
    width: 16.666667%;
  }

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

  .lg\:w-\[500px\] {
    width: 500px;
  }

  .lg\:w-\[540px\] {
    width: 540px;
  }

  .lg\:w-\[650px\] {
    width: 650px;
  }

  .lg\:w-\[740px\] {
    width: 740px;
  }

  .lg\:w-auto {
    width: auto;
  }

  .lg\:min-w-\[10rem\] {
    min-width: 10rem;
  }

  .lg\:max-w-none {
    max-width: none;
  }

  .lg\:flex-1 {
    flex: 1 1 0%;
  }

  .lg\:shrink-0 {
    flex-shrink: 0;
  }

  .lg\:basis-1\/5 {
    flex-basis: 20%;
  }

  .lg\:basis-4\/5 {
    flex-basis: 80%;
  }

  .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-\[1\.3fr_1fr\] {
    grid-template-columns: 1.3fr 1fr;
  }

  .lg\:grid-cols-\[1fr_1\.2fr\] {
    grid-template-columns: 1fr 1.2fr;
  }

  .lg\:grid-cols-\[1fr_1\.3fr\] {
    grid-template-columns: 1fr 1.3fr;
  }

  .lg\:grid-cols-\[1fr_320px\] {
    grid-template-columns: 1fr 320px;
  }

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

  .lg\:flex-nowrap {
    flex-wrap: nowrap;
  }

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

  .lg\:items-end {
    align-items: flex-end;
  }

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

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

  .lg\:gap-12 {
    gap: 3rem;
  }

  .lg\:gap-5 {
    gap: 1.25rem;
  }

  .lg\:gap-8 {
    gap: 2rem;
  }

  .lg\:p-4 {
    padding: 1rem;
  }

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

  .lg\:px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

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

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

  .lg\:pr-8 {
    padding-right: 2rem;
  }

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

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

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

  .lg\:leading-6 {
    line-height: 1.5rem;
  }
}


