/* PathHub 设计 token（与 packages/ui-kit/src/styles.css 同步） */
/*
 * 模块 16.2 字体：Inter + PingFang SC + Microsoft YaHei → 与 ref pack 字栈一致
 * 字体文件本身从 Google Fonts CDN 拉（见 apps/web/index.html <link>），
 * 切换到 self-host 时在本文件加 @font-face（参考 public/fonts/README.md）。
 *
 * Self-host 切换时反注释下面这段并把 woff2 文件放进 public/fonts/：
 * @font-face {
 *   font-family: 'Inter';
 *   font-style: normal;
 *   font-weight: 400 500 600;
 *   font-display: swap;
 *   src: url('/fonts/Inter-Variable.woff2') format('woff2');
 * }
 * @font-face {
 *   font-family: 'Cormorant Garamond';
 *   font-style: normal;
 *   font-weight: 500 600;
 *   font-display: swap;
 *   src: url('/fonts/CormorantGaramond-Medium.woff2') format('woff2');
 * }
 */
:root {
  --color-primary: #064E3B;
  --color-primary-mid: #047857;
  --color-primary-light: #10B981;
  --color-bg: #FFFFFF;
  --color-bg-warm: #F8F9FA;
  --color-bg-tint: #D1FAE5;
  --color-text: #1F2937;
  --color-text-muted: #64748B;
  --color-border: #E5E7EB;
  --font-sans: 'Inter', 'PingFang SC', 'Microsoft YaHei', system-ui, -apple-system, sans-serif;
  --font-serif: 'Cormorant Garamond', 'Source Serif Pro', Georgia, 'PingFang SC', serif;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.06);
}

*, ::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.19 | 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: Inter, PingFang SC, Microsoft YaHei, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif; /* 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;
}
.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;
  }
}
.pointer-events-none {
  pointer-events: none;
}
.pointer-events-auto {
  pointer-events: auto;
}
.\!visible {
  visibility: visible !important;
}
.visible {
  visibility: visible;
}
.collapse {
  visibility: collapse;
}
.static {
  position: static;
}
.fixed {
  position: fixed;
}
.absolute {
  position: absolute;
}
.relative {
  position: relative;
}
.sticky {
  position: sticky;
}
.inset-0 {
  inset: 0px;
}
.inset-x-0 {
  left: 0px;
  right: 0px;
}
.inset-y-0 {
  top: 0px;
  bottom: 0px;
}
.-top-3 {
  top: -0.75rem;
}
.bottom-0 {
  bottom: 0px;
}
.bottom-12 {
  bottom: 3rem;
}
.bottom-16 {
  bottom: 4rem;
}
.bottom-3 {
  bottom: 0.75rem;
}
.bottom-4 {
  bottom: 1rem;
}
.bottom-6 {
  bottom: 1.5rem;
}
.left-0 {
  left: 0px;
}
.left-1\/2 {
  left: 50%;
}
.left-2 {
  left: 0.5rem;
}
.left-2\.5 {
  left: 0.625rem;
}
.left-3 {
  left: 0.75rem;
}
.left-3\.5 {
  left: 0.875rem;
}
.left-6 {
  left: 1.5rem;
}
.right-0 {
  right: 0px;
}
.right-2 {
  right: 0.5rem;
}
.right-3 {
  right: 0.75rem;
}
.right-4 {
  right: 1rem;
}
.right-6 {
  right: 1.5rem;
}
.top-0 {
  top: 0px;
}
.top-1\/2 {
  top: 50%;
}
.top-10 {
  top: 2.5rem;
}
.top-20 {
  top: 5rem;
}
.top-4 {
  top: 1rem;
}
.top-5 {
  top: 1.25rem;
}
.top-8 {
  top: 2rem;
}
.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;
}
.z-\[60\] {
  z-index: 60;
}
.z-\[9999\] {
  z-index: 9999;
}
.m-auto {
  margin: auto;
}
.-my-1 {
  margin-top: -0.25rem;
  margin-bottom: -0.25rem;
}
.mx-1\.5 {
  margin-left: 0.375rem;
  margin-right: 0.375rem;
}
.mx-3\.5 {
  margin-left: 0.875rem;
  margin-right: 0.875rem;
}
.mx-5 {
  margin-left: 1.25rem;
  margin-right: 1.25rem;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.-mt-6 {
  margin-top: -1.5rem;
}
.mb-0\.5 {
  margin-bottom: 0.125rem;
}
.mb-1 {
  margin-bottom: 0.25rem;
}
.mb-1\.5 {
  margin-bottom: 0.375rem;
}
.mb-10 {
  margin-bottom: 2.5rem;
}
.mb-12 {
  margin-bottom: 3rem;
}
.mb-14 {
  margin-bottom: 3.5rem;
}
.mb-16 {
  margin-bottom: 4rem;
}
.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-8 {
  margin-bottom: 2rem;
}
.ml-0\.5 {
  margin-left: 0.125rem;
}
.ml-1 {
  margin-left: 0.25rem;
}
.ml-1\.5 {
  margin-left: 0.375rem;
}
.ml-2 {
  margin-left: 0.5rem;
}
.ml-5 {
  margin-left: 1.25rem;
}
.ml-auto {
  margin-left: auto;
}
.mr-0\.5 {
  margin-right: 0.125rem;
}
.mr-1 {
  margin-right: 0.25rem;
}
.mr-1\.5 {
  margin-right: 0.375rem;
}
.mr-2 {
  margin-right: 0.5rem;
}
.mt-0\.5 {
  margin-top: 0.125rem;
}
.mt-1 {
  margin-top: 0.25rem;
}
.mt-1\.5 {
  margin-top: 0.375rem;
}
.mt-10 {
  margin-top: 2.5rem;
}
.mt-16 {
  margin-top: 4rem;
}
.mt-2 {
  margin-top: 0.5rem;
}
.mt-2\.5 {
  margin-top: 0.625rem;
}
.mt-3 {
  margin-top: 0.75rem;
}
.mt-4 {
  margin-top: 1rem;
}
.mt-5 {
  margin-top: 1.25rem;
}
.mt-6 {
  margin-top: 1.5rem;
}
.mt-7 {
  margin-top: 1.75rem;
}
.mt-8 {
  margin-top: 2rem;
}
.line-clamp-1 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}
.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;
}
.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\/10\] {
  aspect-ratio: 16/10;
}
.aspect-\[4\/3\] {
  aspect-ratio: 4/3;
}
.h-0\.5 {
  height: 0.125rem;
}
.h-1 {
  height: 0.25rem;
}
.h-1\.5 {
  height: 0.375rem;
}
.h-10 {
  height: 2.5rem;
}
.h-11 {
  height: 2.75rem;
}
.h-12 {
  height: 3rem;
}
.h-14 {
  height: 3.5rem;
}
.h-16 {
  height: 4rem;
}
.h-2 {
  height: 0.5rem;
}
.h-2\.5 {
  height: 0.625rem;
}
.h-24 {
  height: 6rem;
}
.h-3 {
  height: 0.75rem;
}
.h-3\.5 {
  height: 0.875rem;
}
.h-4 {
  height: 1rem;
}
.h-48 {
  height: 12rem;
}
.h-5 {
  height: 1.25rem;
}
.h-56 {
  height: 14rem;
}
.h-6 {
  height: 1.5rem;
}
.h-64 {
  height: 16rem;
}
.h-7 {
  height: 1.75rem;
}
.h-8 {
  height: 2rem;
}
.h-9 {
  height: 2.25rem;
}
.h-\[14px\] {
  height: 14px;
}
.h-\[2px\] {
  height: 2px;
}
.h-\[70vh\] {
  height: 70vh;
}
.h-full {
  height: 100%;
}
.h-px {
  height: 1px;
}
.max-h-32 {
  max-height: 8rem;
}
.max-h-48 {
  max-height: 12rem;
}
.max-h-60 {
  max-height: 15rem;
}
.max-h-64 {
  max-height: 16rem;
}
.max-h-72 {
  max-height: 18rem;
}
.max-h-80 {
  max-height: 20rem;
}
.max-h-96 {
  max-height: 24rem;
}
.max-h-\[50vh\] {
  max-height: 50vh;
}
.max-h-\[520px\] {
  max-height: 520px;
}
.max-h-\[60vh\] {
  max-height: 60vh;
}
.max-h-\[70vh\] {
  max-height: 70vh;
}
.max-h-\[80vh\] {
  max-height: 80vh;
}
.max-h-\[85vh\] {
  max-height: 85vh;
}
.max-h-\[88vh\] {
  max-height: 88vh;
}
.max-h-\[90vh\] {
  max-height: 90vh;
}
.min-h-0 {
  min-height: 0px;
}
.min-h-\[1\.2em\] {
  min-height: 1.2em;
}
.min-h-\[110px\] {
  min-height: 110px;
}
.min-h-\[120px\] {
  min-height: 120px;
}
.min-h-\[140px\] {
  min-height: 140px;
}
.min-h-\[160px\] {
  min-height: 160px;
}
.min-h-\[280px\] {
  min-height: 280px;
}
.min-h-\[2em\] {
  min-height: 2em;
}
.min-h-\[320px\] {
  min-height: 320px;
}
.min-h-\[400px\] {
  min-height: 400px;
}
.min-h-\[80px\] {
  min-height: 80px;
}
.min-h-full {
  min-height: 100%;
}
.min-h-screen {
  min-height: 100vh;
}
.w-0\.5 {
  width: 0.125rem;
}
.w-1 {
  width: 0.25rem;
}
.w-1\.5 {
  width: 0.375rem;
}
.w-1\/2 {
  width: 50%;
}
.w-10 {
  width: 2.5rem;
}
.w-11 {
  width: 2.75rem;
}
.w-12 {
  width: 3rem;
}
.w-14 {
  width: 3.5rem;
}
.w-16 {
  width: 4rem;
}
.w-2 {
  width: 0.5rem;
}
.w-2\.5 {
  width: 0.625rem;
}
.w-20 {
  width: 5rem;
}
.w-24 {
  width: 6rem;
}
.w-28 {
  width: 7rem;
}
.w-3 {
  width: 0.75rem;
}
.w-3\.5 {
  width: 0.875rem;
}
.w-32 {
  width: 8rem;
}
.w-36 {
  width: 9rem;
}
.w-4 {
  width: 1rem;
}
.w-40 {
  width: 10rem;
}
.w-48 {
  width: 12rem;
}
.w-5 {
  width: 1.25rem;
}
.w-6 {
  width: 1.5rem;
}
.w-64 {
  width: 16rem;
}
.w-7 {
  width: 1.75rem;
}
.w-8 {
  width: 2rem;
}
.w-9 {
  width: 2.25rem;
}
.w-\[14px\] {
  width: 14px;
}
.w-\[320px\] {
  width: 320px;
}
.w-\[380px\] {
  width: 380px;
}
.w-\[420px\] {
  width: 420px;
}
.w-\[480px\] {
  width: 480px;
}
.w-\[560px\] {
  width: 560px;
}
.w-\[760px\] {
  width: 760px;
}
.w-\[90\%\] {
  width: 90%;
}
.w-full {
  width: 100%;
}
.min-w-0 {
  min-width: 0px;
}
.min-w-\[160px\] {
  min-width: 160px;
}
.min-w-\[180px\] {
  min-width: 180px;
}
.min-w-\[200px\] {
  min-width: 200px;
}
.min-w-\[240px\] {
  min-width: 240px;
}
.min-w-\[260px\] {
  min-width: 260px;
}
.min-w-\[280px\] {
  min-width: 280px;
}
.min-w-\[700px\] {
  min-width: 700px;
}
.min-w-\[88px\] {
  min-width: 88px;
}
.min-w-full {
  min-width: 100%;
}
.max-w-2xl {
  max-width: 42rem;
}
.max-w-3xl {
  max-width: 48rem;
}
.max-w-4xl {
  max-width: 56rem;
}
.max-w-5xl {
  max-width: 64rem;
}
.max-w-6xl {
  max-width: 72rem;
}
.max-w-\[1200px\] {
  max-width: 1200px;
}
.max-w-\[120px\] {
  max-width: 120px;
}
.max-w-\[1600px\] {
  max-width: 1600px;
}
.max-w-\[200px\] {
  max-width: 200px;
}
.max-w-\[240px\] {
  max-width: 240px;
}
.max-w-\[360px\] {
  max-width: 360px;
}
.max-w-\[600px\] {
  max-width: 600px;
}
.max-w-\[720px\] {
  max-width: 720px;
}
.max-w-\[80\%\] {
  max-width: 80%;
}
.max-w-\[800px\] {
  max-width: 800px;
}
.max-w-\[88\%\] {
  max-width: 88%;
}
.max-w-\[90vw\] {
  max-width: 90vw;
}
.max-w-\[92vw\] {
  max-width: 92vw;
}
.max-w-\[94vw\] {
  max-width: 94vw;
}
.max-w-full {
  max-width: 100%;
}
.max-w-lg {
  max-width: 32rem;
}
.max-w-md {
  max-width: 28rem;
}
.max-w-none {
  max-width: none;
}
.max-w-sm {
  max-width: 24rem;
}
.max-w-xl {
  max-width: 36rem;
}
.max-w-xs {
  max-width: 20rem;
}
.flex-1 {
  flex: 1 1 0%;
}
.flex-shrink-0 {
  flex-shrink: 0;
}
.shrink-0 {
  flex-shrink: 0;
}
.-translate-x-1\/2 {
  --tw-translate-x: -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-x-full {
  --tw-translate-x: -100%;
  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\/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));
}
.rotate-180 {
  --tw-rotate: 180deg;
  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));
}
.animate-\[ph-bounce_1\.2s_ease-in-out_infinite\] {
  animation: ph-bounce 1.2s ease-in-out infinite;
}
.animate-\[ph-shimmer_1\.4s_ease-in-out_infinite\] {
  animation: ph-shimmer 1.4s ease-in-out infinite;
}
@keyframes pulse {
  50% {
    opacity: .5;
  }
}
.animate-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.animate-spin {
  animation: spin 1s linear infinite;
}
.cursor-default {
  cursor: default;
}
.cursor-grab {
  cursor: grab;
}
.cursor-not-allowed {
  cursor: not-allowed;
}
.cursor-pointer {
  cursor: pointer;
}
.select-none {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.resize-none {
  resize: none;
}
.resize-y {
  resize: vertical;
}
.resize {
  resize: both;
}
.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));
}
.grid-cols-7 {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}
.grid-cols-\[auto_1fr\] {
  grid-template-columns: auto 1fr;
}
.grid-rows-\[repeat\(auto-fill\2c minmax\(110px\2c 1fr\)\)\] {
  grid-template-rows: repeat(auto-fill,minmax(110px,1fr));
}
.flex-row {
  flex-direction: row;
}
.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-0\.5 {
  gap: 0.125rem;
}
.gap-1 {
  gap: 0.25rem;
}
.gap-1\.5 {
  gap: 0.375rem;
}
.gap-12 {
  gap: 3rem;
}
.gap-2 {
  gap: 0.5rem;
}
.gap-2\.5 {
  gap: 0.625rem;
}
.gap-3 {
  gap: 0.75rem;
}
.gap-4 {
  gap: 1rem;
}
.gap-5 {
  gap: 1.25rem;
}
.gap-6 {
  gap: 1.5rem;
}
.gap-8 {
  gap: 2rem;
}
.gap-px {
  gap: 1px;
}
.gap-x-3 {
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
}
.gap-x-4 {
  -moz-column-gap: 1rem;
       column-gap: 1rem;
}
.gap-y-1 {
  row-gap: 0.25rem;
}
.space-y-0\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.125rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.125rem * var(--tw-space-y-reverse));
}
.space-y-1 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.25rem * var(--tw-space-y-reverse));
}
.space-y-1\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.375rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.375rem * var(--tw-space-y-reverse));
}
.space-y-12 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(3rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(3rem * var(--tw-space-y-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-2\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.625rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.625rem * 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-5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.25rem * 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));
}
.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-border > :not([hidden]) ~ :not([hidden]) {
  --tw-divide-opacity: 1;
  border-color: rgb(229 231 235 / var(--tw-divide-opacity, 1));
}
.divide-border\/60 > :not([hidden]) ~ :not([hidden]) {
  border-color: rgb(229 231 235 / 0.6);
}
.divide-slate-800 > :not([hidden]) ~ :not([hidden]) {
  --tw-divide-opacity: 1;
  border-color: rgb(30 41 59 / var(--tw-divide-opacity, 1));
}
.divide-slate-800\/60 > :not([hidden]) ~ :not([hidden]) {
  border-color: rgb(30 41 59 / 0.6);
}
.self-center {
  align-self: center;
}
.overflow-auto {
  overflow: auto;
}
.overflow-hidden {
  overflow: hidden;
}
.overflow-x-auto {
  overflow-x: auto;
}
.overflow-y-auto {
  overflow-y: auto;
}
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.whitespace-nowrap {
  white-space: nowrap;
}
.whitespace-pre-line {
  white-space: pre-line;
}
.whitespace-pre-wrap {
  white-space: pre-wrap;
}
.break-words {
  overflow-wrap: break-word;
}
.break-all {
  word-break: break-all;
}
.rounded {
  border-radius: 0.25rem;
}
.rounded-2xl {
  border-radius: 1rem;
}
.rounded-3xl {
  border-radius: 1.5rem;
}
.rounded-full {
  border-radius: 9999px;
}
.rounded-lg {
  border-radius: 0.5rem;
}
.rounded-lg-token {
  border-radius: 16px;
}
.rounded-md {
  border-radius: 0.375rem;
}
.rounded-md-token {
  border-radius: 12px;
}
.rounded-sm {
  border-radius: 0.125rem;
}
.rounded-sm-token {
  border-radius: 8px;
}
.rounded-xl {
  border-radius: 0.75rem;
}
.rounded-xl-token {
  border-radius: 24px;
}
.rounded-r {
  border-top-right-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
}
.rounded-t-lg {
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}
.border {
  border-width: 1px;
}
.border-2 {
  border-width: 2px;
}
.border-\[3px\] {
  border-width: 3px;
}
.border-y {
  border-top-width: 1px;
  border-bottom-width: 1px;
}
.border-b {
  border-bottom-width: 1px;
}
.border-b-2 {
  border-bottom-width: 2px;
}
.border-l {
  border-left-width: 1px;
}
.border-l-2 {
  border-left-width: 2px;
}
.border-l-4 {
  border-left-width: 4px;
}
.border-r {
  border-right-width: 1px;
}
.border-t {
  border-top-width: 1px;
}
.border-t-2 {
  border-top-width: 2px;
}
.border-dashed {
  border-style: dashed;
}
.border-\[\#1F4D3F\] {
  --tw-border-opacity: 1;
  border-color: rgb(31 77 63 / var(--tw-border-opacity, 1));
}
.border-\[\#1F4D3F\]\/10 {
  border-color: rgb(31 77 63 / 0.1);
}
.border-\[\#1F4D3F\]\/20 {
  border-color: rgb(31 77 63 / 0.2);
}
.border-\[\#1F4D3F\]\/30 {
  border-color: rgb(31 77 63 / 0.3);
}
.border-\[\#C9A84C\] {
  --tw-border-opacity: 1;
  border-color: rgb(201 168 76 / var(--tw-border-opacity, 1));
}
.border-\[\#C9A84C\]\/20 {
  border-color: rgb(201 168 76 / 0.2);
}
.border-\[\#C9A84C\]\/30 {
  border-color: rgb(201 168 76 / 0.3);
}
.border-\[\#C9A84C\]\/40 {
  border-color: rgb(201 168 76 / 0.4);
}
.border-\[\#C9A84C\]\/50 {
  border-color: rgb(201 168 76 / 0.5);
}
.border-\[\#E5E7EB\] {
  --tw-border-opacity: 1;
  border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}
.border-amber-100 {
  --tw-border-opacity: 1;
  border-color: rgb(254 243 199 / var(--tw-border-opacity, 1));
}
.border-amber-200 {
  --tw-border-opacity: 1;
  border-color: rgb(253 230 138 / var(--tw-border-opacity, 1));
}
.border-amber-300 {
  --tw-border-opacity: 1;
  border-color: rgb(252 211 77 / var(--tw-border-opacity, 1));
}
.border-amber-500 {
  --tw-border-opacity: 1;
  border-color: rgb(245 158 11 / var(--tw-border-opacity, 1));
}
.border-amber-700\/30 {
  border-color: rgb(180 83 9 / 0.3);
}
.border-amber-700\/40 {
  border-color: rgb(180 83 9 / 0.4);
}
.border-amber-700\/50 {
  border-color: rgb(180 83 9 / 0.5);
}
.border-bg-tint {
  --tw-border-opacity: 1;
  border-color: rgb(209 250 229 / var(--tw-border-opacity, 1));
}
.border-blue-200 {
  --tw-border-opacity: 1;
  border-color: rgb(191 219 254 / var(--tw-border-opacity, 1));
}
.border-blue-700\/40 {
  border-color: rgb(29 78 216 / 0.4);
}
.border-blue-700\/50 {
  border-color: rgb(29 78 216 / 0.5);
}
.border-border {
  --tw-border-opacity: 1;
  border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}
.border-border\/40 {
  border-color: rgb(229 231 235 / 0.4);
}
.border-border\/60 {
  border-color: rgb(229 231 235 / 0.6);
}
.border-border\/70 {
  border-color: rgb(229 231 235 / 0.7);
}
.border-emerald-100 {
  --tw-border-opacity: 1;
  border-color: rgb(209 250 229 / var(--tw-border-opacity, 1));
}
.border-emerald-200 {
  --tw-border-opacity: 1;
  border-color: rgb(167 243 208 / var(--tw-border-opacity, 1));
}
.border-emerald-300 {
  --tw-border-opacity: 1;
  border-color: rgb(110 231 183 / var(--tw-border-opacity, 1));
}
.border-emerald-400 {
  --tw-border-opacity: 1;
  border-color: rgb(52 211 153 / var(--tw-border-opacity, 1));
}
.border-emerald-500 {
  --tw-border-opacity: 1;
  border-color: rgb(16 185 129 / var(--tw-border-opacity, 1));
}
.border-emerald-700\/40 {
  border-color: rgb(4 120 87 / 0.4);
}
.border-emerald-700\/50 {
  border-color: rgb(4 120 87 / 0.5);
}
.border-ink-muted\/20 {
  border-color: rgb(100 116 139 / 0.2);
}
.border-orange-100 {
  --tw-border-opacity: 1;
  border-color: rgb(255 237 213 / var(--tw-border-opacity, 1));
}
.border-orange-200 {
  --tw-border-opacity: 1;
  border-color: rgb(254 215 170 / var(--tw-border-opacity, 1));
}
.border-primary {
  --tw-border-opacity: 1;
  border-color: rgb(6 78 59 / var(--tw-border-opacity, 1));
}
.border-primary-light {
  --tw-border-opacity: 1;
  border-color: rgb(16 185 129 / var(--tw-border-opacity, 1));
}
.border-primary-light\/40 {
  border-color: rgb(16 185 129 / 0.4);
}
.border-primary\/15 {
  border-color: rgb(6 78 59 / 0.15);
}
.border-primary\/30 {
  border-color: rgb(6 78 59 / 0.3);
}
.border-primary\/40 {
  border-color: rgb(6 78 59 / 0.4);
}
.border-purple-700\/50 {
  border-color: rgb(126 34 206 / 0.5);
}
.border-red-100 {
  --tw-border-opacity: 1;
  border-color: rgb(254 226 226 / var(--tw-border-opacity, 1));
}
.border-red-200 {
  --tw-border-opacity: 1;
  border-color: rgb(254 202 202 / var(--tw-border-opacity, 1));
}
.border-red-300 {
  --tw-border-opacity: 1;
  border-color: rgb(252 165 165 / var(--tw-border-opacity, 1));
}
.border-red-700\/40 {
  border-color: rgb(185 28 28 / 0.4);
}
.border-red-700\/50 {
  border-color: rgb(185 28 28 / 0.5);
}
.border-rose-100 {
  --tw-border-opacity: 1;
  border-color: rgb(255 228 230 / var(--tw-border-opacity, 1));
}
.border-rose-200 {
  --tw-border-opacity: 1;
  border-color: rgb(254 205 211 / var(--tw-border-opacity, 1));
}
.border-rose-300 {
  --tw-border-opacity: 1;
  border-color: rgb(253 164 175 / var(--tw-border-opacity, 1));
}
.border-rose-500 {
  --tw-border-opacity: 1;
  border-color: rgb(244 63 94 / var(--tw-border-opacity, 1));
}
.border-sky-200 {
  --tw-border-opacity: 1;
  border-color: rgb(186 230 253 / var(--tw-border-opacity, 1));
}
.border-slate-200 {
  --tw-border-opacity: 1;
  border-color: rgb(226 232 240 / var(--tw-border-opacity, 1));
}
.border-slate-300 {
  --tw-border-opacity: 1;
  border-color: rgb(203 213 225 / var(--tw-border-opacity, 1));
}
.border-slate-600\/50 {
  border-color: rgb(71 85 105 / 0.5);
}
.border-slate-700 {
  --tw-border-opacity: 1;
  border-color: rgb(51 65 85 / var(--tw-border-opacity, 1));
}
.border-slate-700\/40 {
  border-color: rgb(51 65 85 / 0.4);
}
.border-slate-700\/50 {
  border-color: rgb(51 65 85 / 0.5);
}
.border-slate-700\/60 {
  border-color: rgb(51 65 85 / 0.6);
}
.border-slate-800 {
  --tw-border-opacity: 1;
  border-color: rgb(30 41 59 / var(--tw-border-opacity, 1));
}
.border-slate-800\/40 {
  border-color: rgb(30 41 59 / 0.4);
}
.border-slate-800\/60 {
  border-color: rgb(30 41 59 / 0.6);
}
.border-transparent {
  border-color: transparent;
}
.border-violet-100 {
  --tw-border-opacity: 1;
  border-color: rgb(237 233 254 / var(--tw-border-opacity, 1));
}
.border-violet-300 {
  --tw-border-opacity: 1;
  border-color: rgb(196 181 253 / var(--tw-border-opacity, 1));
}
.border-violet-300\/30 {
  border-color: rgb(196 181 253 / 0.3);
}
.border-violet-700\/40 {
  border-color: rgb(109 40 217 / 0.4);
}
.border-white\/10 {
  border-color: rgb(255 255 255 / 0.1);
}
.border-white\/30 {
  border-color: rgb(255 255 255 / 0.3);
}
.border-white\/\[0\.06\] {
  border-color: rgb(255 255 255 / 0.06);
}
.border-white\/\[0\.08\] {
  border-color: rgb(255 255 255 / 0.08);
}
.border-t-\[\#C9A84C\] {
  --tw-border-opacity: 1;
  border-top-color: rgb(201 168 76 / var(--tw-border-opacity, 1));
}
.border-t-ink-muted {
  --tw-border-opacity: 1;
  border-top-color: rgb(100 116 139 / var(--tw-border-opacity, 1));
}
.border-t-primary {
  --tw-border-opacity: 1;
  border-top-color: rgb(6 78 59 / var(--tw-border-opacity, 1));
}
.bg-\[\#02040a\] {
  --tw-bg-opacity: 1;
  background-color: rgb(2 4 10 / var(--tw-bg-opacity, 1));
}
.bg-\[\#1F4D3F\] {
  --tw-bg-opacity: 1;
  background-color: rgb(31 77 63 / var(--tw-bg-opacity, 1));
}
.bg-\[\#1F4D3F\]\/10 {
  background-color: rgb(31 77 63 / 0.1);
}
.bg-\[\#1F4D3F\]\/5 {
  background-color: rgb(31 77 63 / 0.05);
}
.bg-\[\#1F4D3F\]\/\[0\.06\] {
  background-color: rgb(31 77 63 / 0.06);
}
.bg-\[\#2C6E55\] {
  --tw-bg-opacity: 1;
  background-color: rgb(44 110 85 / var(--tw-bg-opacity, 1));
}
.bg-\[\#2C6E55\]\/10 {
  background-color: rgb(44 110 85 / 0.1);
}
.bg-\[\#4B5563\]\/10 {
  background-color: rgb(75 85 99 / 0.1);
}
.bg-\[\#C9A84C\] {
  --tw-bg-opacity: 1;
  background-color: rgb(201 168 76 / var(--tw-bg-opacity, 1));
}
.bg-\[\#C9A84C\]\/15 {
  background-color: rgb(201 168 76 / 0.15);
}
.bg-\[\#C9A84C\]\/20 {
  background-color: rgb(201 168 76 / 0.2);
}
.bg-\[\#E5E7EB\] {
  --tw-bg-opacity: 1;
  background-color: rgb(229 231 235 / var(--tw-bg-opacity, 1));
}
.bg-\[\#F5EBD9\]\/60 {
  background-color: rgb(245 235 217 / 0.6);
}
.bg-\[\#F5EBD9\]\/70 {
  background-color: rgb(245 235 217 / 0.7);
}
.bg-\[\#F9FAFB\] {
  --tw-bg-opacity: 1;
  background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
}
.bg-amber-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 243 199 / var(--tw-bg-opacity, 1));
}
.bg-amber-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(255 251 235 / var(--tw-bg-opacity, 1));
}
.bg-amber-50\/50 {
  background-color: rgb(255 251 235 / 0.5);
}
.bg-amber-50\/60 {
  background-color: rgb(255 251 235 / 0.6);
}
.bg-amber-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(245 158 11 / var(--tw-bg-opacity, 1));
}
.bg-amber-500\/10 {
  background-color: rgb(245 158 11 / 0.1);
}
.bg-amber-500\/15 {
  background-color: rgb(245 158 11 / 0.15);
}
.bg-amber-500\/70 {
  background-color: rgb(245 158 11 / 0.7);
}
.bg-amber-900\/10 {
  background-color: rgb(120 53 15 / 0.1);
}
.bg-amber-900\/15 {
  background-color: rgb(120 53 15 / 0.15);
}
.bg-amber-900\/20 {
  background-color: rgb(120 53 15 / 0.2);
}
.bg-amber-900\/30 {
  background-color: rgb(120 53 15 / 0.3);
}
.bg-amber-900\/40 {
  background-color: rgb(120 53 15 / 0.4);
}
.bg-bg {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.bg-bg-tint {
  --tw-bg-opacity: 1;
  background-color: rgb(209 250 229 / var(--tw-bg-opacity, 1));
}
.bg-bg-tint\/30 {
  background-color: rgb(209 250 229 / 0.3);
}
.bg-bg-tint\/50 {
  background-color: rgb(209 250 229 / 0.5);
}
.bg-bg-tint\/60 {
  background-color: rgb(209 250 229 / 0.6);
}
.bg-bg-warm {
  --tw-bg-opacity: 1;
  background-color: rgb(248 249 250 / var(--tw-bg-opacity, 1));
}
.bg-bg-warm\/20 {
  background-color: rgb(248 249 250 / 0.2);
}
.bg-bg-warm\/30 {
  background-color: rgb(248 249 250 / 0.3);
}
.bg-bg-warm\/40 {
  background-color: rgb(248 249 250 / 0.4);
}
.bg-bg-warm\/60 {
  background-color: rgb(248 249 250 / 0.6);
}
.bg-bg-warm\/80 {
  background-color: rgb(248 249 250 / 0.8);
}
.bg-bg\/60 {
  background-color: rgb(255 255 255 / 0.6);
}
.bg-bg\/90 {
  background-color: rgb(255 255 255 / 0.9);
}
.bg-black\/30 {
  background-color: rgb(0 0 0 / 0.3);
}
.bg-black\/40 {
  background-color: rgb(0 0 0 / 0.4);
}
.bg-black\/50 {
  background-color: rgb(0 0 0 / 0.5);
}
.bg-black\/55 {
  background-color: rgb(0 0 0 / 0.55);
}
.bg-black\/60 {
  background-color: rgb(0 0 0 / 0.6);
}
.bg-black\/85 {
  background-color: rgb(0 0 0 / 0.85);
}
.bg-blue-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(239 246 255 / var(--tw-bg-opacity, 1));
}
.bg-blue-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(59 130 246 / var(--tw-bg-opacity, 1));
}
.bg-blue-900\/10 {
  background-color: rgb(30 58 138 / 0.1);
}
.bg-blue-900\/15 {
  background-color: rgb(30 58 138 / 0.15);
}
.bg-blue-900\/30 {
  background-color: rgb(30 58 138 / 0.3);
}
.bg-blue-900\/40 {
  background-color: rgb(30 58 138 / 0.4);
}
.bg-emerald-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(209 250 229 / var(--tw-bg-opacity, 1));
}
.bg-emerald-200\/70 {
  background-color: rgb(167 243 208 / 0.7);
}
.bg-emerald-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(236 253 245 / var(--tw-bg-opacity, 1));
}
.bg-emerald-50\/30 {
  background-color: rgb(236 253 245 / 0.3);
}
.bg-emerald-50\/40 {
  background-color: rgb(236 253 245 / 0.4);
}
.bg-emerald-50\/50 {
  background-color: rgb(236 253 245 / 0.5);
}
.bg-emerald-50\/60 {
  background-color: rgb(236 253 245 / 0.6);
}
.bg-emerald-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(16 185 129 / var(--tw-bg-opacity, 1));
}
.bg-emerald-500\/15 {
  background-color: rgb(16 185 129 / 0.15);
}
.bg-emerald-500\/20 {
  background-color: rgb(16 185 129 / 0.2);
}
.bg-emerald-500\/70 {
  background-color: rgb(16 185 129 / 0.7);
}
.bg-emerald-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(5 150 105 / var(--tw-bg-opacity, 1));
}
.bg-emerald-900\/10 {
  background-color: rgb(6 78 59 / 0.1);
}
.bg-emerald-900\/15 {
  background-color: rgb(6 78 59 / 0.15);
}
.bg-emerald-900\/20 {
  background-color: rgb(6 78 59 / 0.2);
}
.bg-emerald-900\/30 {
  background-color: rgb(6 78 59 / 0.3);
}
.bg-emerald-900\/40 {
  background-color: rgb(6 78 59 / 0.4);
}
.bg-ink-muted\/60 {
  background-color: rgb(100 116 139 / 0.6);
}
.bg-ink\/40 {
  background-color: rgb(31 41 55 / 0.4);
}
.bg-orange-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(255 237 213 / var(--tw-bg-opacity, 1));
}
.bg-orange-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(255 247 237 / var(--tw-bg-opacity, 1));
}
.bg-primary {
  --tw-bg-opacity: 1;
  background-color: rgb(6 78 59 / var(--tw-bg-opacity, 1));
}
.bg-primary-light\/15 {
  background-color: rgb(16 185 129 / 0.15);
}
.bg-primary-light\/20 {
  background-color: rgb(16 185 129 / 0.2);
}
.bg-primary\/10 {
  background-color: rgb(6 78 59 / 0.1);
}
.bg-primary\/5 {
  background-color: rgb(6 78 59 / 0.05);
}
.bg-primary\/60 {
  background-color: rgb(6 78 59 / 0.6);
}
.bg-purple-900\/40 {
  background-color: rgb(88 28 135 / 0.4);
}
.bg-red-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 226 226 / var(--tw-bg-opacity, 1));
}
.bg-red-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}
.bg-red-50\/50 {
  background-color: rgb(254 242 242 / 0.5);
}
.bg-red-50\/60 {
  background-color: rgb(254 242 242 / 0.6);
}
.bg-red-50\/95 {
  background-color: rgb(254 242 242 / 0.95);
}
.bg-red-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(239 68 68 / var(--tw-bg-opacity, 1));
}
.bg-red-500\/15 {
  background-color: rgb(239 68 68 / 0.15);
}
.bg-red-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(220 38 38 / var(--tw-bg-opacity, 1));
}
.bg-red-900\/10 {
  background-color: rgb(127 29 29 / 0.1);
}
.bg-red-900\/20 {
  background-color: rgb(127 29 29 / 0.2);
}
.bg-red-900\/40 {
  background-color: rgb(127 29 29 / 0.4);
}
.bg-rose-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(255 228 230 / var(--tw-bg-opacity, 1));
}
.bg-rose-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(255 241 242 / var(--tw-bg-opacity, 1));
}
.bg-rose-50\/40 {
  background-color: rgb(255 241 242 / 0.4);
}
.bg-rose-50\/50 {
  background-color: rgb(255 241 242 / 0.5);
}
.bg-rose-50\/60 {
  background-color: rgb(255 241 242 / 0.6);
}
.bg-rose-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(244 63 94 / var(--tw-bg-opacity, 1));
}
.bg-rose-600 {
  --tw-bg-opacity: 1;
  background-color: rgb(225 29 72 / var(--tw-bg-opacity, 1));
}
.bg-sky-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(224 242 254 / var(--tw-bg-opacity, 1));
}
.bg-sky-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(240 249 255 / var(--tw-bg-opacity, 1));
}
.bg-sky-50\/60 {
  background-color: rgb(240 249 255 / 0.6);
}
.bg-sky-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(14 165 233 / var(--tw-bg-opacity, 1));
}
.bg-sky-500\/15 {
  background-color: rgb(14 165 233 / 0.15);
}
.bg-slate-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(241 245 249 / var(--tw-bg-opacity, 1));
}
.bg-slate-300 {
  --tw-bg-opacity: 1;
  background-color: rgb(203 213 225 / var(--tw-bg-opacity, 1));
}
.bg-slate-400 {
  --tw-bg-opacity: 1;
  background-color: rgb(148 163 184 / var(--tw-bg-opacity, 1));
}
.bg-slate-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(248 250 252 / var(--tw-bg-opacity, 1));
}
.bg-slate-50\/50 {
  background-color: rgb(248 250 252 / 0.5);
}
.bg-slate-700 {
  --tw-bg-opacity: 1;
  background-color: rgb(51 65 85 / var(--tw-bg-opacity, 1));
}
.bg-slate-700\/40 {
  background-color: rgb(51 65 85 / 0.4);
}
.bg-slate-800 {
  --tw-bg-opacity: 1;
  background-color: rgb(30 41 59 / var(--tw-bg-opacity, 1));
}
.bg-slate-800\/60 {
  background-color: rgb(30 41 59 / 0.6);
}
.bg-slate-900 {
  --tw-bg-opacity: 1;
  background-color: rgb(15 23 42 / var(--tw-bg-opacity, 1));
}
.bg-slate-900\/30 {
  background-color: rgb(15 23 42 / 0.3);
}
.bg-slate-900\/40 {
  background-color: rgb(15 23 42 / 0.4);
}
.bg-slate-900\/60 {
  background-color: rgb(15 23 42 / 0.6);
}
.bg-slate-950 {
  --tw-bg-opacity: 1;
  background-color: rgb(2 6 23 / var(--tw-bg-opacity, 1));
}
.bg-transparent {
  background-color: transparent;
}
.bg-violet-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(237 233 254 / var(--tw-bg-opacity, 1));
}
.bg-violet-300\/60 {
  background-color: rgb(196 181 253 / 0.6);
}
.bg-violet-300\/80 {
  background-color: rgb(196 181 253 / 0.8);
}
.bg-violet-400\/15 {
  background-color: rgb(167 139 250 / 0.15);
}
.bg-violet-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(245 243 255 / var(--tw-bg-opacity, 1));
}
.bg-violet-50\/40 {
  background-color: rgb(245 243 255 / 0.4);
}
.bg-violet-500 {
  --tw-bg-opacity: 1;
  background-color: rgb(139 92 246 / var(--tw-bg-opacity, 1));
}
.bg-violet-900\/10 {
  background-color: rgb(76 29 149 / 0.1);
}
.bg-violet-900\/15 {
  background-color: rgb(76 29 149 / 0.15);
}
.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.bg-white\/10 {
  background-color: rgb(255 255 255 / 0.1);
}
.bg-white\/60 {
  background-color: rgb(255 255 255 / 0.6);
}
.bg-white\/70 {
  background-color: rgb(255 255 255 / 0.7);
}
.bg-white\/95 {
  background-color: rgb(255 255 255 / 0.95);
}
.bg-white\/\[0\.03\] {
  background-color: rgb(255 255 255 / 0.03);
}
.bg-white\/\[0\.04\] {
  background-color: rgb(255 255 255 / 0.04);
}
.bg-white\/\[0\.06\] {
  background-color: rgb(255 255 255 / 0.06);
}
.bg-white\/\[0\.10\] {
  background-color: rgb(255 255 255 / 0.10);
}
.bg-zinc-950\/85 {
  background-color: rgb(9 9 11 / 0.85);
}
.bg-gradient-to-b {
  background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}
.bg-gradient-to-br {
  background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));
}
.bg-gradient-to-r {
  background-image: linear-gradient(to right, var(--tw-gradient-stops));
}
.from-\[\#1F4D3F\] {
  --tw-gradient-from: #1F4D3F var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(31 77 63 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-\[\#2C6E55\] {
  --tw-gradient-from: #2C6E55 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(44 110 85 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-\[\#C9A84C\] {
  --tw-gradient-from: #C9A84C var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(201 168 76 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-\[\#F5EBD9\]\/60 {
  --tw-gradient-from: rgb(245 235 217 / 0.6) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(245 235 217 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-\[\#F5EBD9\]\/80 {
  --tw-gradient-from: rgb(245 235 217 / 0.8) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(245 235 217 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-\[\#F9FAFB\] {
  --tw-gradient-from: #F9FAFB var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(249 250 251 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-bg-tint {
  --tw-gradient-from: #D1FAE5 var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(209 250 229 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-primary {
  --tw-gradient-from: #064E3B var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(6 78 59 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-primary\/10 {
  --tw-gradient-from: rgb(6 78 59 / 0.1) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(6 78 59 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.via-border {
  --tw-gradient-to: rgb(229 231 235 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), #E5E7EB var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.via-border\/60 {
  --tw-gradient-to: rgb(229 231 235 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), rgb(229 231 235 / 0.6) var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.via-primary-mid {
  --tw-gradient-to: rgb(4 120 87 / 0)  var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), #047857 var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.to-\[\#1F4D3F\] {
  --tw-gradient-to: #1F4D3F var(--tw-gradient-to-position);
}
.to-\[\#2C6E55\] {
  --tw-gradient-to: #2C6E55 var(--tw-gradient-to-position);
}
.to-\[\#C9A84C\] {
  --tw-gradient-to: #C9A84C var(--tw-gradient-to-position);
}
.to-bg-tint {
  --tw-gradient-to: #D1FAE5 var(--tw-gradient-to-position);
}
.to-primary-light {
  --tw-gradient-to: #10B981 var(--tw-gradient-to-position);
}
.to-primary\/5 {
  --tw-gradient-to: rgb(6 78 59 / 0.05) var(--tw-gradient-to-position);
}
.to-white {
  --tw-gradient-to: #fff var(--tw-gradient-to-position);
}
.fill-current {
  fill: currentColor;
}
.object-contain {
  -o-object-fit: contain;
     object-fit: contain;
}
.p-0 {
  padding: 0px;
}
.p-0\.5 {
  padding: 0.125rem;
}
.p-1 {
  padding: 0.25rem;
}
.p-1\.5 {
  padding: 0.375rem;
}
.p-10 {
  padding: 2.5rem;
}
.p-12 {
  padding: 3rem;
}
.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-1\.5 {
  padding-left: 0.375rem;
  padding-right: 0.375rem;
}
.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.px-2\.5 {
  padding-left: 0.625rem;
  padding-right: 0.625rem;
}
.px-3 {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}
.px-3\.5 {
  padding-left: 0.875rem;
  padding-right: 0.875rem;
}
.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-7 {
  padding-left: 1.75rem;
  padding-right: 1.75rem;
}
.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-14 {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}
.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-20 {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
.py-24 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}
.py-3\.5 {
  padding-top: 0.875rem;
  padding-bottom: 0.875rem;
}
.py-32 {
  padding-top: 8rem;
  padding-bottom: 8rem;
}
.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}
.py-5 {
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
}
.py-6 {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}
.py-7 {
  padding-top: 1.75rem;
  padding-bottom: 1.75rem;
}
.py-8 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}
.pb-1 {
  padding-bottom: 0.25rem;
}
.pb-12 {
  padding-bottom: 3rem;
}
.pb-2 {
  padding-bottom: 0.5rem;
}
.pb-20 {
  padding-bottom: 5rem;
}
.pb-5 {
  padding-bottom: 1.25rem;
}
.pb-8 {
  padding-bottom: 2rem;
}
.pl-1 {
  padding-left: 0.25rem;
}
.pl-1\.5 {
  padding-left: 0.375rem;
}
.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-7 {
  padding-left: 1.75rem;
}
.pl-8 {
  padding-left: 2rem;
}
.pl-9 {
  padding-left: 2.25rem;
}
.pr-1 {
  padding-right: 0.25rem;
}
.pr-1\.5 {
  padding-right: 0.375rem;
}
.pr-10 {
  padding-right: 2.5rem;
}
.pr-2 {
  padding-right: 0.5rem;
}
.pr-3 {
  padding-right: 0.75rem;
}
.pr-4 {
  padding-right: 1rem;
}
.pr-7 {
  padding-right: 1.75rem;
}
.pt-0\.5 {
  padding-top: 0.125rem;
}
.pt-1 {
  padding-top: 0.25rem;
}
.pt-1\.5 {
  padding-top: 0.375rem;
}
.pt-2 {
  padding-top: 0.5rem;
}
.pt-24 {
  padding-top: 6rem;
}
.pt-3 {
  padding-top: 0.75rem;
}
.pt-32 {
  padding-top: 8rem;
}
.pt-4 {
  padding-top: 1rem;
}
.pt-5 {
  padding-top: 1.25rem;
}
.pt-6 {
  padding-top: 1.5rem;
}
.pt-\[14vh\] {
  padding-top: 14vh;
}
.text-left {
  text-align: left;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
.align-top {
  vertical-align: top;
}
.align-middle {
  vertical-align: middle;
}
.align-text-bottom {
  vertical-align: text-bottom;
}
.font-mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}
.font-serif {
  font-family: Cormorant Garamond, Source Serif Pro, Georgia, PingFang SC, serif;
}
.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-7xl {
  font-size: 4.5rem;
  line-height: 1;
}
.text-\[10\.5px\] {
  font-size: 10.5px;
}
.text-\[10px\] {
  font-size: 10px;
}
.text-\[11\.5px\] {
  font-size: 11.5px;
}
.text-\[11px\] {
  font-size: 11px;
}
.text-\[12\.5px\] {
  font-size: 12.5px;
}
.text-\[12px\] {
  font-size: 12px;
}
.text-\[13px\] {
  font-size: 13px;
}
.text-\[15px\] {
  font-size: 15px;
}
.text-\[21px\] {
  font-size: 21px;
}
.text-\[32px\] {
  font-size: 32px;
}
.text-\[36px\] {
  font-size: 36px;
}
.text-\[7\.5px\] {
  font-size: 7.5px;
}
.text-\[8px\] {
  font-size: 8px;
}
.text-\[9px\] {
  font-size: 9px;
}
.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;
}
.uppercase {
  text-transform: uppercase;
}
.italic {
  font-style: italic;
}
.tabular-nums {
  --tw-numeric-spacing: tabular-nums;
  font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);
}
.leading-\[1\.06\] {
  line-height: 1.06;
}
.leading-\[2\.75rem\] {
  line-height: 2.75rem;
}
.leading-\[3rem\] {
  line-height: 3rem;
}
.leading-none {
  line-height: 1;
}
.leading-relaxed {
  line-height: 1.625;
}
.leading-snug {
  line-height: 1.375;
}
.leading-tight {
  line-height: 1.25;
}
.tracking-\[0\.18em\] {
  letter-spacing: 0.18em;
}
.tracking-\[0\.22em\] {
  letter-spacing: 0.22em;
}
.tracking-tight {
  letter-spacing: -0.025em;
}
.tracking-wide {
  letter-spacing: 0.025em;
}
.tracking-wider {
  letter-spacing: 0.05em;
}
.tracking-widest {
  letter-spacing: 0.1em;
}
.text-\[\#1F2937\] {
  --tw-text-opacity: 1;
  color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}
.text-\[\#1F4D3F\] {
  --tw-text-opacity: 1;
  color: rgb(31 77 63 / var(--tw-text-opacity, 1));
}
.text-\[\#1F4D3F\]\/15 {
  color: rgb(31 77 63 / 0.15);
}
.text-\[\#1F4D3F\]\/60 {
  color: rgb(31 77 63 / 0.6);
}
.text-\[\#1F4D3F\]\/70 {
  color: rgb(31 77 63 / 0.7);
}
.text-\[\#1F4D3F\]\/80 {
  color: rgb(31 77 63 / 0.8);
}
.text-\[\#1F4D3F\]\/90 {
  color: rgb(31 77 63 / 0.9);
}
.text-\[\#2C6E55\] {
  --tw-text-opacity: 1;
  color: rgb(44 110 85 / var(--tw-text-opacity, 1));
}
.text-\[\#4B5563\] {
  --tw-text-opacity: 1;
  color: rgb(75 85 99 / var(--tw-text-opacity, 1));
}
.text-\[\#6B7280\] {
  --tw-text-opacity: 1;
  color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}
.text-\[\#8C7128\] {
  --tw-text-opacity: 1;
  color: rgb(140 113 40 / var(--tw-text-opacity, 1));
}
.text-\[\#8C7128\]\/80 {
  color: rgb(140 113 40 / 0.8);
}
.text-\[\#8F7430\] {
  --tw-text-opacity: 1;
  color: rgb(143 116 48 / var(--tw-text-opacity, 1));
}
.text-\[\#9C7A1A\] {
  --tw-text-opacity: 1;
  color: rgb(156 122 26 / var(--tw-text-opacity, 1));
}
.text-\[\#A88A30\] {
  --tw-text-opacity: 1;
  color: rgb(168 138 48 / var(--tw-text-opacity, 1));
}
.text-\[\#C9A84C\] {
  --tw-text-opacity: 1;
  color: rgb(201 168 76 / var(--tw-text-opacity, 1));
}
.text-\[\#D1D5DB\] {
  --tw-text-opacity: 1;
  color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}
.text-\[rgba\(140\2c 180\2c 255\2c 0\.7\)\] {
  color: rgba(140,180,255,0.7);
}
.text-amber-200 {
  --tw-text-opacity: 1;
  color: rgb(253 230 138 / var(--tw-text-opacity, 1));
}
.text-amber-300 {
  --tw-text-opacity: 1;
  color: rgb(252 211 77 / var(--tw-text-opacity, 1));
}
.text-amber-300\/60 {
  color: rgb(252 211 77 / 0.6);
}
.text-amber-300\/70 {
  color: rgb(252 211 77 / 0.7);
}
.text-amber-300\/80 {
  color: rgb(252 211 77 / 0.8);
}
.text-amber-300\/90 {
  color: rgb(252 211 77 / 0.9);
}
.text-amber-400 {
  --tw-text-opacity: 1;
  color: rgb(251 191 36 / var(--tw-text-opacity, 1));
}
.text-amber-400\/80 {
  color: rgb(251 191 36 / 0.8);
}
.text-amber-500 {
  --tw-text-opacity: 1;
  color: rgb(245 158 11 / var(--tw-text-opacity, 1));
}
.text-amber-600 {
  --tw-text-opacity: 1;
  color: rgb(217 119 6 / var(--tw-text-opacity, 1));
}
.text-amber-700 {
  --tw-text-opacity: 1;
  color: rgb(180 83 9 / var(--tw-text-opacity, 1));
}
.text-amber-800 {
  --tw-text-opacity: 1;
  color: rgb(146 64 14 / var(--tw-text-opacity, 1));
}
.text-amber-900 {
  --tw-text-opacity: 1;
  color: rgb(120 53 15 / var(--tw-text-opacity, 1));
}
.text-blue-200 {
  --tw-text-opacity: 1;
  color: rgb(191 219 254 / var(--tw-text-opacity, 1));
}
.text-blue-300 {
  --tw-text-opacity: 1;
  color: rgb(147 197 253 / var(--tw-text-opacity, 1));
}
.text-blue-300\/60 {
  color: rgb(147 197 253 / 0.6);
}
.text-blue-300\/80 {
  color: rgb(147 197 253 / 0.8);
}
.text-blue-600 {
  --tw-text-opacity: 1;
  color: rgb(37 99 235 / var(--tw-text-opacity, 1));
}
.text-blue-700 {
  --tw-text-opacity: 1;
  color: rgb(29 78 216 / var(--tw-text-opacity, 1));
}
.text-emerald-200 {
  --tw-text-opacity: 1;
  color: rgb(167 243 208 / var(--tw-text-opacity, 1));
}
.text-emerald-300 {
  --tw-text-opacity: 1;
  color: rgb(110 231 183 / var(--tw-text-opacity, 1));
}
.text-emerald-300\/60 {
  color: rgb(110 231 183 / 0.6);
}
.text-emerald-300\/70 {
  color: rgb(110 231 183 / 0.7);
}
.text-emerald-300\/80 {
  color: rgb(110 231 183 / 0.8);
}
.text-emerald-400 {
  --tw-text-opacity: 1;
  color: rgb(52 211 153 / var(--tw-text-opacity, 1));
}
.text-emerald-500 {
  --tw-text-opacity: 1;
  color: rgb(16 185 129 / var(--tw-text-opacity, 1));
}
.text-emerald-600 {
  --tw-text-opacity: 1;
  color: rgb(5 150 105 / var(--tw-text-opacity, 1));
}
.text-emerald-700 {
  --tw-text-opacity: 1;
  color: rgb(4 120 87 / var(--tw-text-opacity, 1));
}
.text-emerald-700\/70 {
  color: rgb(4 120 87 / 0.7);
}
.text-emerald-700\/80 {
  color: rgb(4 120 87 / 0.8);
}
.text-emerald-800 {
  --tw-text-opacity: 1;
  color: rgb(6 95 70 / var(--tw-text-opacity, 1));
}
.text-emerald-900 {
  --tw-text-opacity: 1;
  color: rgb(6 78 59 / var(--tw-text-opacity, 1));
}
.text-ink {
  --tw-text-opacity: 1;
  color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}
.text-ink-muted {
  --tw-text-opacity: 1;
  color: rgb(100 116 139 / var(--tw-text-opacity, 1));
}
.text-ink-muted\/40 {
  color: rgb(100 116 139 / 0.4);
}
.text-ink-muted\/50 {
  color: rgb(100 116 139 / 0.5);
}
.text-ink-muted\/60 {
  color: rgb(100 116 139 / 0.6);
}
.text-ink-muted\/70 {
  color: rgb(100 116 139 / 0.7);
}
.text-ink-muted\/80 {
  color: rgb(100 116 139 / 0.8);
}
.text-ink-muted\/90 {
  color: rgb(100 116 139 / 0.9);
}
.text-orange-300 {
  --tw-text-opacity: 1;
  color: rgb(253 186 116 / var(--tw-text-opacity, 1));
}
.text-orange-600 {
  --tw-text-opacity: 1;
  color: rgb(234 88 12 / var(--tw-text-opacity, 1));
}
.text-orange-700 {
  --tw-text-opacity: 1;
  color: rgb(194 65 12 / var(--tw-text-opacity, 1));
}
.text-primary {
  --tw-text-opacity: 1;
  color: rgb(6 78 59 / var(--tw-text-opacity, 1));
}
.text-primary-light {
  --tw-text-opacity: 1;
  color: rgb(16 185 129 / var(--tw-text-opacity, 1));
}
.text-purple-200 {
  --tw-text-opacity: 1;
  color: rgb(233 213 255 / var(--tw-text-opacity, 1));
}
.text-purple-300 {
  --tw-text-opacity: 1;
  color: rgb(216 180 254 / var(--tw-text-opacity, 1));
}
.text-red-200 {
  --tw-text-opacity: 1;
  color: rgb(254 202 202 / var(--tw-text-opacity, 1));
}
.text-red-300 {
  --tw-text-opacity: 1;
  color: rgb(252 165 165 / var(--tw-text-opacity, 1));
}
.text-red-300\/80 {
  color: rgb(252 165 165 / 0.8);
}
.text-red-400 {
  --tw-text-opacity: 1;
  color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}
.text-red-500 {
  --tw-text-opacity: 1;
  color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}
.text-red-600 {
  --tw-text-opacity: 1;
  color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}
.text-red-600\/80 {
  color: rgb(220 38 38 / 0.8);
}
.text-red-700 {
  --tw-text-opacity: 1;
  color: rgb(185 28 28 / var(--tw-text-opacity, 1));
}
.text-red-700\/70 {
  color: rgb(185 28 28 / 0.7);
}
.text-red-700\/80 {
  color: rgb(185 28 28 / 0.8);
}
.text-red-800 {
  --tw-text-opacity: 1;
  color: rgb(153 27 27 / var(--tw-text-opacity, 1));
}
.text-rose-300\/90 {
  color: rgb(253 164 175 / 0.9);
}
.text-rose-500 {
  --tw-text-opacity: 1;
  color: rgb(244 63 94 / var(--tw-text-opacity, 1));
}
.text-rose-500\/70 {
  color: rgb(244 63 94 / 0.7);
}
.text-rose-600 {
  --tw-text-opacity: 1;
  color: rgb(225 29 72 / var(--tw-text-opacity, 1));
}
.text-rose-700 {
  --tw-text-opacity: 1;
  color: rgb(190 18 60 / var(--tw-text-opacity, 1));
}
.text-rose-800 {
  --tw-text-opacity: 1;
  color: rgb(159 18 57 / var(--tw-text-opacity, 1));
}
.text-rose-900 {
  --tw-text-opacity: 1;
  color: rgb(136 19 55 / var(--tw-text-opacity, 1));
}
.text-sky-300 {
  --tw-text-opacity: 1;
  color: rgb(125 211 252 / var(--tw-text-opacity, 1));
}
.text-sky-300\/90 {
  color: rgb(125 211 252 / 0.9);
}
.text-sky-600 {
  --tw-text-opacity: 1;
  color: rgb(2 132 199 / var(--tw-text-opacity, 1));
}
.text-sky-700 {
  --tw-text-opacity: 1;
  color: rgb(3 105 161 / var(--tw-text-opacity, 1));
}
.text-sky-800 {
  --tw-text-opacity: 1;
  color: rgb(7 89 133 / var(--tw-text-opacity, 1));
}
.text-slate-100 {
  --tw-text-opacity: 1;
  color: rgb(241 245 249 / var(--tw-text-opacity, 1));
}
.text-slate-200 {
  --tw-text-opacity: 1;
  color: rgb(226 232 240 / var(--tw-text-opacity, 1));
}
.text-slate-300 {
  --tw-text-opacity: 1;
  color: rgb(203 213 225 / var(--tw-text-opacity, 1));
}
.text-slate-400 {
  --tw-text-opacity: 1;
  color: rgb(148 163 184 / var(--tw-text-opacity, 1));
}
.text-slate-500 {
  --tw-text-opacity: 1;
  color: rgb(100 116 139 / var(--tw-text-opacity, 1));
}
.text-slate-600 {
  --tw-text-opacity: 1;
  color: rgb(71 85 105 / var(--tw-text-opacity, 1));
}
.text-slate-700 {
  --tw-text-opacity: 1;
  color: rgb(51 65 85 / var(--tw-text-opacity, 1));
}
.text-slate-900 {
  --tw-text-opacity: 1;
  color: rgb(15 23 42 / var(--tw-text-opacity, 1));
}
.text-transparent {
  color: transparent;
}
.text-violet-100 {
  --tw-text-opacity: 1;
  color: rgb(237 233 254 / var(--tw-text-opacity, 1));
}
.text-violet-200 {
  --tw-text-opacity: 1;
  color: rgb(221 214 254 / var(--tw-text-opacity, 1));
}
.text-violet-300 {
  --tw-text-opacity: 1;
  color: rgb(196 181 253 / var(--tw-text-opacity, 1));
}
.text-violet-300\/30 {
  color: rgb(196 181 253 / 0.3);
}
.text-violet-300\/40 {
  color: rgb(196 181 253 / 0.4);
}
.text-violet-300\/60 {
  color: rgb(196 181 253 / 0.6);
}
.text-violet-300\/80 {
  color: rgb(196 181 253 / 0.8);
}
.text-violet-500 {
  --tw-text-opacity: 1;
  color: rgb(139 92 246 / var(--tw-text-opacity, 1));
}
.text-violet-600 {
  --tw-text-opacity: 1;
  color: rgb(124 58 237 / var(--tw-text-opacity, 1));
}
.text-violet-700 {
  --tw-text-opacity: 1;
  color: rgb(109 40 217 / var(--tw-text-opacity, 1));
}
.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.text-white\/20 {
  color: rgb(255 255 255 / 0.2);
}
.text-white\/30 {
  color: rgb(255 255 255 / 0.3);
}
.text-white\/35 {
  color: rgb(255 255 255 / 0.35);
}
.text-white\/40 {
  color: rgb(255 255 255 / 0.4);
}
.text-white\/45 {
  color: rgb(255 255 255 / 0.45);
}
.text-white\/50 {
  color: rgb(255 255 255 / 0.5);
}
.text-white\/55 {
  color: rgb(255 255 255 / 0.55);
}
.text-white\/60 {
  color: rgb(255 255 255 / 0.6);
}
.text-white\/70 {
  color: rgb(255 255 255 / 0.7);
}
.text-white\/75 {
  color: rgb(255 255 255 / 0.75);
}
.text-white\/80 {
  color: rgb(255 255 255 / 0.8);
}
.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);
}
.text-yellow-500 {
  --tw-text-opacity: 1;
  color: rgb(234 179 8 / var(--tw-text-opacity, 1));
}
.underline {
  text-decoration-line: underline;
}
.line-through {
  text-decoration-line: line-through;
}
.placeholder-white\/60::-moz-placeholder {
  color: rgb(255 255 255 / 0.6);
}
.placeholder-white\/60::placeholder {
  color: rgb(255 255 255 / 0.6);
}
.accent-\[\#1F4D3F\] {
  accent-color: #1F4D3F;
}
.accent-primary {
  accent-color: #064E3B;
}
.opacity-0 {
  opacity: 0;
}
.opacity-100 {
  opacity: 1;
}
.opacity-30 {
  opacity: 0.3;
}
.opacity-50 {
  opacity: 0.5;
}
.opacity-60 {
  opacity: 0.6;
}
.opacity-70 {
  opacity: 0.7;
}
.opacity-80 {
  opacity: 0.8;
}
.opacity-90 {
  opacity: 0.9;
}
.opacity-\[0\.35\] {
  opacity: 0.35;
}
.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-2xl {
  --tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  --tw-shadow-colored: 0 25px 50px -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-\[0_0_0_4px_rgba\(201\2c 168\2c 76\2c 0\.18\)\] {
  --tw-shadow: 0 0 0 4px rgba(201,168,76,0.18);
  --tw-shadow-colored: 0 0 0 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-\[0_12px_40px_rgba\(31\2c 41\2c 55\2c 0\.06\)\] {
  --tw-shadow: 0 12px 40px rgba(31,41,55,0.06);
  --tw-shadow-colored: 0 12px 40px 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-inner {
  --tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: inset 0 2px 4px 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);
}
.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-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);
}
.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);
}
.shadow-soft-md {
  --tw-shadow: 0 4px 8px rgba(0, 0, 0, 0.06);
  --tw-shadow-colored: 0 4px 8px 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-soft-sm {
  --tw-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  --tw-shadow-colored: 0 1px 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);
}
.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);
}
.shadow-\[\#1F4D3F\]\/15 {
  --tw-shadow-color: rgb(31 77 63 / 0.15);
  --tw-shadow: var(--tw-shadow-colored);
}
.shadow-black\/40 {
  --tw-shadow-color: rgb(0 0 0 / 0.4);
  --tw-shadow: var(--tw-shadow-colored);
}
.shadow-black\/60 {
  --tw-shadow-color: rgb(0 0 0 / 0.6);
  --tw-shadow: var(--tw-shadow-colored);
}
.shadow-black\/70 {
  --tw-shadow-color: rgb(0 0 0 / 0.7);
  --tw-shadow: var(--tw-shadow-colored);
}
.shadow-white\/\[0\.05\] {
  --tw-shadow-color: rgb(255 255 255 / 0.05);
  --tw-shadow: var(--tw-shadow-colored);
}
.outline-none {
  outline: 2px solid transparent;
  outline-offset: 2px;
}
.outline {
  outline-style: solid;
}
.ring {
  --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);
}
.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-2 {
  --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);
}
.ring-4 {
  --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(4px + 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-inset {
  --tw-ring-inset: inset;
}
.ring-\[\#C9A84C\]\/10 {
  --tw-ring-color: rgb(201 168 76 / 0.1);
}
.ring-\[\#C9A84C\]\/60 {
  --tw-ring-color: rgb(201 168 76 / 0.6);
}
.ring-amber-300 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(252 211 77 / var(--tw-ring-opacity, 1));
}
.ring-emerald-100 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(209 250 229 / var(--tw-ring-opacity, 1));
}
.ring-emerald-200 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(167 243 208 / var(--tw-ring-opacity, 1));
}
.ring-emerald-300 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(110 231 183 / var(--tw-ring-opacity, 1));
}
.ring-primary {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(6 78 59 / var(--tw-ring-opacity, 1));
}
.ring-primary-light {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(16 185 129 / var(--tw-ring-opacity, 1));
}
.ring-primary\/15 {
  --tw-ring-color: rgb(6 78 59 / 0.15);
}
.ring-red-200 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(254 202 202 / var(--tw-ring-opacity, 1));
}
.ring-rose-300 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(253 164 175 / var(--tw-ring-opacity, 1));
}
.ring-sky-200 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(186 230 253 / var(--tw-ring-opacity, 1));
}
.ring-slate-200 {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(226 232 240 / var(--tw-ring-opacity, 1));
}
.blur {
  --tw-blur: blur(8px);
  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);
}
.invert {
  --tw-invert: invert(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);
}
.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 {
  --tw-backdrop-blur: blur(8px);
  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-lg {
  --tw-backdrop-blur: blur(16px);
  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-md {
  --tw-backdrop-blur: blur(12px);
  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);
  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-xl {
  --tw-backdrop-blur: blur(24px);
  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, 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;
}
.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-150 {
  transition-duration: 150ms;
}
.duration-200 {
  transition-duration: 200ms;
}
.duration-300 {
  transition-duration: 300ms;
}
.duration-500 {
  transition-duration: 500ms;
}
.duration-700 {
  transition-duration: 700ms;
}
.ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.ease-out {
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}
.gpu {
    backface-visibility: hidden;
  }

html,
body,
#root {
  height: 100%;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  background: var(--color-bg-warm);
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
}

/* 模块 16 — 标题字重统一 500,不再走 700/600 那么粗的视觉 */
h1, h2, h3, h4, h5, h6 {
  font-weight: 500;
}

/* 模块 16 — 桌面端隐藏系统鼠标由 CustomCursor.tsx 在 body 上动态设置,
   不再用全局通配 cursor:none（修：高 z-index / portal / iframe 内出现死区）。 */

/* ───── 白色全息球 mini icon (2026-05-30 直接 copy from zip 像素版) ──
   纯 CSS 无图片, 自带呼吸 + 双环反向自转.
   16×16 固定, 跟 zip 完全一致 (inset 像素版).
   用法: <span class="holo-icon"><i class="hi-halo"/><i class="hi-ring1"/><i class="hi-ring2"/><i class="hi-core"/></span>
─────────────────────────────────────────────────────────── */
.holo-icon {
  position: relative;
  display: inline-block;
  width: 16px;
  height: 16px;
  vertical-align: -3px;
  flex-shrink: 0;
}
.holo-icon > i {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
/* 外层辉光 — 白色 halo, 2.6s 呼吸 */
.holo-icon .hi-halo {
  inset: -2px;
  background: radial-gradient(circle,
    rgba(255,255,255,.7) 0%,
    rgba(255,255,255,.22) 45%,
    transparent 72%);
  animation: hi-halo 2.6s ease-in-out infinite;
}
/* 外环 wireframe + 3 颗卫星点, 9s 自转 */
.holo-icon .hi-ring1 {
  inset: 1px;
  border: 0.5px solid rgba(255,255,255,.55);
  animation: hi-spin 9s linear infinite;
}
.holo-icon .hi-ring1::after {
  content: "";
  position: absolute;
  width: 2px; height: 2px;
  background: #fff;
  border-radius: 50%;
  top: 50%; left: -1px;
  transform: translateY(-50%);
  box-shadow:
    13px 0 0 #fff,
    6px -11px 0 rgba(255,255,255,.9),
    6px 11px 0 rgba(255,255,255,.9);
}
/* 内环 + 4 颗节点, 6s 反向自转 */
.holo-icon .hi-ring2 {
  inset: 4px;
  border: 0.5px solid rgba(255,255,255,.75);
  animation: hi-spin 6s linear infinite reverse;
}
.holo-icon .hi-ring2::after {
  content: "";
  position: absolute;
  width: 1.8px; height: 1.8px;
  background: #fff;
  border-radius: 50%;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  box-shadow:
    0 5px 0 #fff,
    5px 0 0 #fff,
    -5px 0 0 #fff;
}
/* 核心 — 白热 → 薄荷绿过渡, 1.8s 呼吸 */
.holo-icon .hi-core {
  inset: 5.5px;
  background: radial-gradient(circle,
    #fff 0%,
    #BDF4D8 35%,
    rgba(255,255,255,.45) 70%,
    rgba(255,255,255,0) 100%);
  box-shadow: 0 0 5px rgba(255,255,255,.75);
  animation: hi-core 1.8s ease-in-out infinite;
}
@keyframes hi-halo {
  0%, 100% { transform: scale(.92); opacity: .7; }
  50%      { transform: scale(1.12); opacity: 1; }
}
@keyframes hi-core {
  0%, 100% { transform: scale(.82); filter: brightness(1); }
  50%      { transform: scale(1.06); filter: brightness(1.25); }
}
@keyframes hi-spin {
  from { transform: rotate(0); }
  to   { transform: rotate(360deg); }
}

/* ───── HoloSphereSvg (chat avatar 白底绿线版) 动画 ───────── */
@keyframes phh-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes phh-twinkle {
  0%, 100% { opacity: 0.4; transform: scale(0.85); }
  50%      { opacity: 1;   transform: scale(1.15); }
}
@keyframes phh-core {
  0%, 100% { transform: scale(0.85); opacity: 0.85; }
  50%      { transform: scale(1.15); opacity: 1; }
}
.placeholder\:text-ink-muted\/60::-moz-placeholder {
  color: rgb(100 116 139 / 0.6);
}
.placeholder\:text-ink-muted\/60::placeholder {
  color: rgb(100 116 139 / 0.6);
}
.placeholder\:text-white\/30::-moz-placeholder {
  color: rgb(255 255 255 / 0.3);
}
.placeholder\:text-white\/30::placeholder {
  color: rgb(255 255 255 / 0.3);
}
.first\:border-t-0:first-child {
  border-top-width: 0px;
}
.first\:pt-1:first-child {
  padding-top: 0.25rem;
}
.last\:border-b-0:last-child {
  border-bottom-width: 0px;
}
.last\:pb-1:last-child {
  padding-bottom: 0.25rem;
}
.hover\:-translate-y-0\.5:hover {
  --tw-translate-y: -0.125rem;
  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\:border-\[\#1F4D3F\]\/30:hover {
  border-color: rgb(31 77 63 / 0.3);
}
.hover\:border-\[\#1F4D3F\]\/60:hover {
  border-color: rgb(31 77 63 / 0.6);
}
.hover\:border-amber-200:hover {
  --tw-border-opacity: 1;
  border-color: rgb(253 230 138 / var(--tw-border-opacity, 1));
}
.hover\:border-border:hover {
  --tw-border-opacity: 1;
  border-color: rgb(229 231 235 / var(--tw-border-opacity, 1));
}
.hover\:border-primary:hover {
  --tw-border-opacity: 1;
  border-color: rgb(6 78 59 / var(--tw-border-opacity, 1));
}
.hover\:border-primary\/40:hover {
  border-color: rgb(6 78 59 / 0.4);
}
.hover\:border-primary\/50:hover {
  border-color: rgb(6 78 59 / 0.5);
}
.hover\:bg-\[\#1F4D3F\]\/5:hover {
  background-color: rgb(31 77 63 / 0.05);
}
.hover\:bg-\[\#1F4D3F\]\/90:hover {
  background-color: rgb(31 77 63 / 0.9);
}
.hover\:bg-\[\#2C6E55\]:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(44 110 85 / var(--tw-bg-opacity, 1));
}
.hover\:bg-\[\#2E6A57\]:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(46 106 87 / var(--tw-bg-opacity, 1));
}
.hover\:bg-\[\#B5953F\]:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(181 149 63 / var(--tw-bg-opacity, 1));
}
.hover\:bg-\[\#B89538\]:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(184 149 56 / var(--tw-bg-opacity, 1));
}
.hover\:bg-\[\#B8983C\]:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(184 152 60 / var(--tw-bg-opacity, 1));
}
.hover\:bg-\[\#C9A84C\]\/10:hover {
  background-color: rgb(201 168 76 / 0.1);
}
.hover\:bg-\[\#C9A84C\]\/25:hover {
  background-color: rgb(201 168 76 / 0.25);
}
.hover\:bg-amber-400:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(251 191 36 / var(--tw-bg-opacity, 1));
}
.hover\:bg-amber-50:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 251 235 / var(--tw-bg-opacity, 1));
}
.hover\:bg-amber-900\/30:hover {
  background-color: rgb(120 53 15 / 0.3);
}
.hover\:bg-bg:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.hover\:bg-bg-tint:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(209 250 229 / var(--tw-bg-opacity, 1));
}
.hover\:bg-bg-tint\/40:hover {
  background-color: rgb(209 250 229 / 0.4);
}
.hover\:bg-bg-tint\/50:hover {
  background-color: rgb(209 250 229 / 0.5);
}
.hover\:bg-bg-tint\/60:hover {
  background-color: rgb(209 250 229 / 0.6);
}
.hover\:bg-bg-tint\/70:hover {
  background-color: rgb(209 250 229 / 0.7);
}
.hover\:bg-bg-warm:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(248 249 250 / var(--tw-bg-opacity, 1));
}
.hover\:bg-bg-warm\/20:hover {
  background-color: rgb(248 249 250 / 0.2);
}
.hover\:bg-bg-warm\/30:hover {
  background-color: rgb(248 249 250 / 0.3);
}
.hover\:bg-emerald-50:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(236 253 245 / var(--tw-bg-opacity, 1));
}
.hover\:bg-emerald-600:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(5 150 105 / var(--tw-bg-opacity, 1));
}
.hover\:bg-emerald-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(4 120 87 / var(--tw-bg-opacity, 1));
}
.hover\:bg-emerald-900\/25:hover {
  background-color: rgb(6 78 59 / 0.25);
}
.hover\:bg-primary-mid:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(4 120 87 / var(--tw-bg-opacity, 1));
}
.hover\:bg-primary\/10:hover {
  background-color: rgb(6 78 59 / 0.1);
}
.hover\:bg-primary\/90:hover {
  background-color: rgb(6 78 59 / 0.9);
}
.hover\:bg-purple-900\/60:hover {
  background-color: rgb(88 28 135 / 0.6);
}
.hover\:bg-red-50:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}
.hover\:bg-red-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}
.hover\:bg-rose-50:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 241 242 / var(--tw-bg-opacity, 1));
}
.hover\:bg-rose-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(190 18 60 / var(--tw-bg-opacity, 1));
}
.hover\:bg-slate-100:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(241 245 249 / var(--tw-bg-opacity, 1));
}
.hover\:bg-slate-700:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(51 65 85 / var(--tw-bg-opacity, 1));
}
.hover\:bg-slate-700\/60:hover {
  background-color: rgb(51 65 85 / 0.6);
}
.hover\:bg-slate-800:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(30 41 59 / var(--tw-bg-opacity, 1));
}
.hover\:bg-slate-800\/60:hover {
  background-color: rgb(30 41 59 / 0.6);
}
.hover\:bg-slate-900\/40:hover {
  background-color: rgb(15 23 42 / 0.4);
}
.hover\:bg-slate-900\/60:hover {
  background-color: rgb(15 23 42 / 0.6);
}
.hover\:bg-slate-900\/70:hover {
  background-color: rgb(15 23 42 / 0.7);
}
.hover\:bg-white:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.hover\:bg-white\/15:hover {
  background-color: rgb(255 255 255 / 0.15);
}
.hover\:bg-white\/40:hover {
  background-color: rgb(255 255 255 / 0.4);
}
.hover\:bg-white\/90:hover {
  background-color: rgb(255 255 255 / 0.9);
}
.hover\:bg-white\/\[0\.03\]:hover {
  background-color: rgb(255 255 255 / 0.03);
}
.hover\:bg-white\/\[0\.04\]:hover {
  background-color: rgb(255 255 255 / 0.04);
}
.hover\:bg-white\/\[0\.08\]:hover {
  background-color: rgb(255 255 255 / 0.08);
}
.hover\:from-primary\/15:hover {
  --tw-gradient-from: rgb(6 78 59 / 0.15) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(6 78 59 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.hover\:text-\[\#C9A84C\]:hover {
  --tw-text-opacity: 1;
  color: rgb(201 168 76 / var(--tw-text-opacity, 1));
}
.hover\:text-amber-200:hover {
  --tw-text-opacity: 1;
  color: rgb(253 230 138 / var(--tw-text-opacity, 1));
}
.hover\:text-amber-500:hover {
  --tw-text-opacity: 1;
  color: rgb(245 158 11 / var(--tw-text-opacity, 1));
}
.hover\:text-amber-600:hover {
  --tw-text-opacity: 1;
  color: rgb(217 119 6 / var(--tw-text-opacity, 1));
}
.hover\:text-ink:hover {
  --tw-text-opacity: 1;
  color: rgb(31 41 55 / var(--tw-text-opacity, 1));
}
.hover\:text-primary:hover {
  --tw-text-opacity: 1;
  color: rgb(6 78 59 / var(--tw-text-opacity, 1));
}
.hover\:text-primary\/80:hover {
  color: rgb(6 78 59 / 0.8);
}
.hover\:text-red-600:hover {
  --tw-text-opacity: 1;
  color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}
.hover\:text-rose-600:hover {
  --tw-text-opacity: 1;
  color: rgb(225 29 72 / var(--tw-text-opacity, 1));
}
.hover\:text-rose-700:hover {
  --tw-text-opacity: 1;
  color: rgb(190 18 60 / var(--tw-text-opacity, 1));
}
.hover\:text-slate-200:hover {
  --tw-text-opacity: 1;
  color: rgb(226 232 240 / var(--tw-text-opacity, 1));
}
.hover\:text-white:hover {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.hover\:text-white\/80:hover {
  color: rgb(255 255 255 / 0.8);
}
.hover\:text-white\/90:hover {
  color: rgb(255 255 255 / 0.9);
}
.hover\:underline:hover {
  text-decoration-line: underline;
}
.hover\:opacity-100:hover {
  opacity: 1;
}
.hover\:shadow-lg:hover {
  --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);
}
.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);
}
.hover\:shadow-soft-md:hover {
  --tw-shadow: 0 4px 8px rgba(0, 0, 0, 0.06);
  --tw-shadow-colored: 0 4px 8px 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-soft-sm:hover {
  --tw-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  --tw-shadow-colored: 0 1px 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-\[\#C9A84C\]:focus {
  --tw-border-opacity: 1;
  border-color: rgb(201 168 76 / var(--tw-border-opacity, 1));
}
.focus\:border-primary:focus {
  --tw-border-opacity: 1;
  border-color: rgb(6 78 59 / var(--tw-border-opacity, 1));
}
.focus\:border-primary\/40:focus {
  border-color: rgb(6 78 59 / 0.4);
}
.focus\:bg-bg:focus {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.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-\[\#C9A84C\]:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(201 168 76 / var(--tw-ring-opacity, 1));
}
.focus\:ring-amber-500\/30:focus {
  --tw-ring-color: rgb(245 158 11 / 0.3);
}
.focus\:ring-amber-500\/40:focus {
  --tw-ring-color: rgb(245 158 11 / 0.4);
}
.focus\:ring-primary-light:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgb(16 185 129 / var(--tw-ring-opacity, 1));
}
.focus\:ring-primary\/40:focus {
  --tw-ring-color: rgb(6 78 59 / 0.4);
}
.focus\:ring-white\/40:focus {
  --tw-ring-color: rgb(255 255 255 / 0.4);
}
.active\:cursor-grabbing:active {
  cursor: grabbing;
}
.disabled\:cursor-not-allowed:disabled {
  cursor: not-allowed;
}
.disabled\:opacity-30:disabled {
  opacity: 0.3;
}
.disabled\:opacity-40:disabled {
  opacity: 0.4;
}
.disabled\:opacity-50:disabled {
  opacity: 0.5;
}
.disabled\:opacity-60:disabled {
  opacity: 0.6;
}
.group:hover .group-hover\:translate-x-0\.5 {
  --tw-translate-x: 0.125rem;
  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\:translate-x-1 {
  --tw-translate-x: 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));
}
.group:hover .group-hover\:scale-110 {
  --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));
}
.group:hover .group-hover\:text-ink-muted {
  --tw-text-opacity: 1;
  color: rgb(100 116 139 / var(--tw-text-opacity, 1));
}
.group:hover .group-hover\:text-white\/60 {
  color: rgb(255 255 255 / 0.6);
}
.group:hover .group-hover\:opacity-100 {
  opacity: 1;
}
@media (min-width: 640px) {
  .sm\:w-\[480px\] {
    width: 480px;
  }
  .sm\:max-w-md {
    max-width: 28rem;
  }
  .sm\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sm\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .sm\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (min-width: 768px) {
  .md\:block {
    display: block;
  }
  .md\:flex {
    display: flex;
  }
  .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\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .md\:gap-8 {
    gap: 2rem;
  }
  .md\:space-y-20 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(5rem * var(--tw-space-y-reverse));
  }
  .md\:p-10 {
    padding: 2.5rem;
  }
  .md\:p-4 {
    padding: 1rem;
  }
  .md\:p-7 {
    padding: 1.75rem;
  }
  .md\:py-24 {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
  .md\:py-28 {
    padding-top: 7rem;
    padding-bottom: 7rem;
  }
  .md\:py-32 {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
  .md\:py-40 {
    padding-top: 10rem;
    padding-bottom: 10rem;
  }
  .md\:pb-28 {
    padding-bottom: 7rem;
  }
  .md\:pt-32 {
    padding-top: 8rem;
  }
  .md\:pt-40 {
    padding-top: 10rem;
  }
  .md\:text-center {
    text-align: center;
  }
  .md\:text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
  .md\:text-5xl {
    font-size: 3rem;
    line-height: 1;
  }
  .md\:text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }
  .md\:text-\[15px\] {
    font-size: 15px;
  }
  .md\:text-\[17px\] {
    font-size: 17px;
  }
  .md\:text-\[56px\] {
    font-size: 56px;
  }
  .md\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  .md\:text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }
  .md\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}
@media (min-width: 1024px) {
  .lg\:col-span-2 {
    grid-column: span 2 / span 2;
  }
  .lg\:flex {
    display: flex;
  }
  .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\:gap-14 {
    gap: 3.5rem;
  }
  .lg\:p-8 {
    padding: 2rem;
  }
  .lg\:px-10 {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }
  .lg\:text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }
  .lg\:text-\[68px\] {
    font-size: 68px;
  }
  .lg\:\[direction\:ltr\] {
    direction: ltr;
  }
  .lg\:\[direction\:rtl\] {
    direction: rtl;
  }
}
@media (min-width: 1280px) {
  .xl\:col-span-2 {
    grid-column: span 2 / span 2;
  }
  .xl\:col-span-3 {
    grid-column: span 3 / span 3;
  }
  .xl\:col-span-4 {
    grid-column: span 4 / span 4;
  }
  .xl\:col-span-5 {
    grid-column: span 5 / span 5;
  }
  .xl\:grid-cols-12 {
    grid-template-columns: repeat(12, 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));
  }
}

:root {
  /* 2026-05-16 Apple 风格中度改造：柔和系统色 + 大圆角 + 玻璃质感 */
  --p: #1a6b4a; --pl: #ebf5f0; --pd: #0f4a32;
  --acc: #AF52DE; --accl: #F5EEFA;
  --red: #FF3B30; --redl: #FFEDEC; --redbg: #FFD9D7;
  --amb: #FF9500; --ambl: #FFF6E8; --ambbg: #FFE6BF;
  --grn: #34C759; --grnl: #ECF9EE; --grnbg: #D2F1D8;
  --blu: #007AFF; --blul: #E8F2FF; --blubg: #C8DDFF;
  --pur: #AF52DE; --purl: #F5EEFA;
  /* Apple system grays — 更接近 macOS / iOS 系统中性色 */
  --g50:#FBFBFD; --g100:#F5F5F7; --g200:#E8E8ED; --g300:#D2D2D7;
  --g400:#AEAEB2; --g500:#86868B; --g600:#6E6E73; --g700:#48484A;
  --g800:#2C2C2E; --g900:#1D1D1F;
  --font: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'PingFang SC', 'Helvetica Neue', system-ui, Arial, sans-serif;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 22px;
  --shadow-sm: 0 0 0 0.5px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);
  --shadow-md: 0 0 0 0.5px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.05);
  --shadow-lg: 0 0 0 0.5px rgba(0,0,0,.04), 0 12px 28px rgba(0,0,0,.08);
  --glass-bg: rgba(255,255,255,.72);
  --glass-blur: saturate(180%) blur(20px);
}
* { box-sizing: border-box; margin: 0; padding: 0; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { font-family: var(--font); background: var(--g100); color: var(--g900); min-height: 100vh; letter-spacing: -0.005em; }

/* ── TOPBAR · 玻璃 ── */
.topbar { display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);border-bottom:0.5px solid rgba(0,0,0,.06);position:sticky;top:0;z-index:50; }
.topbar::after { content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:linear-gradient(90deg, transparent 0%, transparent 47%, rgba(26,107,74,.9) 50%, transparent 53%, transparent 100%);background-size:400% 100%;background-repeat:no-repeat;animation:tbMarquee 9s linear infinite;pointer-events:none; }
@keyframes tbMarquee { 0% { background-position:200% 0; } 100% { background-position:-100% 0; } }
.tb-l { display:flex;align-items:center;gap:16px; }
.logo { display:inline-flex;flex-direction:column;align-items:center;line-height:1;padding-right:2px; }
.logo-mark { font-family:'Instrument Serif','Times New Roman','Songti SC',Georgia,serif;font-size:32px;font-weight:400;font-style:italic;color:var(--p);letter-spacing:-.005em;line-height:.95; }
.logo-tag { display:inline-flex;align-items:center;gap:5px;font-size:7.5px;font-weight:500;color:var(--p);letter-spacing:.16em;margin-top:3px;text-transform:none;opacity:.8; }
.logo-tag-line { width:11px;height:0.5px;background:var(--p);opacity:.5; }
.logo-sys { display:none; }
.tb-stu { display:flex;align-items:center;gap:10px;padding:4px 14px 4px 4px;background:rgba(0,0,0,.04);border:0;border-radius:100px;cursor:pointer;transition:background .15s; }
.tb-stu:hover { background:rgba(0,0,0,.06); }
.tb-stu-ava { width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11px; }
.tb-stu-nm { font-size:13px;font-weight:600;color:var(--g900);letter-spacing:-.005em; }
.tb-stu-meta { font-size:11px;color:var(--g500);margin-top:1px; }
.tb-r { display:flex;align-items:center;gap:14px; }
.live { display:inline-flex;align-items:center;gap:6px;padding:4px 11px;background:var(--pl);color:var(--p);border-radius:100px;font-size:11px;font-weight:600; }
.live-dot { width:6px;height:6px;border-radius:50%;background:var(--grn);animation:pulse 1.8s infinite; }
.tb-ai { display:inline-flex;align-items:center;gap:7px;padding:6px 14px;background:linear-gradient(135deg,var(--grn),var(--p));color:#fff;border:0;border-radius:100px;font-size:12px;font-weight:600;cursor:pointer;letter-spacing:-.005em;box-shadow:0 1px 3px rgba(52,199,89,.3);transition:transform .12s, box-shadow .15s;font-family:var(--font); }
.tb-ai:hover { transform:translateY(-1px);box-shadow:0 3px 8px rgba(52,199,89,.4); }
.tb-ai:active { transform:translateY(0); }
.tb-ai svg { width:14px;height:14px; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.45;transform:scale(1.35)} }
.avatar { width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--grn),var(--p));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11.5px;box-shadow:var(--shadow-sm); }

/* ── LAYOUT ── */
.layout { display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 52px); }

/* ── SIDEBAR · 玻璃 ── */
.sb { background:var(--glass-bg);backdrop-filter:var(--glass-blur);border-right:0.5px solid rgba(0,0,0,.08);padding:16px 12px;overflow-y:auto;max-height:calc(100vh - 52px); }
.sb-grp-hd { padding:14px 12px 6px;font-size:11px;font-weight:600;color:var(--g500);letter-spacing:.02em;display:flex;align-items:center;gap:8px;text-transform:none; }
.sb-grp-stage { display:inline-block;padding:2px 8px;background:var(--pl);color:var(--p);border-radius:100px;font-size:10px;font-weight:600;letter-spacing:.01em; }
.sb-i { display:flex;align-items:center;gap:10px;padding:8px 12px;margin:1px 0;font-size:13px;color:var(--g700);cursor:pointer;border-radius:8px;border-left:0;transition:background .15s, color .15s; }
.sb-i:hover { background:rgba(0,0,0,.04);color:var(--g900); }
.sb-i.active { background:var(--pl);color:var(--p);font-weight:600; }
.sb-ic { display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;opacity:.85; }
.sb-ic svg { width:18px;height:18px;stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round; }
/* 通用 Lucide inline 图标（lucidify 注入的内容用） */
.lic { display:inline-block;vertical-align:-2px;margin-right:1px;stroke:currentColor;fill:none;flex-shrink:0; }
.sb-tag { margin-left:auto;font-size:10px;padding:2px 7px;background:rgba(0,0,0,.06);color:var(--g600);border-radius:100px;font-weight:600; }
.sb-i.active .sb-tag { background:rgba(26,107,74,.15);color:var(--p); }
.sb-tag.new { background:var(--accl);color:var(--acc); }

/* ── SIDEBAR · 折叠机制 + 顶部 hamburger + 底部设置/退出(行为照搬 prod main AppLayout) ── */
.sb-head { display:flex;align-items:center;justify-content:flex-start;gap:8px;padding:6px 6px 12px;border-bottom:0.5px solid rgba(0,0,0,.06);margin-bottom:8px; }
.sb-collapse-btn { display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:0;background:transparent;color:var(--g600);cursor:pointer;transition:background .15s, color .15s;flex-shrink:0; }
.sb-collapse-btn:hover { background:rgba(0,0,0,.04);color:var(--g900); }
.sb-collapse-btn svg { width:18px;height:18px; }
.sb-head-mark { width:32px;height:32px;-o-object-fit:contain;object-fit:contain;border-radius:8px; }

.sb-actions { margin-top:18px;padding-top:12px;border-top:0.5px solid rgba(0,0,0,.06);display:flex;flex-direction:column;gap:2px; }
/* font-family/weight 显式继承 — 防 button 默认字体跟 .sb-i 不一致 */
.sb-action { display:flex;align-items:center;gap:10px;padding:8px 12px;margin:1px 0;font-family:inherit;font-size:13px;font-weight:400;color:var(--g700);cursor:pointer;border-radius:8px;border:0;background:transparent;width:100%;text-align:left;transition:background .15s, color .15s; }
.sb-action:hover { background:rgba(0,0,0,.04);color:var(--g900); }
.sb-action.active { background:var(--pl);color:var(--p);font-weight:600; }

/* dashboard 政策卡 hover 灰度跟左侧学生卡(.sc:hover)一致 */
.pf-item { cursor:pointer;transition:background .15s; }
.pf-item:hover { background:var(--g100); }

/* sb-collapsed 套餐:整组样式仅在折叠态生效 */
.layout.layout-collapsed,
.layout:has(.sb.sb-collapsed) { grid-template-columns:64px 1fr; }
.sb.sb-collapsed { padding:16px 8px; }
.sb.sb-collapsed .sb-head { flex-direction:column;align-items:center;gap:10px;padding:6px 0 12px; }
.sb.sb-collapsed .sb-grp-hd { display:none; }
/* 2026-05-30: 折叠按钮挪到"工作台" group header 行最右 (sb-grp-hd--with-collapse) */
.sb-grp-hd--with-collapse .sb-collapse-btn { margin-left:auto; }
.sb.sb-collapsed .sb-grp-hd--with-collapse { display:flex;justify-content:center;padding:6px 0 8px;border-bottom:0.5px solid rgba(0,0,0,.06);margin-bottom:6px; }
.sb.sb-collapsed .sb-grp-hd--with-collapse > span { display:none; }
.sb.sb-collapsed .sb-grp-hd--with-collapse .sb-collapse-btn { margin-left:0; }
.sb.sb-collapsed .sb-i { justify-content:center;padding:10px 0;gap:0; }
.sb.sb-collapsed .sb-i > span:not(.sb-ic) { display:none; }
.sb.sb-collapsed .sb-tag { display:none; }
.sb.sb-collapsed .sb-action { justify-content:center;padding:10px 0;gap:0; }
.sb.sb-collapsed .sb-action-label { display:none; }

/* ── MAIN ── */
/* flex column + footer margin-top:auto:LegalFooter 始终贴 viewport 最底,即使 Outlet 内容短也不会浮在中段
 * min-height + max-height 一起 = main 固定 viewport - 52px 高度,
 * flex column 才能把空余分给 margin-top:auto 的 footer */
.main { padding:24px 28px;overflow-y:auto;height:calc(100vh - 52px);display:flex;flex-direction:column; }
.main > footer { margin-top:auto; }
.page { display:none; }
.page.active { display:block;animation:fadeIn .35s cubic-bezier(.4,0,.2,1); }
@keyframes fadeIn { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }

/* ── PAGE HEADER ── */
.ph { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:16px; }
.ph-l { display:flex;gap:14px;align-items:flex-start; }
.ph-ic { display:none; } /* 2026-05-16 用户：删除所有页头大 icon */
.sh-hd-ic, .eh-hd-ic, .oc-ic { display:none !important; }

/* 2026-05-16 用户：取消所有卡片左侧色条 */
.kpi, .alert-card, .sc, .rs-card, .rs-card.dec, .rs-card.coun, .rs-card.out,
.card[style*="border-left"], .stu-row, .act-rec-card,
.fw-target, .eh-leg, .eg-card, .eg-result, .oc-card, .sn-detail {
  border-left: 0 !important;
}
.alert-card::before { display: none !important; }
.sc::before { display: none !important; }
.sc.is-red, .sc.is-amber, .sc.is-blue, .sc.is-green {
  border-left: 0 !important;
}
.ph h1 { font-size:22px;font-weight:600;color:var(--g900);letter-spacing:-.015em;line-height:1.25; }
.ph-sub { font-size:13px;color:var(--g500);margin-top:3px;line-height:1.5;letter-spacing:-.005em; }
.ph-r { display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end; }
.ph-r-col { display:flex;flex-direction:column;align-items:flex-end;gap:8px; }
.ph-stu { display:inline-flex;align-items:center;gap:10px;padding:4px 14px 4px 4px;background:rgba(0,0,0,.04);border:0;border-radius:100px;cursor:pointer;transition:background .15s; }
.ph-stu:hover { background:rgba(0,0,0,.07); }
.ph-stu-ava { width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11px; }
.ph-stu-nm { font-size:13px;font-weight:600;color:var(--g900);letter-spacing:-.005em;line-height:1.2; }
.ph-stu-meta { font-size:11px;color:var(--g500);margin-top:1px;letter-spacing:-.005em; }
.ph-stu-arrow { font-size:10px;color:var(--g400);margin-left:2px; }
.btn { padding:7px 14px;border:0;background:rgba(0,0,0,.05);border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--g900);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s, transform .15s; letter-spacing:-.005em; }
.btn:hover { background:rgba(0,0,0,.08); }
.btn:active { transform:scale(.97); }
.btn:disabled { cursor:not-allowed;opacity:.5;transform:none; }
.btn:disabled:hover { background:rgba(0,0,0,.05); }
.btn-p { background:var(--p);color:#fff;box-shadow:var(--shadow-sm); }
.btn-p:hover { background:var(--pd);box-shadow:var(--shadow-md); }
.btn-p:disabled { background:#A7C4B3;box-shadow:none;opacity:.75; }
.btn-p:disabled:hover { background:#A7C4B3;box-shadow:none; }
.btn-acc { background:var(--acc);color:#fff;box-shadow:var(--shadow-sm); }
.btn-acc:hover { background:#9333EA;box-shadow:var(--shadow-md); }

/* ── CARDS ── */
.card { background:#fff;border-radius:var(--radius-lg);border:0;padding:18px;box-shadow:var(--shadow-sm); }
.card-h { font-size:14px;font-weight:600;color:var(--g900);margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;letter-spacing:-.008em; }
.card-h-l { display:flex;align-items:center;gap:8px; }
.grid { display:grid;gap:14px; }

/* ── ATC 作战看板 (page 1) ── */
.atc-hero { display:flex;justify-content:space-between;align-items:center;margin-bottom:20px; }
.atc-hero h2 { font-size:24px;font-weight:600;color:var(--g900);letter-spacing:-.02em; }
.atc-hero p { font-size:13px;color:var(--g500);margin-top:4px;letter-spacing:-.005em; }
.atc-clock { font-size:13px;color:var(--g500);font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:8px;padding:5px 11px;background:rgba(0,0,0,.04);border-radius:100px; }
.atc-clock .live-dot { background:var(--grn); }

.zone-label { font-size:11px;font-weight:600;color:var(--g500);letter-spacing:.02em;margin-bottom:10px;display:flex;align-items:center;gap:6px;text-transform:none; }
.alert-cards { display:flex;gap:14px;margin-bottom:22px;flex-wrap:wrap; }
.alert-card { flex:1;min-width:340px;background:#fff;border:0;border-radius:var(--radius-lg);padding:18px 20px;display:flex;gap:14px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm); }
.alert-card::before { content:'';position:absolute;top:0;left:0;bottom:0;width:4px;background:var(--red);border-radius:4px 0 0 4px; }
.alert-card.amber::before { background:var(--amb); }
.alert-icon { font-size:22px;color:#fff;flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-md);background:var(--red);display:flex;align-items:center;justify-content:center; }
.alert-card.amber .alert-icon { background:var(--amb); }
.alert-icon svg { stroke:#fff !important; }
/* 看板红区 critical: 纯线条红色感叹号 + 浅红底 (替原白色 siren) */
.alert-icon.excl { background:var(--redbg); }
.alert-icon.excl svg { stroke:var(--red) !important; }
.alert-body { flex:1;min-width:0; }
.alert-title { font-size:14px;font-weight:600;color:var(--g900);margin-bottom:6px;display:flex;align-items:center;gap:8px;letter-spacing:-.008em; }
.alert-cd { font-size:11px;padding:3px 9px;background:var(--red);color:#fff;border-radius:100px;font-weight:600;letter-spacing:-.005em; }
.alert-card.amber .alert-cd { background:var(--amb); }
.alert-msg { font-size:13px;color:var(--g700);line-height:1.6;margin-bottom:8px;letter-spacing:-.005em; }
.alert-msg strong { color:var(--g900);font-weight:600; }
.alert-meta { font-size:11px;color:var(--g500);margin-bottom:11px;letter-spacing:-.005em; }
.alert-btn { padding:7px 14px;background:var(--red);color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;letter-spacing:-.005em; }
.alert-card.amber .alert-btn { background:var(--amb); }
.alert-btn:hover { transform:translateY(-1px);box-shadow:0 4px 10px rgba(255,59,48,.25); }
.alert-card.amber .alert-btn:hover { box-shadow:0 4px 10px rgba(255,149,0,.25); }

.atc-grid { display:grid;grid-template-columns:1.3fr 1fr;gap:16px;margin-bottom:18px; }
.caseload { background:#fff;border:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;max-height:540px;height:540px; }
.caseload-h { padding:14px 18px;border-bottom:0.5px solid rgba(0,0,0,.06);display:flex;justify-content:space-between;align-items:center;flex-shrink:0; }
/* 学生列车竖直 scroll(用户 2026-05-24 拍板回退 v3 demo HTML 同款,
 * spec §1.2 区域 D "横向滑动" 改成竖向)*/
.caseload-body { flex:1;min-height:0;overflow-y:auto; }
.caseload-body::-webkit-scrollbar { width:8px; }
.caseload-body::-webkit-scrollbar-track { background:rgba(0,0,0,.04);border-radius:4px;margin:4px 0; }
.caseload-body::-webkit-scrollbar-thumb { background:rgba(0,0,0,.25);border-radius:4px;border:1px solid transparent;background-clip:padding-box; }
.caseload-body::-webkit-scrollbar-thumb:hover { background:rgba(0,0,0,.4);background-clip:padding-box; }
.caseload-h-t { font-size:14px;font-weight:600;color:var(--g900);letter-spacing:-.008em; }
.caseload-h-d { font-size:11.5px;color:var(--g500);margin-top:3px;letter-spacing:-.005em; }
/* 2026-05-16 用户：学生卡更紧凑 + 右栏绝对定位，让 issues 紧贴目标 */
.sc { padding:10px 14px 10px 14px;border-bottom:0.5px solid rgba(0,0,0,.05);cursor:pointer;transition:background .15s;position:relative; }
.sc:hover { background:var(--g100); }
.sc:last-child { border:none; }
.sc::before { content:'';position:absolute;left:0;top:10px;bottom:10px;width:3px;background:transparent;border-radius:0 3px 3px 0; }
.sc.is-red::before { background:var(--red); }
.sc.is-amber::before { background:var(--amb); }
.sc.is-blue::before { background:var(--blu); }
.sc.is-green::before { background:var(--grn); }
.sc-top { display:block;margin-bottom:5px;padding-right:130px;position:relative; }
.sc-name { font-size:13.5px;font-weight:600;color:var(--g900);letter-spacing:-.008em; }
.sc-target { font-size:11.5px;color:var(--g500);margin-top:1px;letter-spacing:-.005em; }
.sc-right { position:absolute;top:10px;right:14px;bottom:13px;text-align:right;display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;gap:1px; }
.sc-deadline { line-height:1; }
.sc-status { font-size:10.5px;padding:2px 8px;border-radius:100px;font-weight:600;letter-spacing:-.005em; }
.sc-status.red { background:var(--redbg);color:var(--red); }
.sc-status.amber { background:var(--ambbg);color:var(--amb); }
.sc-status.blue { background:var(--blubg);color:var(--blu); }
.sc-status.green { background:var(--grnbg);color:var(--grn); }
.sc-deadline { font-size:11px;color:var(--g500);margin-top:3px;letter-spacing:-.005em; }
.sc-fail { font-size:11px;color:var(--red);font-weight:600;margin-top:1px; }
.sc-issues { display:flex;flex-wrap:wrap;gap:5px;margin-top:0; }
.sc-issue { font-size:11px;padding:3px 9px;background:rgba(0,0,0,.05);color:var(--g700);border-radius:100px;font-weight:500;letter-spacing:-.005em; }
.sc-issue.warn { background:var(--ambbg);color:var(--amb); }

.policy-feed { background:#fff;border:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;max-height:540px;height:540px; }
.policy-feed-h { padding:14px 18px;border-bottom:0.5px solid rgba(0,0,0,.06);display:flex;justify-content:space-between;align-items:center;flex-shrink:0; }
/* 与 .caseload-body 同款滚动条；overflow:auto 让不溢出时完全隐藏（避免 dotted/empty 残影） */
.pf-body { flex:1;min-height:0;overflow-y:auto; }
.pf-body::-webkit-scrollbar { width:8px; }
.pf-body::-webkit-scrollbar-track { background:rgba(0,0,0,.04);border-radius:4px;margin:4px 0; }
.pf-body::-webkit-scrollbar-thumb { background:rgba(0,0,0,.25);border-radius:4px;border:1px solid transparent;background-clip:padding-box; }
.pf-body::-webkit-scrollbar-thumb:hover { background:rgba(0,0,0,.4);background-clip:padding-box; }
.pf-item { padding:13px 18px;border-bottom:0.5px solid rgba(0,0,0,.05);display:flex;gap:11px;transition:background .15s; }
.pf-item:last-child { border:none; }
.pf-item:hover { background:var(--g100); }
.pf-ic { font-size:18px;flex-shrink:0; }
.pf-body { flex:1;min-width:0; }
.pf-msg { font-size:12.5px;color:var(--g700);line-height:1.55;letter-spacing:-.005em; }
.pf-msg strong { color:var(--g900);font-weight:600; }
.pf-meta { display:flex;justify-content:space-between;align-items:center;margin-top:6px; }
.pf-time { font-size:11px;color:var(--g400); }
.pf-act { font-size:11.5px;color:var(--p);font-weight:600;cursor:pointer;letter-spacing:-.005em; }
.pf-act:hover { text-decoration:underline; }

/* 2026-05-16 用户：KPI 卡改横向布局 — 左侧 label+desc，右侧大数字 */
.kpi-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px; }
.kpi { background:#fff;border-radius:var(--radius-lg);border:0;padding:14px 18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:center;gap:12px;min-height:78px; }
.kpi-text { flex:1;min-width:0;display:flex;flex-direction:column;gap:4px; }
.kpi-l { font-size:13px;color:var(--g800);font-weight:500;letter-spacing:-.005em;display:flex;align-items:center;gap:6px; }
.kpi-l .lic { margin-right:0; }
.kpi-d { font-size:11.5px;letter-spacing:-.005em;color:var(--g500);padding-left:20px; } /* 与 dot 后的文本左对齐 */
.kpi-d.up { color:var(--grn); }
.kpi-d.dn { color:var(--red); }
.kpi-v { font-size:28px;font-weight:600;color:var(--g900);line-height:1;letter-spacing:-.025em;font-variant-numeric:tabular-nums;flex-shrink:0;display:inline-flex;align-items:baseline;gap:0; }
.kpi-v sub { font-size:13px;font-weight:500;color:var(--g500);margin-left:1px;letter-spacing:-.005em; }

.modules-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:14px; }
.mod-card { background:#fff;border-radius:var(--radius-lg);border:0;padding:18px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm); }
.mod-card:hover { transform:translateY(-3px);box-shadow:var(--shadow-lg); }
.mod-card-hd { display:flex;justify-content:space-between;align-items:center;margin-bottom:10px; }
.mod-card-ic { width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:17px; }
.mod-card-status { font-size:10px;padding:3px 8px;border-radius:100px;font-weight:600;letter-spacing:-.005em; }
.status-live { background:var(--grnl);color:var(--grn); }
.status-coming { background:var(--ambl);color:var(--amb); }
.mod-card-t { font-size:14px;font-weight:600;color:var(--g900);margin-bottom:4px;letter-spacing:-.008em; }
.mod-card-d { font-size:12px;color:var(--g500);line-height:1.5;letter-spacing:-.005em; }

/* ── ESSAY GENERATE · 生成模式（初稿撰写表单）─── */
.eg-tabs { display:flex;align-items:center;gap:8px;margin-bottom:14px; }
.eg-tab { padding:6px 14px;background:rgba(0,0,0,.04);border:1.5px solid transparent;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--g700);cursor:pointer;letter-spacing:-.005em;transition:all .15s; }
.eg-tab.active { background:var(--pl);border-color:var(--p);color:var(--p);font-weight:600; }
.eg-tab-add { padding:6px 12px;background:rgba(0,0,0,.04);border:0;border-radius:var(--radius-sm);font-size:12.5px;color:var(--g600);cursor:pointer;letter-spacing:-.005em; }
.eg-tab-add:hover { background:rgba(0,0,0,.08); }

.eg-stepper { display:flex;align-items:center;gap:10px;margin-bottom:18px; }
.eg-step { display:flex;align-items:center;gap:8px; }
.eg-step-n { width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;background:rgba(0,0,0,.06);color:var(--g500);letter-spacing:-.005em; }
.eg-step.active .eg-step-n { background:var(--p);color:#fff;box-shadow:var(--shadow-sm); }
.eg-step-l { font-size:13.5px;font-weight:500;color:var(--g500);letter-spacing:-.005em; }
.eg-step.active .eg-step-l { color:var(--p);font-weight:600; }
.eg-step-arrow { color:var(--g300);font-size:14px; }

.eg-layout { display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start; }
.eg-card { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 26px; }
.eg-card-h { font-size:16px;font-weight:600;color:var(--p);letter-spacing:-.012em;margin-bottom:5px;display:flex;align-items:center;gap:6px; }
.eg-card-h-num { color:var(--p);display:inline-flex;align-items:center;justify-content:center; }
.eg-card-d { font-size:12.5px;color:var(--g500);letter-spacing:-.005em;margin-bottom:18px;padding-bottom:14px;border-bottom:0.5px solid rgba(0,0,0,.08); }
.eg-row { margin-bottom:14px; }
.eg-row-l { font-size:12.5px;color:var(--g700);font-weight:500;letter-spacing:-.005em;margin-bottom:6px; }
.eg-row-2c { display:grid;grid-template-columns:1fr 1fr;gap:10px; }
.eg-sel,.eg-inp { width:100%;padding:9px 12px;border:1px solid rgba(0,0,0,.1);background:#fff;border-radius:var(--radius-sm);font-size:13px;color:var(--g900);font-family:var(--font);letter-spacing:-.005em;transition:border-color .15s; }
.eg-sel:focus,.eg-inp:focus { outline:0;border-color:var(--p); }
.eg-ta { width:100%;padding:9px 12px;border:1px solid rgba(0,0,0,.1);background:#fff;border-radius:var(--radius-sm);font-size:13px;color:var(--g900);font-family:var(--font);letter-spacing:-.005em;resize:vertical;min-height:64px;transition:border-color .15s; }
.eg-ta:focus { outline:0;border-color:var(--p); }
.eg-country { display:grid;grid-template-columns:repeat(3,1fr);gap:8px; }
.eg-country-btn { padding:11px 8px;background:#fff;border:1.5px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--g700);cursor:pointer;letter-spacing:-.005em;transition:all .15s;line-height:1.35; }
.eg-country-btn:hover { background:rgba(0,0,0,.03); }
.eg-country-btn.active { background:var(--pl);border-color:var(--p);color:var(--p);font-weight:600; }
.eg-multi { position:relative; }
.eg-multi-btn { width:100%;padding:9px 12px;border:1px solid rgba(0,0,0,.1);background:#fff;border-radius:var(--radius-sm);font-size:13px;color:var(--g900);font-family:var(--font);letter-spacing:-.005em;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left;transition:border-color .15s; }
.eg-multi-btn:hover { border-color:rgba(0,0,0,.2); }
.eg-multi.open .eg-multi-btn { border-color:var(--p); }
.eg-multi-label { overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.eg-multi-panel { display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:4px;z-index:50;max-height:240px;overflow-y:auto; }
.eg-multi.open .eg-multi-panel { display:block; }
.eg-multi-opt { display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;font-size:12.5px;color:var(--g800);cursor:pointer;letter-spacing:-.005em;transition:background .12s; }
.eg-multi-opt:hover { background:rgba(0,0,0,.04); }
.eg-multi-opt input { accent-color:var(--p);width:14px;height:14px;flex-shrink:0; }
.eg-num-row { display:flex;align-items:center;gap:8px; }
.eg-num { width:90px;padding:9px 12px;border:1px solid rgba(0,0,0,.1);background:#fff;border-radius:var(--radius-sm);font-size:13px;color:var(--g900);font-family:var(--font);font-variant-numeric:tabular-nums; }
.eg-gen-btn { width:100%;padding:13px;background:var(--p);color:#fff;border:0;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;letter-spacing:-.005em;margin-top:8px;transition:background .15s,opacity .15s; }
.eg-gen-btn:hover:not(:disabled) { background:#155a3a; }
.eg-gen-btn:disabled { background:#A7C4B3;cursor:not-allowed;opacity:.75; }
.eg-result { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 26px;display:flex;flex-direction:column;min-height:480px; }
.eg-result-h { font-size:16px;font-weight:600;color:var(--g900);letter-spacing:-.012em;padding-bottom:14px;border-bottom:0.5px solid rgba(0,0,0,.08);margin-bottom:0; }
.eg-result-empty { flex:1;display:flex;align-items:center;justify-content:center;color:var(--g500);font-size:13.5px;letter-spacing:-.005em;text-align:center;padding:32px; }

/* ── LOR HOME · AI 推荐信首页 (复用 .eh-* + 加搜索/拖拽) ── */
.eh-lib-bar { display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap; }
.eh-lib-bar-l { display:flex;align-items:center;gap:8px; }
.eh-lib-bar-t { font-size:15px;font-weight:600;color:var(--g900);letter-spacing:-.01em;display:inline-flex;align-items:center;gap:6px; }
.eh-lib-bar-cnt { padding:3px 11px;background:rgba(0,0,0,.04);border-radius:100px;font-size:11.5px;color:var(--g600);font-weight:500;letter-spacing:-.005em; }
.eh-lib-bar-r { display:flex;align-items:center;gap:8px; }
.eh-lib-sub { font-size:12px;color:var(--g500);margin-bottom:10px;letter-spacing:-.005em; }
.eh-search { width:100%;padding:11px 16px;border:2px solid var(--p);border-radius:var(--radius-md);background:#fff;font-size:13.5px;color:var(--g700);font-family:var(--font);letter-spacing:-.005em;cursor:pointer;transition:background .15s;margin-bottom:12px; }
.eh-search:hover { background:var(--pl); }
.eh-drop { border:2px dashed rgba(26,107,74,.35);border-radius:var(--radius-lg);padding:36px 24px;text-align:center;background:rgba(26,107,74,.03);margin-bottom:14px;cursor:pointer;transition:background .15s;position:relative; }
.eh-drop:hover { background:rgba(26,107,74,.07); }
.eh-drop::before { content:'';position:absolute;left:36px;top:24px;width:8px;height:8px;border-radius:50%;background:var(--p);opacity:.4; }
.eh-drop-ic { font-size:24px;color:var(--p);margin-bottom:10px;display:inline-block; }
.eh-drop-t { font-size:13.5px;color:var(--g600);letter-spacing:-.005em; }
.eh-doc-uni-ic { font-size:13px;color:var(--g500);margin-right:5px; }
.eh-doc-uni-tag { display:inline-flex;align-items:center;padding:2px 8px;background:rgba(0,0,0,.04);border-radius:100px;font-size:10.5px;font-weight:600;color:var(--g600);letter-spacing:-.005em;margin-left:6px; }
.eh-doc-cnt { font-size:11.5px;color:var(--g500);letter-spacing:-.005em;font-variant-numeric:tabular-nums; }
.eh-doc-dt { font-size:11.5px;color:var(--g500);letter-spacing:-.005em;font-variant-numeric:tabular-nums; }

/* ── ESSAY HOME · 文书工坊首页 ── */
.eh-hd { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px;gap:14px; }
.eh-hd-l { display:flex;align-items:flex-start;gap:12px; }
.eh-hd-ic { font-size:24px;color:var(--p);flex-shrink:0;margin-top:1px; }
.eh-hd h1 { font-size:24px;font-weight:600;color:var(--g900);letter-spacing:-.02em; }
.eh-hd p { font-size:13px;color:var(--g500);margin-top:4px;letter-spacing:-.005em; }
.eh-tabs { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px; }
.eh-tab { padding:13px 18px;background:rgba(0,0,0,.04);border:0;border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--g700);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;letter-spacing:-.005em;transition:all .15s; }
.eh-tab.active { background:var(--p);color:#fff;box-shadow:var(--shadow-sm); }
.eh-tab:hover:not(.active) { background:rgba(0,0,0,.07); }
.eh-mode { display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px; }
.eh-mode-l { display:flex;align-items:center;gap:6px; }
.eh-mode-btn { padding:8px 14px;background:rgba(0,0,0,.04);border:0;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--g700);cursor:pointer;display:inline-flex;align-items:center;gap:5px;letter-spacing:-.005em;transition:background .15s; }
.eh-mode-btn:hover { background:rgba(0,0,0,.08); }
.eh-mode-btn.active { background:var(--p);color:#fff; }
.eh-ver { padding:5px 11px;background:rgba(0,0,0,.04);border-radius:100px;font-size:11.5px;color:var(--g600);letter-spacing:-.005em; }

.eh-banner { background:rgba(26,107,74,.06);border:1.5px solid rgba(26,107,74,.18);border-radius:var(--radius-lg);padding:18px 22px;margin-bottom:22px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:background .15s; }
.eh-banner:hover { background:rgba(26,107,74,.1); }
.eh-banner-ic { width:44px;height:44px;border-radius:var(--radius-md);background:#fff;color:var(--p);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:var(--shadow-sm); }
.eh-banner-b { flex:1;min-width:0; }
.eh-banner-t { font-size:15.5px;font-weight:600;color:var(--g900);letter-spacing:-.01em; }
.eh-banner-d { font-size:12.5px;color:var(--g600);margin-top:3px;letter-spacing:-.005em; }
.eh-banner-arrow { font-size:18px;color:var(--g500);flex-shrink:0; }

.eh-lib-h { display:flex;align-items:baseline;gap:10px;margin-bottom:12px; }
.eh-lib-h-t { font-size:16px;font-weight:600;color:var(--g900);letter-spacing:-.012em; }
.eh-lib-h-d { font-size:13px;color:var(--g500);letter-spacing:-.005em; }
.eh-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px; }
.eh-doc { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px 18px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1); }
.eh-doc:hover { transform:translateY(-2px);box-shadow:var(--shadow-md); }
.eh-doc-top { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;gap:10px; }
.eh-doc-l { display:flex;align-items:flex-start;gap:10px;min-width:0;flex:1; }
.eh-doc-ava { display:none; }
.eh-doc-info { min-width:0;flex:1; }
.eh-doc-nm { font-size:14.5px;font-weight:600;color:var(--g900);letter-spacing:-.008em;line-height:1.25; }
.eh-doc-uni { font-size:12.5px;color:var(--g500);margin-top:2px;letter-spacing:-.005em;line-height:1.35; }
.eh-doc-ver { padding:3px 10px;background:rgba(0,0,0,.04);border-radius:100px;font-size:11px;font-weight:600;color:var(--g600);letter-spacing:-.005em;flex-shrink:0; }
.eh-doc-foot { display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--g500);letter-spacing:-.005em; }
.eh-doc-act { color:var(--p);font-weight:500; }

.eh-legend { display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px; }
.eh-leg { background:#fff;border-radius:var(--radius-md);padding:14px 16px;border-left:3px solid; }
.eh-leg.grn { border-left-color:var(--grn);background:var(--grnl); }
.eh-leg.amb { border-left-color:var(--amb);background:var(--ambl); }
.eh-leg.red { border-left-color:var(--red);background:var(--redl); }
.eh-leg-t { font-size:13px;font-weight:600;color:var(--g900);letter-spacing:-.008em;display:flex;align-items:center;gap:6px; }
.eh-leg-t-dot { width:8px;height:8px;border-radius:50%; }
.eh-leg.grn .eh-leg-t-dot { background:var(--grn); }
.eh-leg.amb .eh-leg-t-dot { background:var(--amb); }
.eh-leg.red .eh-leg-t-dot { background:var(--red); }
.eh-leg-d { font-size:11.5px;color:var(--g600);margin-top:5px;line-height:1.5;letter-spacing:-.005em; }

/* ── SCHOOL HISTORY · 本校历史数据库 ── */
.sh-hd { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:14px;flex-wrap:wrap; }
.sh-hd-l { flex:1;min-width:0;display:flex;align-items:flex-start;gap:12px; }
.sh-hd-ic { font-size:22px;color:var(--p);flex-shrink:0;margin-top:2px; }
.sh-hd h1 { font-size:24px;font-weight:600;color:var(--g900);letter-spacing:-.02em; }
.sh-hd p { font-size:13px;color:var(--g500);margin-top:4px;letter-spacing:-.005em;line-height:1.55;max-width:560px; }
.sh-drop { background:#fff;border:2px dashed rgba(0,0,0,.12);border-radius:var(--radius-lg);padding:42px 24px;text-align:center;margin-bottom:18px;position:relative;transition:border-color .15s, background .15s; }
.sh-drop:hover { border-color:var(--p);background:#FBFEFC; }
.sh-drop::before { content:'';position:absolute;left:50%;bottom:-4px;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--p);opacity:.5; }
.sh-drop-ic { font-size:36px;color:var(--g500);margin-bottom:14px;display:inline-flex;width:60px;height:60px;border-radius:var(--radius-md);background:rgba(0,0,0,.04);align-items:center;justify-content:center; }
.sh-drop-t { font-size:15px;font-weight:600;color:var(--g900);letter-spacing:-.008em;margin-bottom:6px; }
.sh-drop-clk { font-size:13px;color:var(--g500);letter-spacing:-.005em;margin-bottom:14px; }
.sh-drop-clk strong { color:var(--p);font-weight:500;cursor:pointer; }
.sh-drop-clk strong:hover { text-decoration:underline; }
.sh-drop-d1 { font-size:12px;color:var(--g500);letter-spacing:-.005em;margin-bottom:4px; }
.sh-drop-d2 { font-size:11.5px;color:var(--g500);letter-spacing:-.005em; }

.sh-data { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px 22px; }
.sh-data-h { display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap; }
.sh-data-cnt { font-size:14px;font-weight:600;color:var(--g900);letter-spacing:-.008em; }
.sh-data-cnt strong { color:var(--p);font-weight:600; }
.sh-data-search { margin-left:auto;display:flex;align-items:center;gap:7px;padding:7px 13px;background:rgba(0,0,0,.04);border-radius:var(--radius-sm);font-size:13px;color:var(--g500);min-width:180px; }
.sh-data-search input { flex:1;border:0;background:transparent;outline:0;font-size:13px;color:var(--g900);font-family:var(--font);letter-spacing:-.005em; }
.sh-data-search input::-moz-placeholder { color:var(--g500); }
.sh-data-search input::placeholder { color:var(--g500); }
.sh-data-filter { width:32px;height:32px;border-radius:var(--radius-sm);background:rgba(0,0,0,.04);border:0;display:flex;align-items:center;justify-content:center;color:var(--g700);font-size:14px;cursor:pointer; }
.sh-data-filter:hover { background:rgba(0,0,0,.08); }
.sh-data-sel { padding:7px 10px;background:rgba(0,0,0,.04);border:0;border-radius:var(--radius-sm);font-size:12.5px;color:var(--g700);font-family:var(--font);letter-spacing:-.005em;cursor:pointer;width:95px;min-width:95px; }
.sh-data-add { padding:8px 16px;background:var(--p);color:#fff;border:0;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:5px;letter-spacing:-.005em;box-shadow:var(--shadow-sm);transition:all .15s; }
.sh-data-add:hover { background:var(--pd);transform:translateY(-1px); }

.sh-tbl { width:100%;border-collapse:collapse; }
.sh-tbl th { text-align:left;font-size:11.5px;font-weight:600;color:var(--g500);padding:10px 12px;letter-spacing:-.005em;text-transform:none;border-bottom:0.5px solid rgba(0,0,0,.08); }
.sh-tbl td { padding:14px 12px;font-size:13px;color:var(--g800);border-bottom:0.5px solid rgba(0,0,0,.05);letter-spacing:-.005em;font-variant-numeric:tabular-nums;vertical-align:middle; }
.sh-tbl tr:last-child td { border-bottom:0; }
.sh-tbl-code { font-family:'SF Mono',Menlo,Monaco,Consolas,monospace;font-size:12.5px;color:var(--g700); }
.sh-tbl-pill { display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;font-size:11.5px;font-weight:600;letter-spacing:-.005em; }
.sh-tbl-pill.cb { background:var(--ambl);color:#B45309; }
.sh-tbl-pill.rj { background:var(--redl);color:var(--red); }
.sh-tbl-pill.of { background:var(--grnl);color:#15803D; }
.sh-tbl-pill.wt { background:var(--blul);color:var(--blu); }

/* ── RETROSPECTIVE · 复盘智库三层架构 ── */
.rs-card { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px 24px;margin-bottom:14px;border-left:5px solid transparent; }
.rs-card.dec { border-left-color:var(--red); }
.rs-card.coun { border-left-color:var(--blu); }
.rs-card.out { border-left-color:#10B981; }
.rs-card-h { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;gap:14px; }
.rs-card-h-l { flex:1;min-width:0; }
.rs-card-t { font-size:17px;font-weight:600;color:var(--g900);letter-spacing:-.012em;display:flex;align-items:center;gap:8px; }
.rs-card-d { font-size:12.5px;color:var(--g500);margin-top:4px;letter-spacing:-.005em; }
.rs-badge { display:inline-flex;align-items:center;padding:5px 12px;border-radius:100px;font-size:11.5px;font-weight:600;letter-spacing:-.005em;flex-shrink:0; }
.rs-badge.red { background:var(--redbg);color:var(--red); }
.rs-badge.blu { background:var(--blubg);color:var(--blu); }
.rs-badge.grn { background:var(--grnbg);color:#15803D; }
.rs-alerts { display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px; }
.rs-alert { padding:13px 15px;border-radius:var(--radius-md);font-size:12.5px;line-height:1.6;letter-spacing:-.005em; }
.rs-alert.red { background:var(--redl); }
.rs-alert.amb { background:var(--ambl); }
.rs-alert.grn { background:var(--grnl); }
.rs-alert-t { font-weight:600;margin-bottom:5px;display:flex;align-items:center;gap:5px; }
.rs-alert.red .rs-alert-t { color:var(--red); }
.rs-alert.amb .rs-alert-t { color:#B45309; }
.rs-alert.grn .rs-alert-t { color:#15803D; }
.rs-alert-b { color:var(--g700); }
.rs-alert-b strong { color:var(--g900);font-weight:600; }
.rs-tbl { width:100%;border-collapse:collapse; }
.rs-tbl th { text-align:left;font-size:11.5px;font-weight:600;color:var(--g500);padding:10px 12px;background:rgba(0,0,0,.025);border-radius:0;letter-spacing:-.005em;text-transform:none; }
.rs-tbl th:first-child { border-radius:8px 0 0 8px; }
.rs-tbl th:last-child { border-radius:0 8px 8px 0; }
.rs-tbl td { padding:13px 12px;font-size:13px;color:var(--g800);border-bottom:0.5px solid rgba(0,0,0,.05);letter-spacing:-.005em;vertical-align:middle; }
.rs-tbl tr:last-child td { border-bottom:0; }
.rs-tbl-name { font-weight:600;color:var(--g900); }
.rs-tbl-dim { color:var(--g600);font-size:12.5px; }
.rs-tbl-pill { display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:11.5px;font-weight:600;letter-spacing:-.005em; }
.rs-tbl-pill.red { background:var(--redbg);color:var(--red); }
.rs-tbl-pill.amb { background:var(--ambbg);color:#B45309; }
.rs-tbl-pill.grn { background:var(--grnbg);color:#15803D; }
.rs-tbl-pill.blu { background:var(--blubg);color:var(--blu); }
.rs-link { color:var(--p);font-weight:600;cursor:pointer;font-size:12.5px;letter-spacing:-.005em;text-decoration:none; }
.rs-link:hover { text-decoration:underline; }
.rs-flag { font-size:14px;margin-right:6px; }

/* ── UCAS IMPORT · 文档导入弹窗 ── */
.ucas-mask { display:none;position:fixed;inset:0;background:rgba(0,0,0,.32);backdrop-filter:blur(8px);z-index:200;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto; }
.ucas-mask.open { display:flex;animation:fadeIn .25s ease; }
.ucas-panel { width:100%;max-width:840px;background:#fff;border-radius:var(--radius-xl);box-shadow:0 24px 60px rgba(0,0,0,.25);padding:28px 32px;position:relative; }
.ucas-close { position:absolute;top:18px;right:18px;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.05);border:0;cursor:pointer;font-size:16px;color:var(--g600);display:flex;align-items:center;justify-content:center;transition:background .15s; }
.ucas-close:hover { background:rgba(0,0,0,.1); }
.ucas-hd { padding-bottom:16px;border-bottom:0.5px solid rgba(0,0,0,.08);margin-bottom:18px; }
.ucas-hd h2 { font-size:18px;font-weight:600;color:var(--g900);letter-spacing:-.012em;display:flex;align-items:center;gap:8px; }
.ucas-hd p { font-size:12.5px;color:var(--g500);margin-top:4px;letter-spacing:-.005em; }

.ucas-drop { border:2px dashed rgba(26,107,74,.35);border-radius:var(--radius-lg);padding:36px 24px;text-align:center;margin-bottom:14px;background:var(--pl);transition:border-color .2s, background .2s; cursor:pointer; }
.ucas-drop:hover { border-color:var(--p);background:rgba(26,107,74,.08); }
.ucas-drop-ic { width:50px;height:50px;border-radius:50%;background:rgba(0,0,0,.04);color:var(--p);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 14px; }
.ucas-drop-t { font-size:15px;font-weight:600;color:var(--g900);margin-bottom:6px;letter-spacing:-.008em; }
.ucas-drop-d { font-size:12px;color:var(--g500);margin-bottom:16px;letter-spacing:-.005em; }
.ucas-drop-btn { padding:9px 18px;background:var(--p);color:#fff;border:0;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;letter-spacing:-.005em;box-shadow:var(--shadow-sm);transition:all .15s; }
.ucas-drop-btn:hover { background:var(--pd);transform:translateY(-1px); }

.ucas-file { display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:var(--radius-md);margin-bottom:8px;font-size:13px;letter-spacing:-.005em; }
.ucas-file.bad { background:var(--redl);border:0.5px solid rgba(255,59,48,.25); }
.ucas-file.warn { background:var(--ambl);border:0.5px solid rgba(255,149,0,.25); }
.ucas-file.ok { background:var(--grnl);border:0.5px solid rgba(52,199,89,.2); }
.ucas-file-check { width:18px;height:18px;border-radius:5px;border:1.5px solid var(--g300);flex-shrink:0;cursor:pointer; }
.ucas-file-ic { font-size:18px;flex-shrink:0;color:var(--g500); }
.ucas-file-nm { flex:1;min-width:0;color:var(--g900);font-weight:500; }
.ucas-file-sz { color:var(--g500);font-weight:400;margin-left:4px; }
.ucas-file-tag { display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:100px;font-size:11.5px;font-weight:600;letter-spacing:-.005em; }
.ucas-file-tag.bad { background:rgba(255,59,48,.15);color:var(--red); }
.ucas-file-tag.warn { background:rgba(255,149,0,.18);color:#B45309; }
.ucas-file-tag.ok { background:rgba(52,199,89,.18);color:#15803D; }
.ucas-file-act { padding:5px 11px;background:var(--p);color:#fff;border:0;border-radius:100px;font-size:11.5px;font-weight:600;cursor:pointer;letter-spacing:-.005em;display:inline-flex;align-items:center;gap:4px; }
.ucas-file-act:hover { background:var(--pd); }
.ucas-file-icon-btn { width:28px;height:28px;border-radius:6px;background:transparent;border:0;cursor:pointer;color:var(--g500);font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .15s, color .15s; }
.ucas-file-icon-btn:hover { background:rgba(0,0,0,.05);color:var(--g700); }
.ucas-file-icon-btn.danger:hover { background:var(--redl);color:var(--red); }

.ucas-foot { display:flex;align-items:center;gap:14px;padding-top:14px;border-top:0.5px solid rgba(0,0,0,.08);margin-top:14px;flex-wrap:wrap; }
.ucas-foot-l { font-size:12.5px;color:var(--g700);letter-spacing:-.005em; }
.ucas-foot-sel { padding:7px 13px;background:rgba(0,0,0,.04);border:0;border-radius:var(--radius-sm);font-size:12.5px;color:var(--g700);font-family:var(--font);letter-spacing:-.005em;cursor:pointer; }
.ucas-foot-cnt { margin-left:auto;font-size:12px;color:var(--g500);letter-spacing:-.005em; }
.ucas-foot-merge { padding:9px 18px;background:var(--p);color:#fff;border:0;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;letter-spacing:-.005em;opacity:.5; }
.ucas-foot-merge.enabled { opacity:1;box-shadow:var(--shadow-sm); }
.ucas-foot-merge.enabled:hover { background:var(--pd); }
.ucas-name-hint { font-size:11.5px;color:var(--g500);margin-top:10px;letter-spacing:-.005em; }
.ucas-name-hint strong { color:var(--g700);font-weight:500; }

/* ── WHATIF START · 选学生空白引导页 ── */
.wif-hd { display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:20px;gap:14px; }
.wif-hd-l { display:flex;align-items:flex-start;gap:14px; }
.wif-back { padding:8px 12px;background:rgba(0,0,0,.04);border:0;border-radius:var(--radius-sm);font-size:13px;color:var(--g700);cursor:pointer;letter-spacing:-.005em;transition:background .15s;margin-top:6px; }
.wif-back:hover { background:rgba(0,0,0,.08); }
.wif-hd h1 { font-size:22px;font-weight:600;color:var(--g900);letter-spacing:-.015em; }
.wif-hd-sub { font-size:13px;color:var(--g500);margin-top:4px;letter-spacing:-.005em; }
.wif-stu-pick { display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#fff;border:1px solid #5fa885;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--g800);cursor:pointer;letter-spacing:-.005em;transition:background .15s, transform .15s;box-shadow:var(--shadow-sm); }
.cur-doc-chip { display:inline-flex;align-items:center;gap:8px;padding:7px 14px;background:#fff;border:1px solid #5fa885;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--g800);letter-spacing:-.005em;box-shadow:var(--shadow-sm);cursor:default; }
.cur-doc-chip-l { color:var(--g500);font-weight:400; }
.cur-doc-chip-nm { color:var(--g900);font-weight:600; }
.wif-stu-pick:hover { background:var(--pl); }
.wif-stu-pick:active { transform:scale(.98); }
.wif-stu-pick-num { display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:1.5px solid #5fa885;color:#5fa885;font-size:10px;font-weight:700; }

.wif-empty { background:#fff;border:2px dashed #5fa885;border-radius:var(--radius-xl);padding:48px 32px;text-align:center;box-shadow:var(--shadow-sm);position:relative;min-height:520px;display:flex;flex-direction:column;justify-content:center;align-items:center;transition:background .25s, border-color .25s; }
.wif-empty:hover { background:rgba(95,168,133,.08);border-color:#4f9576; }
.wif-empty::before { content:'';position:absolute;left:32px;top:32px;width:8px;height:8px;border-radius:50%;background:#5fa885;opacity:.4; }
.wif-empty-ic { width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,#EAF6EF,#CFE9DB);color:#5fa885;display:flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:18px;box-shadow:0 4px 20px rgba(95,168,133,.18); }
.wif-empty h2 { font-size:26px;font-weight:600;color:var(--g900);letter-spacing:-.018em;margin-bottom:14px; }
.wif-empty-cta { font-size:15px;font-weight:500;color:#5fa885;letter-spacing:-.008em;margin-bottom:14px;display:inline-flex;align-items:center;gap:8px; }
.wif-empty p { font-size:13.5px;color:var(--g500);line-height:1.7;max-width:560px;letter-spacing:-.005em;margin-bottom:32px; }

.wif-steps { display:flex;align-items:center;gap:14px;margin-bottom:24px; }
.wif-step { display:flex;flex-direction:column;align-items:center;gap:8px; }
.wif-step-num { width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;letter-spacing:-.01em;background:#fff;color:var(--g400);box-shadow:var(--shadow-sm);border:2px solid var(--g200); }
.wif-step.active .wif-step-num { background:#5fa885;color:#fff;border-color:#5fa885;box-shadow:0 4px 14px rgba(95,168,133,.3); }
.wif-step-lbl { font-size:12px;color:var(--g500);letter-spacing:-.005em; }
.wif-step.active .wif-step-lbl { color:#5fa885;font-weight:600; }
.wif-step-arrow { font-size:18px;color:var(--g300);margin-top:-26px; }

.wif-example { display:inline-block;padding:10px 18px;background:rgba(0,0,0,.04);border-radius:100px;font-size:12.5px;color:var(--g700);font-style:italic;letter-spacing:-.005em;margin-bottom:18px; }
.wif-example strong { color:var(--g900);font-style:normal;font-weight:600; }
.wif-link { font-size:12.5px;color:#5fa885;font-weight:500;cursor:pointer;letter-spacing:-.005em;text-decoration:none; }
.wif-link:hover { text-decoration:underline; }

/* ── OUTCOMES · 战绩复盘 ── */
.oc-hd { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px;gap:14px;flex-wrap:wrap; }
.oc-hd-l { display:flex;align-items:center;gap:14px; }
.oc-back { padding:8px 14px;background:rgba(0,0,0,.04);border:0;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--g700);cursor:pointer;display:inline-flex;align-items:center;gap:6px;letter-spacing:-.005em;transition:background .15s; }
.oc-back:hover { background:rgba(0,0,0,.08); }
.oc-ic { width:44px;height:44px;border-radius:var(--radius-md);background:#FFF4DC;color:#C2750B;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:var(--shadow-sm); }
.oc-hd h1 { font-size:24px;font-weight:600;color:var(--g900);letter-spacing:-.02em;line-height:1.2; }
.oc-hd p { font-size:13px;color:var(--g500);margin-top:3px;letter-spacing:-.005em; }
.oc-hd-r { display:flex;align-items:center;gap:8px; }
.btn-gold { background:linear-gradient(135deg,#F59E0B,#D97706);color:#fff;padding:8px 16px;border:0;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;letter-spacing:-.005em;box-shadow:var(--shadow-sm);transition:all .15s; }
.btn-gold:hover { box-shadow:var(--shadow-md);transform:translateY(-1px); }
.oc-filters { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px 18px;margin-bottom:14px;display:flex;align-items:center;gap:14px;flex-wrap:wrap; }
.oc-filter { display:flex;align-items:center;gap:7px; }
.oc-filter-l { font-size:12.5px;color:var(--g600);letter-spacing:-.005em; }
.oc-filter select { padding:6px 13px;background:rgba(0,0,0,.04);border:0;border-radius:100px;font-size:12.5px;color:var(--g700);font-family:var(--font);letter-spacing:-.005em;cursor:pointer; }
.oc-card { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px 24px;margin-bottom:14px; }
.oc-card-h { margin-bottom:14px; }
.oc-card-t { font-size:15px;font-weight:600;color:var(--g900);letter-spacing:-.008em; }
.oc-card-d { font-size:12px;color:var(--g500);margin-top:2px;letter-spacing:-.005em; }

.oc-pyramid { display:flex;flex-direction:column;align-items:center;gap:8px;padding:30px 0; }
.oc-py-row { display:flex;align-items:center;justify-content:center;height:64px;color:#fff;font-size:16px;font-weight:600;letter-spacing:-.005em;border-radius:14px;box-shadow:var(--shadow-md);cursor:pointer;transition:transform .15s; }
.oc-py-row:hover { transform:translateY(-2px) scale(1.01); }
.oc-py-row.l1 { width:30%;background:linear-gradient(135deg,#1E3A8A,#1E40AF); }
.oc-py-row.l2 { width:50%;background:linear-gradient(135deg,#1D4ED8,#2563EB); }
.oc-py-row.l3 { width:70%;background:linear-gradient(135deg,#2563EB,#3B82F6); }
.oc-py-row.l4 { width:90%;background:linear-gradient(135deg,#60A5FA,#93C5FD); }

.oc-grid { display:grid;grid-template-columns:1fr 1fr;gap:14px; }
.oc-chart-wrap { display:flex;justify-content:center;align-items:center;padding:20px 0;min-height:280px; }

/* ── SCHOOL NEWS · 院校资讯 ── */
.sn-hd { margin-bottom:14px; }
.sn-hd h1 { font-size:26px;font-weight:600;color:var(--g900);letter-spacing:-.02em; }
.sn-hd p { font-size:13px;color:var(--g500);margin-top:4px;letter-spacing:-.005em; }
.sn-filters { display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap; }
.sn-chip { padding:7px 16px;background:rgba(0,0,0,.04);border:0;border-radius:100px;font-size:13px;font-weight:500;color:var(--g700);cursor:pointer;letter-spacing:-.005em;transition:background .15s; }
.sn-chip:hover { background:rgba(0,0,0,.07); }
.sn-chip.active { background:var(--p);color:#fff; }
.sn-meta-row { display:flex;justify-content:space-between;align-items:center;margin-bottom:14px; }
.sn-auto { font-size:12px;color:var(--g500);letter-spacing:-.005em; }
.sn-cnt { font-size:12px;color:var(--g500); }
.sn-layout { display:grid;grid-template-columns:380px 1fr;gap:14px; }
.sn-list { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:8px;max-height:calc(100vh - 230px);overflow-y:auto; }
.sn-item { padding:14px 14px;border-radius:var(--radius-md);cursor:pointer;border:0;transition:background .15s;margin-bottom:2px; }
.sn-item:hover { background:rgba(0,0,0,.03); }
.sn-item.active { background:var(--pl); }
.sn-item-tags { display:flex;align-items:center;gap:8px;margin-bottom:6px; }
.sn-type { font-size:11px;font-weight:600;letter-spacing:-.005em; }
.sn-type.r { color:var(--red); }
.sn-type.b { color:var(--blu); }
.sn-type.g { color:var(--grn); }
.sn-time { font-size:11.5px;color:var(--g500); }
.sn-item-t { font-size:14px;font-weight:600;color:var(--g900);line-height:1.45;margin-bottom:8px;letter-spacing:-.008em; }
.sn-item-sub { display:flex;align-items:center;gap:8px;margin-bottom:8px; }
.sn-pill { display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:500;letter-spacing:-.005em; }
.sn-pill.a { background:var(--ambl);color:var(--amb); }
.sn-pill.r { background:var(--redl);color:var(--red); }
.sn-pill-dot { width:5px;height:5px;border-radius:50%; }
.sn-pill-dot.a { background:var(--amb); }
.sn-pill-dot.r { background:var(--red); }
.sn-meta { font-size:11.5px;color:var(--g500);letter-spacing:-.005em; }
.sn-item-stu { display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--g600);letter-spacing:-.005em; }

.sn-detail { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 28px;max-height:calc(100vh - 230px);overflow-y:auto; }
.sn-d-head { display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:12px;color:var(--g500);letter-spacing:-.005em; }
.sn-d-title { font-size:22px;font-weight:600;color:var(--g900);line-height:1.35;letter-spacing:-.015em;margin-bottom:12px; }
.sn-d-tags { display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap; }
.sn-d-source { font-size:11.5px;color:var(--g500);letter-spacing:-.005em; }
.sn-box { padding:14px 16px;border-radius:var(--radius-md);margin-bottom:10px; }
.sn-box-l { font-size:12px;font-weight:600;letter-spacing:-.005em;margin-bottom:6px;display:flex;align-items:center;gap:6px; }
.sn-box-b { font-size:13.5px;line-height:1.6;color:var(--g800);letter-spacing:-.005em; }
.sn-box.ai { background:rgba(0,0,0,.03); }
.sn-box.ai .sn-box-l { color:var(--g600); }
.sn-box.tip { background:var(--accl); }
.sn-box.tip .sn-box-l { color:var(--acc); }
.sn-box.impact { background:#FFF8E0;border:1px solid #FFE9A8; }
.sn-box.impact .sn-box-l { color:#A16207; }
.sn-box.impact .sn-box-b { color:var(--g700); }

/* ── STUDENTS LIST · 学生档案管理列表页 ── */
.stu-hd { display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;gap:14px;flex-wrap:wrap; }
.stu-hd h1 { font-size:26px;font-weight:600;color:var(--g900);letter-spacing:-.02em; }
.stu-hd-r { display:flex;align-items:center;gap:10px;flex-wrap:wrap; }
.stu-search { display:flex;align-items:center;gap:7px;padding:8px 14px;background:rgba(0,0,0,.04);border:0;border-radius:100px;font-size:13px;color:var(--g500);width:280px;letter-spacing:-.005em; }
.stu-search input { flex:1;border:0;background:transparent;outline:0;font-size:13px;color:var(--g900);font-family:var(--font);letter-spacing:-.005em; }
.stu-search input::-moz-placeholder { color:var(--g500); }
.stu-search input::placeholder { color:var(--g500); }
.stu-live { display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--g500); }
.stu-live-dot { width:6px;height:6px;border-radius:50%;background:var(--grn);animation:pulse 1.8s infinite; }
.stu-stats { display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px; }
.stu-stat { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0; }
.stu-stat-l { font-size:12.5px;color:var(--g600);font-weight:500;letter-spacing:-.005em;display:inline-flex;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0; }
.stu-stat-v { font-size:24px;font-weight:600;color:var(--g900);line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums;flex-shrink:0; }
.stu-stat-v.red { color:var(--red); }
.stu-stat-v.amb { color:var(--amb); }
.stu-stat-v.grn { color:var(--grn); }
.stu-filters { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px 18px;margin-bottom:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap; }
.stu-chip { padding:6px 14px;background:rgba(0,0,0,.04);border:0;border-radius:100px;font-size:12.5px;font-weight:500;color:var(--g700);cursor:pointer;display:inline-flex;align-items:center;gap:5px;letter-spacing:-.005em;transition:background .15s; }
.stu-chip:hover { background:rgba(0,0,0,.07); }
.stu-chip.active { background:var(--p);color:#fff; }
.stu-chip-dot { width:6px;height:6px;border-radius:50%; }
.stu-chip-dot.r { background:var(--red); }
.stu-chip-dot.a { background:var(--amb); }
.stu-chip-dot.g { background:var(--grn); }
.stu-sel { padding:6px 13px;background:rgba(0,0,0,.04);border:0;border-radius:100px;font-size:12.5px;color:var(--g700);font-family:var(--font);letter-spacing:-.005em;cursor:pointer; }
.stu-cnt { margin-left:auto;font-size:12px;color:var(--g500); }
.stu-list-wrap { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px 14px 14px 18px;max-height:640px;overflow-y:auto; }
.stu-list-wrap::-webkit-scrollbar { width:8px; }
.stu-list-wrap::-webkit-scrollbar-thumb { background:rgba(0,0,0,.12);border-radius:8px; }
.stu-list-wrap::-webkit-scrollbar-thumb:hover { background:rgba(0,0,0,.2); }
.stu-list-wrap .stu-row { box-shadow:none;background:rgba(0,0,0,.015);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:8px; }
.stu-list-wrap .stu-row:last-child { margin-bottom:0; }
.stu-row { background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px 20px;margin-bottom:10px;display:grid;grid-template-columns:10px 40px 210px 300px 96px 1fr 150px auto;gap:10px 16px;align-items:center; }
.stu-ava { display:none !important; } /* 2026-05-16 用户：删除学生卡圆形姓字头像 */
.stu-row-dot { width:10px;height:10px;border-radius:50%; }
.stu-row-dot.r { background:var(--red); }
.stu-row-dot.a { background:var(--amb); }
.stu-row-dot.g { background:var(--grn); }
.stu-ava { width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#fff; }
.stu-ava.r { background:#FFE5E3;color:var(--red); }
.stu-ava.a { background:#FFF1D6;color:var(--amb); }
.stu-ava.g { background:#D2F1D8;color:var(--grn); }
.stu-ava.b { background:#D9EAFF;color:var(--blu); }
.stu-nm-zh { font-size:15px;font-weight:600;color:var(--g900);letter-spacing:-.008em; }
.stu-nm-en { font-size:12px;color:var(--g500);margin-top:1px;letter-spacing:-.005em; }
.stu-gpa-warn { display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--redbg);color:var(--red);border-radius:100px;font-size:11.5px;font-weight:600;letter-spacing:-.005em; }
.stu-grade-l1 { font-size:13px;color:var(--g700);letter-spacing:-.005em; }
.stu-grade-l2 { font-size:11.5px;color:var(--g500);margin-top:2px;letter-spacing:-.005em; }
.stu-metric-l { font-size:11px;color:var(--g500);margin-bottom:4px;letter-spacing:-.005em; }
.stu-metric-v { font-size:14px;font-weight:600;color:var(--g900);letter-spacing:-.005em;font-variant-numeric:tabular-nums; }
.stu-metric-bar { height:4px;background:rgba(0,0,0,.06);border-radius:100px;overflow:hidden;margin-top:5px; }
.stu-metric-bar-fill { height:100%;border-radius:100px; }
.stu-ddl-l { font-size:11px;color:var(--g500);margin-bottom:4px;letter-spacing:-.005em; }
.stu-ddl-v { display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;letter-spacing:-.005em; }
.stu-ddl-v.r { color:var(--red); }
.stu-ddl-v.a { color:var(--amb); }
.stu-ddl-v.g { color:var(--grn); }
.stu-actions { display:flex;align-items:center;gap:6px; }
.stu-act-btn { padding:8px 16px;background:var(--p);color:#fff;border:0;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:5px;letter-spacing:-.005em;transition:background .15s, transform .15s; }
.stu-act-btn:hover { background:var(--pd); }
.stu-act-btn:active { transform:scale(.97); }
.stu-trash { width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;border:0;display:flex;align-items:center;justify-content:center;color:var(--g500);cursor:pointer;font-size:14px;transition:background .15s, color .15s; }
.stu-trash:hover { background:var(--redl);color:var(--red); }

/* ── STUDENT PROFILE ── */
.prof-grid { display:grid;grid-template-columns:280px 1fr;gap:14px; }
.prof-summary { background:#fff;border:1px solid var(--g200);border-radius:10px;padding:18px;height:-moz-fit-content;height:fit-content; }
/* 可点学生卡 hover 用纯 CSS — 替原内联 JS (re-render 会卡住灰底的 bug) */
.prof-summary.is-clickable { cursor:pointer;transition:background .15s; }
.prof-summary.is-clickable:hover { background:var(--g50); }
.prof-ava { width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;margin:0 auto 14px; }
.prof-nm { font-size:16px;font-weight:800;color:var(--g900);text-align:center;margin-bottom:3px; }
.prof-nm-en { font-size:11.5px;color:var(--g500);text-align:center;margin-bottom:14px; }
.prof-pills { display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px;justify-content:center; }
.prof-pill { font-size:10.5px;padding:3px 8px;background:var(--pl);color:var(--p);border-radius:100px;font-weight:700; }
.prof-row { display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--g100);font-size:11.5px; }
.prof-row:last-of-type { border:none; }
.prof-row-l { color:var(--g500); }
.prof-row-r { color:var(--g800);font-weight:600; }

.prof-tabs { display:flex;gap:2px;align-items:center;background:#fff;border-radius:var(--radius-lg);border:0;padding:6px;margin-bottom:14px;box-shadow:var(--shadow-sm);flex-wrap:nowrap;overflow-x:auto; }
.prof-tab { padding:8px 11px;font-size:12.5px;font-weight:500;color:var(--g600);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.005em;transition:background .15s, color .15s;white-space:nowrap;flex-shrink:0; }
.prof-tab.active { background:var(--pl);color:var(--p);font-weight:600; }
.prof-tab:hover:not(.active) { background:rgba(0,0,0,.04);color:var(--g900); }
.prof-tab-sep { width:1px;height:18px;background:rgba(0,0,0,.08);margin:0 4px; }
.prof-tab-btn { display:inline-flex;align-items:center;gap:5px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--g600);background:transparent;border:0;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.005em;transition:background .15s, color .15s, transform .15s; }
.prof-tab-btn:hover { background:rgba(0,0,0,.04);color:var(--g900); }
.prof-tab-btn:active { transform:scale(.97); }
.prof-subpage { display:none; }
.prof-subpage.active { display:block; }

/* Academic */
.acad-grid { display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px; }
.subject-tbl { width:100%;border-collapse:collapse; }
.subject-tbl th { text-align:left;font-size:11px;font-weight:700;color:var(--g500);padding:8px 10px;background:var(--g50);border-bottom:1px solid var(--g200);text-transform:uppercase;letter-spacing:.3px; }
.subject-tbl td { font-size:12px;padding:9px 10px;border-bottom:1px solid var(--g100);color:var(--g700); }
.subject-tbl tr:last-child td { border:none; }
.grade-pill { display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-weight:800;font-size:11px; }
.grade-A { background:var(--grnbg);color:var(--grn); }
.grade-B { background:var(--blubg);color:var(--blu); }
.grade-C { background:var(--ambbg);color:var(--amb); }

.activity-card { background:#fff;border:1px solid var(--g200);border-radius:9px;padding:11px 14px;margin-bottom:8px;display:flex;align-items:center;gap:11px; }
.activity-card-ic { width:32px;height:32px;border-radius:8px;background:var(--pl);color:var(--p);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0; }
.activity-card-info { flex:1;min-width:0; }
.activity-card-t { font-size:12.5px;font-weight:700;color:var(--g800);margin-bottom:2px; }
.activity-card-meta { font-size:10.5px;color:var(--g500); }
.activity-sat { font-size:10px;padding:2px 7px;border-radius:100px;font-weight:700; }
.sat-high { background:var(--redbg);color:var(--red); }
.sat-medium { background:var(--ambbg);color:var(--amb); }
.sat-low { background:var(--grnbg);color:var(--grn); }

/* ── FIREWALL ── */
.fw-grid { display:grid;grid-template-columns:280px 1fr;gap:14px; }
.fw-student-courses { background:#fff;border:1px solid var(--g200);border-radius:10px;padding:14px;height:-moz-fit-content;height:fit-content; }
.fw-course { display:flex;justify-content:space-between;align-items:center;padding:9px 12px;background:var(--g50);border-radius:7px;margin-bottom:6px;font-size:12px; }
.fw-course-nm { font-weight:700;color:var(--g800); }
.fw-course-pred { color:var(--g500);font-size:11px; }
.fw-add-btn { width:100%;padding:9px;background:transparent;border:1px dashed var(--g300);color:var(--g500);border-radius:7px;font-size:12px;cursor:pointer;margin-top:8px; }
.fw-add-btn:hover { background:var(--pl);border-color:var(--p);color:var(--p);border-style:solid; }

.fw-target { background:#fff;border:1px solid var(--g200);border-radius:10px;padding:14px;margin-bottom:10px; }
.fw-target-hd { display:flex;justify-content:space-between;align-items:center;margin-bottom:10px; }
.fw-target-nm { font-size:13.5px;font-weight:800;color:var(--g900);display:flex;align-items:center;gap:7px; }
.fw-target-tag { font-size:10px;padding:2px 8px;border-radius:100px;font-weight:700; }
.tag-r { background:var(--redbg);color:var(--red); }
.tag-a { background:var(--ambbg);color:var(--amb); }
.tag-g { background:var(--grnbg);color:var(--grn); }
.fw-target-status { font-size:11.5px;color:var(--g500);display:flex;align-items:center;gap:5px; }
.fw-checks { display:flex;flex-direction:column;gap:6px; }
.fw-check { display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:7px;font-size:11.5px; }
.fw-check.pass { background:var(--grnl); }
.fw-check.fail { background:var(--redl); }
.fw-check.warn { background:var(--ambl); }
.fw-check-ic { width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0; }
.fw-check.pass .fw-check-ic { background:var(--grn);color:#fff; }
.fw-check.fail .fw-check-ic { background:var(--red);color:#fff; }
.fw-check.warn .fw-check-ic { background:var(--amb);color:#fff; }
.fw-check-info { flex:1; }
.fw-check-t { font-weight:700;color:var(--g800); }
.fw-check-d { color:var(--g500);font-size:11px;margin-top:2px;line-height:1.45; }
.fw-action { margin-top:8px;padding:8px 11px;background:var(--blul);border:1px solid #c7dbff;border-radius:7px;font-size:11.5px;color:#1e3a8a; }
.fw-action strong { color:var(--blu); }

/* ── WHAT-IF v2 ── */
.wi-layout { display:grid;grid-template-columns:280px 1fr;gap:14px;align-items:start; }
.wi-full { grid-column:1 / -1; }
.wi-schools-list { background:#fff;border:1px solid var(--g200);border-radius:10px;overflow:hidden;display:flex;flex-direction:column; }
.wi-schools-h { padding:11px 13px;border-bottom:1px solid var(--g200);background:var(--g50);font-size:11.5px;font-weight:700;color:var(--g700);display:flex;justify-content:space-between;align-items:center; }
.wi-search { padding:9px 13px;border-bottom:1px solid var(--g200);position:relative; }
.wi-search input { width:100%;padding:6px 10px 6px 32px;border:1px solid var(--g300);border-radius:6px;font-size:11.5px;font-family:var(--font); }
.wi-search-ic { position:absolute;left:24px;top:50%;transform:translateY(-50%);color:var(--g400);pointer-events:none;display:flex; }
.wi-search-ic svg { width:14px;height:14px; }
.wi-schools-body { padding:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px; }
.wi-school-row { padding:11px 13px;border:1px solid var(--g200);border-radius:9px;cursor:pointer;display:flex;align-items:center;gap:9px;transition:all .12s;background:#fff; }
.wi-school-row:hover { background:var(--g50);border-color:var(--g300); }
.wi-school-row.active { background:var(--pl);border:1px solid var(--p);box-shadow:0 0 0 2px rgba(26,107,74,.1); }
.wi-school-flag { font-size:14px; }
.wi-school-info { flex:1;min-width:0; }
.wi-school-nm { font-size:12px;font-weight:700;color:var(--g900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.wi-school-pg { font-size:10.5px;color:var(--g500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.wi-school-prob { font-size:12px;font-weight:800;flex-shrink:0; }
.wi-school-prob.r { color:var(--red); }
.wi-school-prob.a { color:var(--amb); }
.wi-school-prob.g { color:var(--grn); }

.wi-center { background:#fff;border:1px solid var(--g200);border-radius:10px;overflow-y:auto; }
.wi-center-hd { padding:14px 18px;border-bottom:1px solid var(--g200);background:#fff; }
.wi-center-t { font-size:15px;font-weight:800;color:var(--g900);margin-bottom:3px;display:flex;align-items:center;gap:7px; }
.wi-center-meta { font-size:11.5px;color:var(--g600); }
.wi-center-body { padding:16px 18px; }

.wi-prob-card { background:linear-gradient(135deg,var(--pl),#fff);border:1px solid var(--g200);border-radius:10px;padding:14px 16px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center; }
.wi-prob-l { display:flex;flex-direction:column;gap:2px; }
.wi-prob-lbl { font-size:10.5px;color:var(--g500);font-weight:700;text-transform:uppercase;letter-spacing:.3px; }
.wi-prob-val { font-size:36px;font-weight:800;line-height:1; }
.wi-prob-val.r { color:var(--red); }
.wi-prob-val.a { color:var(--amb); }
.wi-prob-val.g { color:var(--grn); }
.wi-prob-delta { font-size:11px;color:var(--g500); }
.wi-prob-delta strong.up { color:var(--grn); }
.wi-prob-delta strong.dn { color:var(--red); }
.wi-prob-r { display:flex;gap:8px; }

.wi-sec { margin-bottom:14px; }
.wi-sec-t { font-size:11px;font-weight:800;color:var(--g500);text-transform:uppercase;letter-spacing:1px;margin-bottom:9px;display:flex;align-items:center;gap:5px; }
.wi-sliders { display:flex;flex-direction:column;gap:11px; }
.sl-grp { background:var(--g50);border-radius:9px;padding:10px 12px; }
.sl-hd { display:flex;justify-content:space-between;align-items:center;margin-bottom:6px; }
.sl-lbl { font-size:12px;font-weight:700;color:var(--g700); }
.sl-val { font-size:12.5px;font-weight:800;color:var(--p);font-variant-numeric:tabular-nums; }
.sl-val sub { font-size:10px;color:var(--g500);font-weight:600;margin-left:2px; }
.sl-track { position:relative;height:6px;background:var(--g200);border-radius:100px;overflow:visible;cursor:pointer; }
.sl-fill { position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--p),#4ade80);border-radius:100px;transition:width .15s; }
.sl-track input[type=range] { position:absolute;top:-6px;left:0;width:100%;height:18px;opacity:0;cursor:pointer;margin:0; }
.sl-mm { display:flex;justify-content:space-between;margin-top:4px;font-size:10px;color:var(--g400); }
.sl-note { font-size:10.5px;color:var(--g500);margin-top:5px;line-height:1.5; }
.sl-note strong { color:var(--g700); }

.wi-checks { background:var(--g50);border-radius:9px;padding:9px 11px;margin-top:8px; }
.wi-checks-i { display:flex;align-items:center;gap:7px;padding:5px 0;font-size:11.5px; }
.wi-check-ic { width:16px;text-align:center;font-size:12px; }
.wi-checks-i.fail { color:var(--red); }
.wi-checks-i.pass { color:var(--grn); }
.wi-checks-i.warn { color:var(--amb); }

.wi-right { background:#fff;border:1px solid var(--g200);border-radius:10px;overflow:hidden;display:flex;flex-direction:column; }
.wi-rl-h { padding:11px 13px;border-bottom:1px solid var(--g200);background:#fff; }
.wi-rl-t { font-size:12.5px;font-weight:800;color:var(--g900); }
.wi-rl-d { font-size:10.5px;color:var(--g500);margin-top:2px; }
.wi-rl-body { padding:14px;display:grid;grid-template-columns:auto 1fr 1fr;gap:14px;align-items:start; }
.wi-radar { display:flex;justify-content:center;align-items:flex-start; }
.wi-prescription { background:linear-gradient(135deg,var(--accl),#fef3ff);border:1px solid #ddd0ff;border-radius:9px;padding:13px 15px;border-left:3px solid var(--acc); }
.wi-prescription-hd { font-size:10.5px;font-weight:800;color:var(--acc);margin-bottom:5px; }
.wi-prescription-body { font-size:11.5px;color:var(--g700);line-height:1.55; }
.wi-prescription-body strong { color:var(--g900); }

/* ── SELECTION PLAN ── */
.plan-summary { display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px; }
.plan-summary-card { background:#fff;border:1px solid var(--g200);border-radius:9px;padding:12px 14px; }
.plan-summary-l { font-size:10.5px;color:var(--g500);font-weight:700;text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px; }
.plan-summary-v { font-size:22px;font-weight:800;color:var(--g900);line-height:1; }
.plan-summary-v sub { font-size:12px;font-weight:600;color:var(--g500);margin-left:3px; }

.plan-tier { margin-bottom:16px; }
.plan-tier-hd { display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:5px;border-bottom:2px solid var(--g200); }
.plan-tier-l { display:flex;align-items:center;gap:8px; }
.plan-tier-t { font-size:13px;font-weight:800;color:var(--g900); }
.plan-tier-cnt { font-size:11px;padding:2px 8px;background:var(--g200);color:var(--g600);border-radius:100px;font-weight:700; }
.plan-tier-stretch .plan-tier-cnt { background:var(--redbg);color:var(--red); }
.plan-tier-match .plan-tier-cnt { background:var(--ambbg);color:var(--amb); }
.plan-tier-safety .plan-tier-cnt { background:var(--grnbg);color:var(--grn); }

.school-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:11px; }
.plan-tiers-grid { background:#fff;border:1px solid var(--g200);border-radius:14px;padding:18px;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start; }
.plan-tiers-grid .plan-tier { margin-bottom:0; }
.plan-tiers-grid .school-grid { grid-template-columns:1fr;gap:10px; }
.school-card { background:#fff;border:1px solid var(--g200);border-radius:10px;padding:13px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:8px; }
.school-card:hover { border-color:var(--p);box-shadow:0 4px 12px rgba(0,0,0,.05);transform:translateY(-2px); }
.school-card-hd { display:grid;grid-template-columns:auto 1fr auto;-moz-column-gap:8px;column-gap:8px;row-gap:4px;align-items:start; }
.school-card-info { display:contents; }
.school-card-flag { grid-column:1;grid-row:1;font-size:18px;flex-shrink:0;line-height:1.3; }
.school-card-nm { grid-column:2;grid-row:1;font-size:13px;font-weight:800;color:var(--g900);line-height:1.3;min-width:0; }
.school-card-prob { grid-column:3;grid-row:1; }
.school-card-pg { grid-column:1 / -1;grid-row:2;font-size:11px;color:var(--g500); }
.school-card-prob { font-size:12px;font-weight:700;line-height:1;display:inline-flex;align-items:baseline;gap:4px; }
.school-card-prob::before { content:"竞争力";font-size:12px;font-weight:700;color:inherit;opacity:.85;letter-spacing:-.005em; }
.school-card-rounds { display:flex;gap:5px;flex-wrap:wrap; }
.school-round-pill { font-size:10px;padding:2px 7px;background:var(--g100);color:var(--g600);border-radius:6px;font-weight:700; }
.school-round-pill.binding { background:var(--accl);color:var(--acc); }
.school-card-progress { display:flex;flex-wrap:wrap;gap:6px 12px;font-size:10.5px;color:var(--g500);white-space:nowrap; }
.school-card-progress span { display:inline-flex;align-items:center;gap:3px; }
.school-card-progress span svg, .school-card-progress span .lic-emoji { display:none !important; }
.school-card-progress strong { color:var(--g700);font-weight:700; }
.school-card-ucas { padding-top:8px;border-top:1px dashed var(--g200);display:flex;justify-content:space-between;align-items:center; }
.school-card-ucas-l { font-size:10.5px;color:var(--g500); }
.school-card-ucas-l strong { color:var(--g700); }
.school-card-ucas-btn { padding:5px 7px;background:var(--g100);color:var(--g500);border-radius:6px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .12s, color .12s; }
.school-card-ucas-btn:hover { background:var(--redbg);color:var(--red); }
.school-card-ucas-btn svg { width:14px;height:14px; }
.card-mark-wrap { display:inline-flex;gap:5px;align-items:center; }
.card-mark-btn { width:24px;height:24px;border:1px solid var(--g200);border-radius:6px;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:all .15s;opacity:.55; }
.card-mark-btn svg { width:13px;height:13px; }
.card-mark-btn.check { color:var(--grn); }
.card-mark-btn.cross { color:var(--red); }
.card-mark-btn:hover { opacity:1;transform:translateY(-1px); }
.card-mark-btn.active { opacity:1; }
.card-mark-btn.check.active { background:var(--grnl);border-color:var(--grn);box-shadow:0 1px 3px rgba(52,199,89,.3); }
.card-mark-btn.cross.active { background:var(--redbg);border-color:var(--red);box-shadow:0 1px 3px rgba(255,59,48,.3); }
.card-mark-btn.dim { opacity:.28; }
#page-plan .card-mark-wrap { display:none; }
/* 选校卡四边边框统一 (原 border-left:0 让左边缺条, 选中/hover 时左边透明; 现保留四边 1px) */

/* ── ACTIVITY ── */
.act-layout { display:grid;grid-template-columns:280px 1fr 320px;gap:14px; }
.act-rec-card { background:#fff;border:1px solid var(--g200);border-radius:10px;padding:14px;margin-bottom:11px; }
.act-rec-hd { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px; }
.act-rec-t { font-size:14px;font-weight:800;color:var(--g900); }
.act-rec-meta { font-size:11px;color:var(--g500);margin-top:5px;display:flex;-moz-column-gap:14px;column-gap:14px;row-gap:3px;flex-wrap:wrap;align-items:center;line-height:1.35; }
.act-rec-meta span { display:inline-flex;align-items:center;gap:5px;white-space:nowrap; }
.act-rec-match { font-size:18px;font-weight:800;color:var(--p);text-align:right; }
.act-rec-match-l { font-size:10.5px;color:var(--g500); }
/* 2026-05-30 适配度 高/中/低 inline 显示, 不换行 — 适配度 + 高 同字号 */
.act-rec-fit { display:inline-flex;align-items:baseline;gap:4px;white-space:nowrap;flex-shrink:0; }
.act-rec-fit-l { font-size:13px;color:var(--g500);font-weight:500; }
.act-rec-fit-v { font-size:13px;font-weight:800;letter-spacing:-0.01em; }
/* 2026-05-30 活动来源 badge — "规划库" / "AI 推荐" 小角标 */
.act-src-tag { display:inline-flex;align-items:center;gap:3px;padding:1px 6px;background:rgba(31,77,63,.09);color:var(--p);border-radius:8px;font-size:10px;font-weight:600;letter-spacing:0;white-space:nowrap;flex-shrink:0; }
/* 2026-05-30 加入活动成功 toast — 底部居中弹入 */
@keyframes act-toast-in {
  from { transform: translate(-50%, 16px); opacity: 0; }
  to   { transform: translate(-50%, 0);    opacity: 1; }
}
.act-rec-body { font-size:12px;color:var(--g600);line-height:1.6;margin-bottom:8px; }
.act-rec-tags { display:flex;flex-wrap:wrap;gap:5px;margin-bottom:9px; }
.act-rec-tag { font-size:10.5px;padding:3px 8px;background:var(--g100);color:var(--g600);border-radius:100px;font-weight:600; }
.act-rec-actions { display:flex;gap:6px; }
.act-saturation { padding:8px 11px;border-radius:7px;font-size:11.5px;display:flex;align-items:center;gap:7px;margin-bottom:9px; }
.act-saturation.high { background:var(--redl);color:#7f1d1d;border:1px solid #fecaca; }
.act-saturation.medium { background:var(--ambl);color:#78350f;border:1px solid #fde68a; }
.act-saturation.low { background:var(--grnl);color:#14532d;border:1px solid #bbf7d0; }
.act-diff-list { background:var(--g50);border-radius:7px;padding:8px 11px;margin-bottom:9px; }
.act-diff-list-t { font-size:10.5px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.3px;margin-bottom:5px; }
.act-diff-list ul { list-style:none;padding:0; }
.act-diff-list li { font-size:11.5px;color:var(--g700);padding:4px 0;display:flex;align-items:flex-start;gap:6px; }
.act-diff-list li::before { content:'→';color:var(--p);font-weight:700;flex-shrink:0; }

/* ── SCAFFOLD CARDS ── */
.scaffold-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:14px; }
.scaffold-card { background:#fff;border:1px solid var(--g200);border-radius:10px;padding:18px;text-align:center; }
.scaffold-ic { font-size:36px;margin-bottom:10px;opacity:.7; }
.scaffold-t { font-size:14px;font-weight:800;color:var(--g900);margin-bottom:5px; }
.scaffold-d { font-size:11.5px;color:var(--g500);line-height:1.6;margin-bottom:12px; }

/* ── LOR / ESSAY WORKBENCH ── */
.wb-layout { display:grid;grid-template-columns:300px 1fr 280px;gap:12px; }
.wb-col { background:#fff;border:1px solid var(--g200);border-radius:10px;overflow:hidden;display:flex;flex-direction:column; }
.wb-col-h { padding:11px 14px;border-bottom:1px solid var(--g200);background:var(--g50); }
.wb-col-t { font-size:12px;font-weight:800;color:var(--g800);display:flex;align-items:center;gap:6px; }
.wb-col-d { font-size:10.5px;color:var(--g500);margin-top:2px; }
.wb-col-b { padding:13px;overflow-y:auto; }
.wb-ai-chat { display:flex;flex-direction:column;gap:10px;padding:14px;margin:12px;border:1px solid var(--g200);border-radius:12px;background:#fff;box-shadow:var(--shadow-sm); }
.wb-ai-chat-hint { font-size:11px;color:var(--g500);line-height:1.5;letter-spacing:-.005em; }
.wb-ai-chat-row { display:flex;align-items:center;gap:8px; }
.wb-ai-chat-inp { width:100%;min-width:0;padding:10px 14px;border:1px solid var(--g300);border-radius:8px;background:var(--g50);font-size:12.5px;color:var(--g800);outline:none;font-family:inherit;transition:border-color .15s,background .15s;box-sizing:border-box; }
.wb-ai-chat-inp:focus { border-color:var(--p);background:#fff; }
.wb-ai-chat-inp::-moz-placeholder { color:var(--g500); }
.wb-ai-chat-inp::placeholder { color:var(--g500); }
.wb-ai-chat-btn { flex-shrink:0;width:34px;height:34px;border-radius:50%;border:0;background:var(--p);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,transform .15s; }
.wb-ai-chat-btn:hover { background:#155a3a; }
.wb-ai-chat-btn:active { transform:scale(.94); }
.wb-sec-t { font-size:10px;font-weight:800;color:var(--g500);text-transform:uppercase;letter-spacing:1px;margin-bottom:7px; }
.wb-school { padding:9px 11px;border:1.5px solid var(--g200);border-radius:8px;margin-bottom:6px;cursor:pointer;font-size:11.5px; }
.wb-school:hover { background:var(--g50); }
.wb-school.active { background:var(--pl);border-color:var(--p); }
.wb-school-nm { font-weight:800;color:var(--g900); }
.wb-school-pg { font-size:10px;color:var(--g500);margin-top:1px; }
.wb-helper { padding:10px 12px;background:linear-gradient(135deg,var(--accl),#fef3ff);border:1px solid #e3d4ff;border-left:3px solid var(--acc);border-radius:8px;margin-bottom:11px; }
.wb-helper-hd { font-size:10.5px;font-weight:800;color:var(--acc);margin-bottom:5px; }
.wb-helper-b { font-size:11px;color:var(--g700);line-height:1.55; }
.wb-bullet { margin-bottom:9px; }
.wb-bullet-l { font-size:10.5px;font-weight:700;color:var(--g600);margin-bottom:4px;display:flex;align-items:center;gap:5px; }
.wb-bullet-l .num { width:15px;height:15px;border-radius:50%;background:var(--p);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:800; }
.wb-bullet textarea { width:100%;padding:7px 9px;font-family:var(--font);font-size:11px;border:1.5px solid var(--g200);border-radius:6px;resize:vertical;min-height:42px;color:var(--g800); }
.wb-bullet textarea:focus { outline:none;border-color:var(--p); }
.wb-gen-btn { width:100%;padding:10px;background:linear-gradient(135deg,var(--p),#178261);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:800;cursor:pointer; }
.wb-gen-btn:hover { background:var(--pd); }
.wb-dna-bar { padding:10px 14px;background:var(--accl);border-bottom:1px solid var(--g200);display:flex;flex-wrap:wrap;gap:6px;align-items:center; }
.wb-dna-lbl { font-size:9.5px;font-weight:800;color:var(--acc);letter-spacing:.5px; }
.wb-dna-chip { padding:3px 9px;background:#fff;border:1px solid #d8c5ff;border-radius:100px;font-size:10px;font-weight:700;color:var(--acc); }
.wb-letter { padding:18px 22px;line-height:1.75;font-size:12.5px;color:var(--g800);overflow-y:auto;flex:1; }
.wb-letter-meta { padding-bottom:11px;border-bottom:1px dashed var(--g200);margin-bottom:14px;font-size:10.5px;color:var(--g500);line-height:1.5; }
.wb-letter p { margin-bottom:11px; }
.wb-ann { padding:1px 3px;border-radius:3px;border-bottom:1.5px dotted var(--grn);background:var(--grnl);cursor:help;position:relative; }
.wb-ann.red { border-bottom-color:var(--red);background:var(--redl);text-decoration:line-through;color:var(--g400); }
.wb-ann.amb { border-bottom-color:var(--amb);background:var(--ambl); }
.wb-ann-tip { visibility:hidden;opacity:0;position:absolute;left:50%;transform:translateX(-50%);bottom:calc(100% + 7px);width:250px;background:var(--g900);color:#fff;padding:8px 11px;border-radius:7px;font-size:10.5px;font-weight:400;line-height:1.5;z-index:10;text-align:left;transition:opacity .15s;text-decoration:none; }
.wb-ann:hover .wb-ann-tip { visibility:visible;opacity:1; }
.wb-ann-tip-hd { font-size:9.5px;font-weight:800;color:#c5f5e0;display:block;margin-bottom:3px; }
.wb-ann.red .wb-ann-tip-hd { color:#ffb8b8; }
.wb-ann.amb .wb-ann-tip-hd { color:#ffdda1; }
.wb-score { padding:13px;background:linear-gradient(135deg,var(--pl),#e8f5ef);border-radius:10px;text-align:center;margin-bottom:12px; }
.wb-score-v { font-size:32px;font-weight:800;color:var(--p);line-height:1; }
.wb-score-l { font-size:10.5px;color:var(--g600);font-weight:700;margin-top:3px; }
.wb-audit-g { margin-bottom:12px; }
.wb-audit-g-t { font-size:10px;font-weight:800;color:var(--g600);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px; }
.wb-audit-i { padding:7px 9px;border-radius:6px;margin-bottom:5px;font-size:10.5px;display:flex;gap:6px;line-height:1.45; }
.wb-audit-i.pass { background:var(--grnl);color:#14532d; }
.wb-audit-i.fail { background:var(--redl);color:#7f1d1d; }
.wb-audit-i.warn { background:var(--ambl);color:#78350f; }
.wb-audit-i.info { background:var(--blul);color:#1e3a8a; }

/* ── TOAST ── */
.toast { position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--g900);color:#fff;padding:12px 22px;border-radius:8px;font-size:13px;font-weight:600;box-shadow:0 6px 20px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:all .3s ease;z-index:1000;display:flex;align-items:center;gap:8px; }
.toast.show { opacity:1;transform:translateX(-50%) translateY(0); }
.toast.success { background:var(--grn); }

/* ── SCROLLBARS ── */
::-webkit-scrollbar { width:6px;height:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--g300);border-radius:100px; }

/* misc */
.muted { color:var(--g500); }
.flex { display:flex; }
.row { display:flex;align-items:center;gap:8px; }
.tag { display:inline-flex;align-items:center;padding:2px 8px;border-radius:5px;font-size:10.5px;font-weight:700; }

/* ════════════════════════════════════════════════════════════════
 * 响应式 — V3 §UI 自适应 (2026-05-25, 用户拍板)
 * 半屏 / 缩放仍要好看, 学习线上版本做得更好.
 *
 * 断点策略:
 *   ≥1280px desktop 完整 (默认, 280px sidebar + content)
 *   1024-1279px 紧凑桌面 (sidebar 240px, gap 减半, 三列 → 两列)
 *   768-1023px 平板 (sidebar 顶部水平栏, content 全宽)
 *   ≤767px 手机 (单列, KPI 2x2)
 *
 * 工具类 (TSX 用):
 *   .rwd-shell-280  →  280px + 1fr 双列, 1024px 以下塌成单列 (替代 inline gridTemplateColumns)
 *   .rwd-2col       →  1fr + 1fr 双列, 768px 以下塌成单列
 *   .rwd-3col       →  1fr × 3, 1024px 以下塌成 2 列, 768 以下塌成 1 列
 *   .rwd-4col       →  1fr × 4, 1024px 以下塌成 2 列, 768 以下塌成 1 列 (KPI 卡 4 件)
 * ════════════════════════════════════════════════════════════════ */

/* 工具类 — 给 TSX 替换 inline gridTemplateColumns 用 */
.rwd-shell-280 {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 14px;
  align-items: start;
}
.rwd-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.rwd-3col { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.rwd-4col { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }

/* ── 1280px 以下: 紧凑桌面 ── */
@media (max-width: 1279px) {
  .fw-grid { grid-template-columns: 240px 1fr; gap: 12px; }
  .rwd-shell-280 { grid-template-columns: 240px 1fr; gap: 12px; }
  .plan-summary { gap: 8px; }
  .plan-tiers-grid { padding: 14px; gap: 12px; }
  .school-grid { grid-template-columns: repeat(2, 1fr); gap: 9px; }
  .rwd-3col { grid-template-columns: repeat(2, 1fr); }

  /* ph 顶部区域: title 缩字, 按钮挤紧 */
  .ph h1 { font-size: 17px; }
  .ph-sub { font-size: 11.5px; }
  .ph-l { gap: 10px; }
}

/* ── 1024px 以下: 平板, sidebar 收顶部 ── */
@media (max-width: 1023px) {
  .fw-grid { grid-template-columns: 1fr; gap: 14px; }
  .rwd-shell-280 { grid-template-columns: 1fr; gap: 14px; }
  .plan-tiers-grid { grid-template-columns: 1fr; gap: 16px; padding: 14px; }
  .plan-summary { grid-template-columns: repeat(2, 1fr); }
  .rwd-4col { grid-template-columns: repeat(2, 1fr); }
  .school-grid { grid-template-columns: repeat(2, 1fr); }

  /* 学生 sidebar 在顶部时压缩为水平条 */
  .fw-student-courses { padding: 12px; }

  /* ph 区域 */
  .ph { padding: 12px 14px; }
  .ph-l { flex-wrap: wrap; }
}

/* ── 768px 以下: 手机, 全单列 ── */
@media (max-width: 767px) {
  .school-grid { grid-template-columns: 1fr; gap: 11px; }
  .plan-summary { grid-template-columns: 1fr; }
  .rwd-2col { grid-template-columns: 1fr; }
  .rwd-3col { grid-template-columns: 1fr; }
  .rwd-4col { grid-template-columns: 1fr; }

  /* 字号收缩 */
  .ph h1 { font-size: 16px; }
  .plan-summary-v { font-size: 19px; }
  .plan-summary-card { padding: 10px 12px; }

  /* 卡片间距收 */
  .school-card { padding: 12px; }

  /* table 横向滚 */
  table { display: block; overflow-x: auto; }
}

/* ── 滚动条美化 — 窄屏新增滚动区, 让滚动条更细 ── */
@media (max-width: 1023px) {
  ::-webkit-scrollbar { width: 6px; height: 6px; }
}

/* ── 全局 app shell (.layout = sidebar nav + main) 自适应 ──
 * 1280px 以下: sidebar 缩到 220px, content padding 收紧
 * 1024px 以下: sidebar 自动收成 64px icon-only (复用 .sb-collapsed 视觉)
 * 768px 以下: main padding 进一步收 */
@media (max-width: 1279px) {
  .layout { grid-template-columns: 220px 1fr; }
  .main { padding: 20px 22px; }
}
@media (max-width: 1023px) {
  .layout,
  .layout:has(.sb:not(.sb-collapsed)) { grid-template-columns: 64px 1fr; }
  .sb { padding: 16px 8px; }
  .sb-head { flex-direction: column; align-items: center; gap: 10px; padding: 6px 0 12px; }
  .sb-grp-hd { display: none; }
  /* 2026-05-30: 折叠按钮 group header 在小屏照样可见, 居中显示按钮 */
  .sb-grp-hd--with-collapse { display: flex; justify-content: center; padding: 6px 0 8px; border-bottom: 0.5px solid rgba(0,0,0,.06); margin-bottom: 6px; }
  .sb-grp-hd--with-collapse > span { display: none; }
  .sb-grp-hd--with-collapse .sb-collapse-btn { margin-left: 0; }
  .sb-i { justify-content: center; padding: 10px 0; gap: 0; }
  .sb-i > span:not(.sb-ic) { display: none; }
  .sb-tag { display: none; }
  .sb-action { justify-content: center; padding: 10px 0; gap: 0; }
  .sb-action-label { display: none; }
  .main { padding: 18px 20px; }
}
@media (max-width: 767px) {
  .main { padding: 14px 14px; }
}
