:root {
  /* Backgrounds */
  --ags-dark:        #1C1208;
  --ags-dark-border: #2E1D0A;
  --ags-dark-deep:   #241608;
  --ags-cream:       #F5F1E8;
  --ags-cream-2:     #EDE8DC;
  --ags-cream-3:     #D4C4A0;

  /* Accent */
  --ags-gold:        #C4A882;
  --ags-gold-mid:    #C4B090;

  /* Text */
  --ags-text-dark:   #1C1208;
  --ags-text-muted:  #8A7560;
  --ags-text-dim:    #6A5A42;

  /* Status */
  --ags-warning:     #7A4A28;
  --ags-success:     #4A6A28;

  /* Typography */
  --ags-font:        'Playfair Display', serif;
  --ags-mono:        'IBM Plex Mono', 'Courier New', monospace;

  /* Borders */
  --ags-border:      0.5px solid var(--ags-cream-3);
  --ags-border-dark: 0.5px solid var(--ags-dark-border);

  /* Radii - ZERO everywhere */
  --ags-radius:      0px;

  /* Spacing scale */
  --ags-space-xs:    4px;
  --ags-space-sm:    8px;
  --ags-space-md:    16px;
  --ags-space-lg:    24px;
  --ags-space-xl:    40px;
}

*, ::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: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, 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: "IBM Plex 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% !important;
}

.container {
  width:        100%;
}

@media (min-width: 640px) {

  .\!container {
    max-width:        640px !important;
  }

  .container {
    max-width:        640px;
  }
}

@media (min-width: 768px) {

  .\!container {
    max-width:        768px !important;
  }

  .container {
    max-width:        768px;
  }
}

@media (min-width: 1024px) {

  .\!container {
    max-width:        1024px !important;
  }

  .container {
    max-width:        1024px;
  }
}

@media (min-width: 1280px) {

  .\!container {
    max-width:        1280px !important;
  }

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

@media (min-width: 1536px) {

  .\!container {
    max-width:        1536px !important;
  }

  .container {
    max-width:        1536px;
  }
}

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

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

.\!visible {
  visibility:        visible !important;
}

.visible {
  visibility:        visible;
}

.invisible {
  visibility:        hidden;
}

.collapse {
  visibility:        collapse;
}

.static {
  position:        static;
}

.fixed {
  position:        fixed;
}

.absolute {
  position:        absolute;
}

.relative {
  position:        relative;
}

.sticky {
  position:        sticky;
}

.inset-0 {
  inset:        0px;
}

.inset-4 {
  inset:        1rem;
}

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

.inset-y-0 {
  top:        0px;
  bottom:        0px;
}

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

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

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

.bottom-0 {
  bottom:        0px;
}

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

.bottom-24 {
  bottom:        6rem;
}

.bottom-3 {
  bottom:        0.75rem;
}

.bottom-4 {
  bottom:        1rem;
}

.bottom-\[calc\(4\.75rem_\+_env\(safe-area-inset-bottom\)\)\] {
  bottom:        calc(4.75rem + env(safe-area-inset-bottom));
}

.left-0 {
  left:        0px;
}

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

.left-3 {
  left:        0.75rem;
}

.left-4 {
  left:        1rem;
}

.right-0 {
  right:        0px;
}

.right-2\.5 {
  right:        0.625rem;
}

.right-24 {
  right:        6rem;
}

.right-3 {
  right:        0.75rem;
}

.right-4 {
  right:        1rem;
}

.right-\[-8rem\] {
  right:        -8rem;
}

.top-0 {
  top:        0px;
}

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

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

.top-3 {
  top:        0.75rem;
}

.top-4 {
  top:        1rem;
}

.top-5 {
  top:        1.25rem;
}

.top-6 {
  top:        1.5rem;
}

.top-\[-2px\] {
  top:        -2px;
}

.top-\[-8rem\] {
  top:        -8rem;
}

.top-\[4\.5rem\] {
  top:        4.5rem;
}

.top-\[4\.6rem\] {
  top:        4.6rem;
}

.top-full {
  top:        100%;
}

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

.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-\[10000\] {
  z-index:        10000;
}

.z-\[1\] {
  z-index:        1;
}

.z-\[2\] {
  z-index:        2;
}

.z-\[350\] {
  z-index:        350;
}

.z-\[400\] {
  z-index:        400;
}

.z-\[49\] {
  z-index:        49;
}

.z-\[500\] {
  z-index:        500;
}

.z-\[60\] {
  z-index:        60;
}

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

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

.-mx-5 {
  margin-left:        -1.25rem;
  margin-right:        -1.25rem;
}

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

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

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

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

.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-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-1 {
  margin-left:        0.25rem;
}

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

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

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

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

.ml-9 {
  margin-left:        2.25rem;
}

.ml-\[22px\] {
  margin-left:        22px;
}

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

.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-12 {
  margin-top:        3rem;
}

.mt-14 {
  margin-top:        3.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-8 {
  margin-top:        2rem;
}

.mt-\[5px\] {
  margin-top:        5px;
}

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

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

.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-20 {
  height:        5rem;
}

.h-24 {
  height:        6rem;
}

.h-28 {
  height:        7rem;
}

.h-3 {
  height:        0.75rem;
}

.h-3\.5 {
  height:        0.875rem;
}

.h-32 {
  height:        8rem;
}

.h-36 {
  height:        9rem;
}

.h-4 {
  height:        1rem;
}

.h-40 {
  height:        10rem;
}

.h-44 {
  height:        11rem;
}

.h-48 {
  height:        12rem;
}

.h-5 {
  height:        1.25rem;
}

.h-52 {
  height:        13rem;
}

.h-56 {
  height:        14rem;
}

.h-6 {
  height:        1.5rem;
}

.h-60 {
  height:        15rem;
}

.h-64 {
  height:        16rem;
}

.h-7 {
  height:        1.75rem;
}

.h-72 {
  height:        18rem;
}

.h-8 {
  height:        2rem;
}

.h-80 {
  height:        20rem;
}

.h-9 {
  height:        2.25rem;
}

.h-96 {
  height:        24rem;
}

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

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

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

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

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

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

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

.h-\[75vh\] {
  height:        75vh;
}

.h-\[92vh\] {
  height:        92vh;
}

.h-\[calc\(100\%\+4px\)\] {
  height:        calc(100% + 4px);
}

.h-auto {
  height:        auto;
}

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

.h-full {
  height:        100%;
}

.h-px {
  height:        1px;
}

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

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

.max-h-\[88vh\] {
  max-height:        88vh;
}

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

.min-h-10 {
  min-height:        2.5rem;
}

.min-h-24 {
  min-height:        6rem;
}

.min-h-6 {
  min-height:        1.5rem;
}

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

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

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

.min-h-\[2\.5rem\] {
  min-height:        2.5rem;
}

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

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

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

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

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

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

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

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

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

.min-h-\[60vh\] {
  min-height:        60vh;
}

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

.min-h-\[75vh\] {
  min-height:        75vh;
}

.min-h-dvh {
  min-height:        100dvh;
}

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

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

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

.w-1 {
  width:        0.25rem;
}

.w-1\.5 {
  width:        0.375rem;
}

.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-3\/4 {
  width:        75%;
}

.w-32 {
  width:        8rem;
}

.w-36 {
  width:        9rem;
}

.w-4 {
  width:        1rem;
}

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

.w-40 {
  width:        10rem;
}

.w-44 {
  width:        11rem;
}

.w-48 {
  width:        12rem;
}

.w-5 {
  width:        1.25rem;
}

.w-52 {
  width:        13rem;
}

.w-56 {
  width:        14rem;
}

.w-6 {
  width:        1.5rem;
}

.w-64 {
  width:        16rem;
}

.w-7 {
  width:        1.75rem;
}

.w-72 {
  width:        18rem;
}

.w-8 {
  width:        2rem;
}

.w-80 {
  width:        20rem;
}

.w-9 {
  width:        2.25rem;
}

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

.w-\[15\%\] {
  width:        15%;
}

.w-\[16\%\] {
  width:        16%;
}

.w-\[22\%\] {
  width:        22%;
}

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

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

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

.w-\[36\%\] {
  width:        36%;
}

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

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

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

.w-\[min\(22rem\2c calc\(100\%-1\.5rem\)\)\] {
  width:        min(22rem, calc(100% - 1.5rem));
}

.w-auto {
  width:        auto;
}

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

.w-full {
  width:        100%;
}

.w-px {
  width:        1px;
}

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

.min-w-12 {
  min-width:        3rem;
}

.min-w-5 {
  min-width:        1.25rem;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.min-w-max {
  min-width:        -moz-max-content;
  min-width:        max-content;
}

.\!max-w-none {
  max-width:        none !important;
}

.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-7xl {
  max-width:        80rem;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.grow {
  flex-grow:        1;
}

.table-fixed {
  table-layout:        fixed;
}

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

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

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

.translate-x-2 {
  --tw-translate-x:        0.5rem;
  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-4 {
  --tw-translate-x:        1rem;
  transform:        translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-6 {
  --tw-translate-x:        1.5rem;
  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-0 {
  --tw-translate-y:        0px;
  transform:        translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-2 {
  --tw-translate-y:        0.5rem;
  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-90 {
  --tw-rotate:        -90deg;
  transform:        translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

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

.scale-\[0\.98\] {
  --tw-scale-x:        0.98;
  --tw-scale-y:        0.98;
  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));
}

@keyframes breathe {

  0%, 100% {
    transform:        scale(1);
    opacity:        0.88;
  }

  50% {
    transform:        scale(1.07);
    opacity:        1;
  }
}

.animate-breathe {
  animation:        breathe 3.6s ease-in-out infinite;
}

@keyframes breathe-subtle {

  0%, 100% {
    transform:        scale(1);
    opacity:        0.88;
  }

  50% {
    transform:        scale(1.06);
    opacity:        1;
  }
}

.animate-breathe-subtle {
  animation:        breathe-subtle 3.6s ease-in-out infinite;
}

@keyframes ping {

  75%, 100% {
    transform:        scale(2);
    opacity:        0;
  }
}

.animate-ping {
  animation:        ping 1s cubic-bezier(0, 0, 0.2, 1) 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-pointer {
  cursor:        pointer;
}

.resize-none {
  resize:        none;
}

.resize {
  resize:        both;
}

.snap-x {
  scroll-snap-type:        x var(--tw-scroll-snap-strictness);
}

.snap-mandatory {
  --tw-scroll-snap-strictness:        mandatory;
}

.snap-start {
  scroll-snap-align:        start;
}

.appearance-none {
  -webkit-appearance:        none;
     -moz-appearance:        none;
          appearance:        none;
}

.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-6 {
  grid-template-columns:        repeat(6, minmax(0, 1fr));
}

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

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

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

.grid-cols-\[1fr_auto_1fr\] {
  grid-template-columns:        1fr auto 1fr;
}

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

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

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

.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 {
  gap:        0px;
}

.gap-0\.5 {
  gap:        0.125rem;
}

.gap-1 {
  gap:        0.25rem;
}

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

.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-x-5 {
  -moz-column-gap:        1.25rem;
       column-gap:        1.25rem;
}

.gap-y-0\.5 {
  row-gap:        0.125rem;
}

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

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

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

.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-10 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse:        0;
  margin-top:        calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom:        calc(2.5rem * 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));
}

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

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

.divide-x > :not([hidden]) ~ :not([hidden]) {
  --tw-divide-x-reverse:        0;
  border-right-width:        calc(1px * var(--tw-divide-x-reverse));
  border-left-width:        calc(1px * calc(1 - var(--tw-divide-x-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(var(--border-rgb) / var(--tw-divide-opacity, 1));
}

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

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

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

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

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

.overflow-hidden {
  overflow:        hidden;
}

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

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

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

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

.truncate {
  overflow:        hidden;
  text-overflow:        ellipsis;
  white-space:        nowrap;
}

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

.whitespace-pre-line {
  white-space:        pre-line;
}

.break-words {
  overflow-wrap:        break-word;
}

.break-all {
  word-break:        break-all;
}

.rounded {
  border-radius:        0.25rem;
}

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

.rounded-\[28px\] {
  border-radius:        28px;
}

.rounded-\[8px\] {
  border-radius:        8px;
}

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

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

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

.rounded-sm {
  border-radius:        0.125rem;
}

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

.rounded-t-2xl {
  border-top-left-radius:        1rem;
  border-top-right-radius:        1rem;
}

.rounded-t-lg {
  border-top-left-radius:        0.5rem;
  border-top-right-radius:        0.5rem;
}

.rounded-t-md {
  border-top-left-radius:        0.375rem;
  border-top-right-radius:        0.375rem;
}

.rounded-bl-sm {
  border-bottom-left-radius:        0.125rem;
}

.border {
  border-width:        1px;
}

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

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

.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-l-\[3px\] {
  border-left-width:        3px;
}

.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-\[\#38bdf8\]\/30 {
  border-color:        rgb(56 189 248 / 0.3);
}

.border-\[\#4285F4\]\/25 {
  border-color:        rgb(66 133 244 / 0.25);
}

.border-\[\#4285F4\]\/30 {
  border-color:        rgb(66 133 244 / 0.3);
}

.border-\[\#5a7a3a\]\/40 {
  border-color:        rgb(90 122 58 / 0.4);
}

.border-\[\#8aad7a\]\/35 {
  border-color:        rgb(138 173 122 / 0.35);
}

.border-\[\#C9A84C\]\/30 {
  border-color:        rgb(201 168 76 / 0.3);
}

.border-\[\#C9A84C\]\/40 {
  border-color:        rgb(201 168 76 / 0.4);
}

.border-\[\#C9A84C\]\/60 {
  border-color:        rgb(201 168 76 / 0.6);
}

.border-\[\#a3c4bc\]\/25 {
  border-color:        rgb(163 196 188 / 0.25);
}

.border-\[\#a3c4bc\]\/30 {
  border-color:        rgb(163 196 188 / 0.3);
}

.border-\[\#a78bfa\]\/25 {
  border-color:        rgb(167 139 250 / 0.25);
}

.border-\[\#a78bfa\]\/30 {
  border-color:        rgb(167 139 250 / 0.3);
}

.border-\[\#a78bfa\]\/40 {
  border-color:        rgb(167 139 250 / 0.4);
}

.border-\[\#c46a37\]\/35 {
  border-color:        rgb(196 106 55 / 0.35);
}

.border-\[\#c46a37\]\/40 {
  border-color:        rgb(196 106 55 / 0.4);
}

.border-\[\#c46a37\]\/45 {
  border-color:        rgb(196 106 55 / 0.45);
}

.border-\[\#c46a37\]\/50 {
  border-color:        rgb(196 106 55 / 0.5);
}

.border-\[\#c46a37\]\/55 {
  border-color:        rgb(196 106 55 / 0.55);
}

.border-\[\#d4af37\]\/10 {
  border-color:        rgb(212 175 55 / 0.1);
}

.border-\[\#d4af37\]\/20 {
  border-color:        rgb(212 175 55 / 0.2);
}

.border-\[\#d4af37\]\/35 {
  border-color:        rgb(212 175 55 / 0.35);
}

.border-\[\#d4af37\]\/60 {
  border-color:        rgb(212 175 55 / 0.6);
}

.border-\[\#d98d7c\]\/35 {
  border-color:        rgb(217 141 124 / 0.35);
}

.border-\[\#d98d7c\]\/60 {
  border-color:        rgb(217 141 124 / 0.6);
}

.border-\[\#e0a071\]\/35 {
  border-color:        rgb(224 160 113 / 0.35);
}

.border-\[\#e0a071\]\/50 {
  border-color:        rgb(224 160 113 / 0.5);
}

.border-\[\#e0a071\]\/60 {
  border-color:        rgb(224 160 113 / 0.6);
}

.border-\[\#f87171\]\/25 {
  border-color:        rgb(248 113 113 / 0.25);
}

.border-\[\#f87171\]\/30 {
  border-color:        rgb(248 113 113 / 0.3);
}

.border-\[\#f97316\]\/30 {
  border-color:        rgb(249 115 22 / 0.3);
}

.border-\[\#f97316\]\/40 {
  border-color:        rgb(249 115 22 / 0.4);
}

.border-\[\#f9a8d4\]\/30 {
  border-color:        rgb(249 168 212 / 0.3);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.14\)\] {
  border-color:        rgba(196,98,45,0.14);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.15\)\] {
  border-color:        rgba(196,98,45,0.15);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.18\)\] {
  border-color:        rgba(196,98,45,0.18);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.2\)\] {
  border-color:        rgba(196,98,45,0.2);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.20\)\] {
  border-color:        rgba(196,98,45,0.20);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.22\)\] {
  border-color:        rgba(196,98,45,0.22);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.28\)\] {
  border-color:        rgba(196,98,45,0.28);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.30\)\] {
  border-color:        rgba(196,98,45,0.30);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.34\)\] {
  border-color:        rgba(196,98,45,0.34);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.35\)\] {
  border-color:        rgba(196,98,45,0.35);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.40\)\] {
  border-color:        rgba(196,98,45,0.40);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.6\)\] {
  border-color:        rgba(196,98,45,0.6);
}

.border-\[rgba\(196\2c 98\2c 45\2c 0\.7\)\] {
  border-color:        rgba(196,98,45,0.7);
}

.border-\[var\(--ags-cream-3\)\] {
  border-color:        var(--ags-cream-3);
}

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

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

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

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

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

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

.border-amber-300 {
  --tw-border-opacity:        1;
  border-color:        rgb(252 211 77 / var(--tw-border-opacity, 1));
}

.border-amber-300\/25 {
  border-color:        rgb(252 211 77 / 0.25);
}

.border-amber-300\/30 {
  border-color:        rgb(252 211 77 / 0.3);
}

.border-amber-300\/35 {
  border-color:        rgb(252 211 77 / 0.35);
}

.border-amber-300\/40 {
  border-color:        rgb(252 211 77 / 0.4);
}

.border-amber-400\/20 {
  border-color:        rgb(251 191 36 / 0.2);
}

.border-amber-400\/25 {
  border-color:        rgb(251 191 36 / 0.25);
}

.border-amber-400\/30 {
  border-color:        rgb(251 191 36 / 0.3);
}

.border-amber-400\/40 {
  border-color:        rgb(251 191 36 / 0.4);
}

.border-amber-400\/50 {
  border-color:        rgb(251 191 36 / 0.5);
}

.border-amber-500\/20 {
  border-color:        rgb(245 158 11 / 0.2);
}

.border-amber-500\/25 {
  border-color:        rgb(245 158 11 / 0.25);
}

.border-amber-500\/30 {
  border-color:        rgb(245 158 11 / 0.3);
}

.border-amber-500\/40 {
  border-color:        rgb(245 158 11 / 0.4);
}

.border-amber-600\/30 {
  border-color:        rgb(217 119 6 / 0.3);
}

.border-bg-card {
  --tw-border-opacity:        1;
  border-color:        rgb(var(--bg-card-rgb) / var(--tw-border-opacity, 1));
}

.border-blue-400\/30 {
  border-color:        rgb(96 165 250 / 0.3);
}

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

.border-border-mid {
  border-color:        var(--border-mid);
}

.border-border\/40 {
  border-color:        rgb(var(--border-rgb) / 0.4);
}

.border-border\/50 {
  border-color:        rgb(var(--border-rgb) / 0.5);
}

.border-border\/60 {
  border-color:        rgb(var(--border-rgb) / 0.6);
}

.border-current {
  border-color:        currentColor;
}

.border-emerald-500\/30 {
  border-color:        rgb(16 185 129 / 0.3);
}

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

.border-gold\/15 {
  border-color:        rgb(var(--gold-rgb) / 0.15);
}

.border-gold\/20 {
  border-color:        rgb(var(--gold-rgb) / 0.2);
}

.border-gold\/25 {
  border-color:        rgb(var(--gold-rgb) / 0.25);
}

.border-gold\/30 {
  border-color:        rgb(var(--gold-rgb) / 0.3);
}

.border-gold\/35 {
  border-color:        rgb(var(--gold-rgb) / 0.35);
}

.border-gold\/40 {
  border-color:        rgb(var(--gold-rgb) / 0.4);
}

.border-gold\/45 {
  border-color:        rgb(var(--gold-rgb) / 0.45);
}

.border-gold\/50 {
  border-color:        rgb(var(--gold-rgb) / 0.5);
}

.border-gold\/55 {
  border-color:        rgb(var(--gold-rgb) / 0.55);
}

.border-gold\/60 {
  border-color:        rgb(var(--gold-rgb) / 0.6);
}

.border-gold\/70 {
  border-color:        rgb(var(--gold-rgb) / 0.7);
}

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

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

.border-green-500\/20 {
  border-color:        rgb(34 197 94 / 0.2);
}

.border-green-500\/25 {
  border-color:        rgb(34 197 94 / 0.25);
}

.border-green-500\/30 {
  border-color:        rgb(34 197 94 / 0.3);
}

.border-ink-faint {
  --tw-border-opacity:        1;
  border-color:        rgb(var(--ink-faint-rgb) / var(--tw-border-opacity, 1));
}

.border-ink-faint\/25 {
  border-color:        rgb(var(--ink-faint-rgb) / 0.25);
}

.border-ink-faint\/30 {
  border-color:        rgb(var(--ink-faint-rgb) / 0.3);
}

.border-orange-500\/30 {
  border-color:        rgb(249 115 22 / 0.3);
}

.border-purple-400\/30 {
  border-color:        rgb(192 132 252 / 0.3);
}

.border-purple-500\/30 {
  border-color:        rgb(168 85 247 / 0.3);
}

.border-red-300\/35 {
  border-color:        rgb(252 165 165 / 0.35);
}

.border-red-400\/15 {
  border-color:        rgb(248 113 113 / 0.15);
}

.border-red-400\/20 {
  border-color:        rgb(248 113 113 / 0.2);
}

.border-red-400\/25 {
  border-color:        rgb(248 113 113 / 0.25);
}

.border-red-400\/30 {
  border-color:        rgb(248 113 113 / 0.3);
}

.border-red-400\/35 {
  border-color:        rgb(248 113 113 / 0.35);
}

.border-red-400\/40 {
  border-color:        rgb(248 113 113 / 0.4);
}

.border-red-500\/30 {
  border-color:        rgb(239 68 68 / 0.3);
}

.border-red-500\/40 {
  border-color:        rgb(239 68 68 / 0.4);
}

.border-red-500\/50 {
  border-color:        rgb(239 68 68 / 0.5);
}

.border-red-900\/50 {
  border-color:        rgb(127 29 29 / 0.5);
}

.border-sage\/20 {
  border-color:        rgb(var(--sage-rgb) / 0.2);
}

.border-sage\/25 {
  border-color:        rgb(var(--sage-rgb) / 0.25);
}

.border-sage\/30 {
  border-color:        rgb(var(--sage-rgb) / 0.3);
}

.border-sage\/35 {
  border-color:        rgb(var(--sage-rgb) / 0.35);
}

.border-sage\/40 {
  border-color:        rgb(var(--sage-rgb) / 0.4);
}

.border-sage\/50 {
  border-color:        rgb(var(--sage-rgb) / 0.5);
}

.border-sky-300\/25 {
  border-color:        rgb(125 211 252 / 0.25);
}

.border-sky-300\/30 {
  border-color:        rgb(125 211 252 / 0.3);
}

.border-sky-400\/20 {
  border-color:        rgb(56 189 248 / 0.2);
}

.border-terra\/35 {
  border-color:        rgb(var(--terra-rgb) / 0.35);
}

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

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

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

.border-white\/30 {
  border-color:        rgb(255 255 255 / 0.3);
}

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

.border-yellow-400\/30 {
  border-color:        rgb(250 204 21 / 0.3);
}

.border-zinc-600\/30 {
  border-color:        rgb(82 82 91 / 0.3);
}

.border-zinc-600\/40 {
  border-color:        rgb(82 82 91 / 0.4);
}

.border-l-amber-400 {
  --tw-border-opacity:        1;
  border-left-color:        rgb(251 191 36 / var(--tw-border-opacity, 1));
}

.border-l-amber-400\/60 {
  border-left-color:        rgb(251 191 36 / 0.6);
}

.border-l-green-400 {
  --tw-border-opacity:        1;
  border-left-color:        rgb(74 222 128 / var(--tw-border-opacity, 1));
}

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

.border-l-red-400\/60 {
  border-left-color:        rgb(248 113 113 / 0.6);
}

.border-l-sky-400 {
  --tw-border-opacity:        1;
  border-left-color:        rgb(56 189 248 / var(--tw-border-opacity, 1));
}

.bg-\[\#0d0f0e\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(13 15 14 / var(--tw-bg-opacity, 1));
}

.bg-\[\#0d1610\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(13 22 16 / var(--tw-bg-opacity, 1));
}

.bg-\[\#0d1f0d\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(13 31 13 / var(--tw-bg-opacity, 1));
}

.bg-\[\#111613\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(17 22 19 / var(--tw-bg-opacity, 1));
}

.bg-\[\#120905\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(18 9 5 / var(--tw-bg-opacity, 1));
}

.bg-\[\#121712\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(18 23 18 / var(--tw-bg-opacity, 1));
}

.bg-\[\#180d08\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(24 13 8 / var(--tw-bg-opacity, 1));
}

.bg-\[\#38bdf8\]\/10 {
  background-color:        rgb(56 189 248 / 0.1);
}

.bg-\[\#4285F4\]\/10 {
  background-color:        rgb(66 133 244 / 0.1);
}

.bg-\[\#52251f\]\/45 {
  background-color:        rgb(82 37 31 / 0.45);
}

.bg-\[\#7c9e8f\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(124 158 143 / var(--tw-bg-opacity, 1));
}

.bg-\[\#C9A84C\]\/10 {
  background-color:        rgb(201 168 76 / 0.1);
}

.bg-\[\#C9A84C\]\/5 {
  background-color:        rgb(201 168 76 / 0.05);
}

.bg-\[\#a3c4bc\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(163 196 188 / var(--tw-bg-opacity, 1));
}

.bg-\[\#a3c4bc\]\/10 {
  background-color:        rgb(163 196 188 / 0.1);
}

.bg-\[\#a3c4bc\]\/15 {
  background-color:        rgb(163 196 188 / 0.15);
}

.bg-\[\#a3c4bc\]\/70 {
  background-color:        rgb(163 196 188 / 0.7);
}

.bg-\[\#a78bfa\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(167 139 250 / var(--tw-bg-opacity, 1));
}

.bg-\[\#a78bfa\]\/10 {
  background-color:        rgb(167 139 250 / 0.1);
}

.bg-\[\#a78bfa\]\/15 {
  background-color:        rgb(167 139 250 / 0.15);
}

.bg-\[\#a78bfa\]\/60 {
  background-color:        rgb(167 139 250 / 0.6);
}

.bg-\[\#a78bfa\]\/70 {
  background-color:        rgb(167 139 250 / 0.7);
}

.bg-\[\#c084fc\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(192 132 252 / var(--tw-bg-opacity, 1));
}

.bg-\[\#c46a37\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(196 106 55 / var(--tw-bg-opacity, 1));
}

.bg-\[\#c46a37\]\/10 {
  background-color:        rgb(196 106 55 / 0.1);
}

.bg-\[\#d4af37\]\/10 {
  background-color:        rgb(212 175 55 / 0.1);
}

.bg-\[\#f87171\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(248 113 113 / var(--tw-bg-opacity, 1));
}

.bg-\[\#f87171\]\/10 {
  background-color:        rgb(248 113 113 / 0.1);
}

.bg-\[\#f87171\]\/50 {
  background-color:        rgb(248 113 113 / 0.5);
}

.bg-\[\#f87171\]\/60 {
  background-color:        rgb(248 113 113 / 0.6);
}

.bg-\[\#f97316\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(249 115 22 / var(--tw-bg-opacity, 1));
}

.bg-\[\#f97316\]\/10 {
  background-color:        rgb(249 115 22 / 0.1);
}

.bg-\[\#f9a8d4\] {
  --tw-bg-opacity:        1;
  background-color:        rgb(249 168 212 / var(--tw-bg-opacity, 1));
}

.bg-\[\#f9a8d4\]\/10 {
  background-color:        rgb(249 168 212 / 0.1);
}

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

.bg-\[rgba\(11\2c 15\2c 13\2c 0\.88\)\] {
  background-color:        rgba(11,15,13,0.88);
}

.bg-\[rgba\(17\2c 12\2c 8\2c 0\.45\)\] {
  background-color:        rgba(17,12,8,0.45);
}

.bg-\[rgba\(17\2c 12\2c 8\2c 0\.5\)\] {
  background-color:        rgba(17,12,8,0.5);
}

.bg-\[rgba\(17\2c 12\2c 8\2c 0\.58\)\] {
  background-color:        rgba(17,12,8,0.58);
}

.bg-\[rgba\(17\2c 12\2c 8\2c 0\.7\)\] {
  background-color:        rgba(17,12,8,0.7);
}

.bg-\[rgba\(17\2c 22\2c 19\2c 0\.88\)\] {
  background-color:        rgba(17,22,19,0.88);
}

.bg-\[rgba\(196\2c 106\2c 55\2c 0\.12\)\] {
  background-color:        rgba(196,106,55,0.12);
}

.bg-\[rgba\(196\2c 106\2c 55\2c 0\.14\)\] {
  background-color:        rgba(196,106,55,0.14);
}

.bg-\[rgba\(196\2c 98\2c 45\2c 0\.05\)\] {
  background-color:        rgba(196,98,45,0.05);
}

.bg-\[rgba\(196\2c 98\2c 45\2c 0\.07\)\] {
  background-color:        rgba(196,98,45,0.07);
}

.bg-\[rgba\(196\2c 98\2c 45\2c 0\.08\)\] {
  background-color:        rgba(196,98,45,0.08);
}

.bg-\[rgba\(196\2c 98\2c 45\2c 0\.10\)\] {
  background-color:        rgba(196,98,45,0.10);
}

.bg-\[rgba\(196\2c 98\2c 45\2c 0\.12\)\] {
  background-color:        rgba(196,98,45,0.12);
}

.bg-\[rgba\(196\2c 98\2c 45\2c 0\.2\)\] {
  background-color:        rgba(196,98,45,0.2);
}

.bg-\[rgba\(196\2c 98\2c 45\2c 0\.25\)\] {
  background-color:        rgba(196,98,45,0.25);
}

.bg-\[rgba\(200\2c 169\2c 110\2c 0\.12\)\] {
  background-color:        rgba(200,169,110,0.12);
}

.bg-\[rgba\(224\2c 160\2c 113\2c 0\.06\)\] {
  background-color:        rgba(224,160,113,0.06);
}

.bg-\[rgba\(224\2c 160\2c 113\2c 0\.07\)\] {
  background-color:        rgba(224,160,113,0.07);
}

.bg-\[rgba\(255\2c 255\2c 255\2c 0\.03\)\] {
  background-color:        rgba(255,255,255,0.03);
}

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

.bg-\[var\(--ags-cream-2\)\] {
  background-color:        var(--ags-cream-2);
}

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

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

.bg-\[var\(--ags-text-dark\)\] {
  background-color:        var(--ags-text-dark);
}

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

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

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

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

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

.bg-amber-300 {
  --tw-bg-opacity:        1;
  background-color:        rgb(252 211 77 / var(--tw-bg-opacity, 1));
}

.bg-amber-300\/10 {
  background-color:        rgb(252 211 77 / 0.1);
}

.bg-amber-300\/15 {
  background-color:        rgb(252 211 77 / 0.15);
}

.bg-amber-300\/50 {
  background-color:        rgb(252 211 77 / 0.5);
}

.bg-amber-300\/60 {
  background-color:        rgb(252 211 77 / 0.6);
}

.bg-amber-300\/70 {
  background-color:        rgb(252 211 77 / 0.7);
}

.bg-amber-400 {
  --tw-bg-opacity:        1;
  background-color:        rgb(251 191 36 / var(--tw-bg-opacity, 1));
}

.bg-amber-400\/10 {
  background-color:        rgb(251 191 36 / 0.1);
}

.bg-amber-400\/15 {
  background-color:        rgb(251 191 36 / 0.15);
}

.bg-amber-400\/5 {
  background-color:        rgb(251 191 36 / 0.05);
}

.bg-amber-400\/50 {
  background-color:        rgb(251 191 36 / 0.5);
}

.bg-amber-400\/60 {
  background-color:        rgb(251 191 36 / 0.6);
}

.bg-amber-400\/\[0\.03\] {
  background-color:        rgb(251 191 36 / 0.03);
}

.bg-amber-400\/\[0\.04\] {
  background-color:        rgb(251 191 36 / 0.04);
}

.bg-amber-400\/\[0\.06\] {
  background-color:        rgb(251 191 36 / 0.06);
}

.bg-amber-50 {
  --tw-bg-opacity:        1;
  background-color:        rgb(255 251 235 / var(--tw-bg-opacity, 1));
}

.bg-amber-500\/10 {
  background-color:        rgb(245 158 11 / 0.1);
}

.bg-amber-600\/20 {
  background-color:        rgb(217 119 6 / 0.2);
}

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

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

.bg-bg-base\/50 {
  background-color:        rgb(var(--bg-base-rgb) / 0.5);
}

.bg-bg-base\/90 {
  background-color:        rgb(var(--bg-base-rgb) / 0.9);
}

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

.bg-bg-card-dark {
  background-color:        var(--bg-card-dark);
}

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

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

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

.bg-bg-card\/85 {
  background-color:        rgb(var(--bg-card-rgb) / 0.85);
}

.bg-bg-card\/90 {
  background-color:        rgb(var(--bg-card-rgb) / 0.9);
}

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

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

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

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

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

.bg-blue-400\/10 {
  background-color:        rgb(96 165 250 / 0.1);
}

.bg-blue-400\/5 {
  background-color:        rgb(96 165 250 / 0.05);
}

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

.bg-border-mid {
  background-color:        var(--border-mid);
}

.bg-border\/20 {
  background-color:        rgb(var(--border-rgb) / 0.2);
}

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

.bg-border\/50 {
  background-color:        rgb(var(--border-rgb) / 0.5);
}

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

.bg-emerald-400 {
  --tw-bg-opacity:        1;
  background-color:        rgb(52 211 153 / var(--tw-bg-opacity, 1));
}

.bg-emerald-500\/10 {
  background-color:        rgb(16 185 129 / 0.1);
}

.bg-emerald-500\/20 {
  background-color:        rgb(16 185 129 / 0.2);
}

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

.bg-gold-trace {
  background-color:        var(--gold-trace);
}

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

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

.bg-gold\/20 {
  background-color:        rgb(var(--gold-rgb) / 0.2);
}

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

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

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

.bg-gold\/50 {
  background-color:        rgb(var(--gold-rgb) / 0.5);
}

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

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

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

.bg-gold\/\[0\.035\] {
  background-color:        rgb(var(--gold-rgb) / 0.035);
}

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

.bg-gold\/\[0\.06\] {
  background-color:        rgb(var(--gold-rgb) / 0.06);
}

.bg-gold\/\[0\.09\] {
  background-color:        rgb(var(--gold-rgb) / 0.09);
}

.bg-gold\/\[0\.10\] {
  background-color:        rgb(var(--gold-rgb) / 0.10);
}

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

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

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

.bg-gray-900 {
  --tw-bg-opacity:        1;
  background-color:        rgb(17 24 39 / var(--tw-bg-opacity, 1));
}

.bg-green-400 {
  --tw-bg-opacity:        1;
  background-color:        rgb(74 222 128 / var(--tw-bg-opacity, 1));
}

.bg-green-400\/5 {
  background-color:        rgb(74 222 128 / 0.05);
}

.bg-green-400\/\[0\.04\] {
  background-color:        rgb(74 222 128 / 0.04);
}

.bg-green-500\/10 {
  background-color:        rgb(34 197 94 / 0.1);
}

.bg-green-500\/20 {
  background-color:        rgb(34 197 94 / 0.2);
}

.bg-green-500\/5 {
  background-color:        rgb(34 197 94 / 0.05);
}

.bg-ink-faint {
  --tw-bg-opacity:        1;
  background-color:        rgb(var(--ink-faint-rgb) / var(--tw-bg-opacity, 1));
}

.bg-ink-faint\/20 {
  background-color:        rgb(var(--ink-faint-rgb) / 0.2);
}

.bg-ink-muted {
  background-color:        var(--ink-muted);
}

.bg-orange-400 {
  --tw-bg-opacity:        1;
  background-color:        rgb(251 146 60 / var(--tw-bg-opacity, 1));
}

.bg-orange-500\/10 {
  background-color:        rgb(249 115 22 / 0.1);
}

.bg-purple-400 {
  --tw-bg-opacity:        1;
  background-color:        rgb(192 132 252 / var(--tw-bg-opacity, 1));
}

.bg-purple-400\/10 {
  background-color:        rgb(192 132 252 / 0.1);
}

.bg-purple-400\/5 {
  background-color:        rgb(192 132 252 / 0.05);
}

.bg-purple-500\/10 {
  background-color:        rgb(168 85 247 / 0.1);
}

.bg-purple-500\/20 {
  background-color:        rgb(168 85 247 / 0.2);
}

.bg-red-300\/10 {
  background-color:        rgb(252 165 165 / 0.1);
}

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

.bg-red-400\/10 {
  background-color:        rgb(248 113 113 / 0.1);
}

.bg-red-400\/15 {
  background-color:        rgb(248 113 113 / 0.15);
}

.bg-red-400\/20 {
  background-color:        rgb(248 113 113 / 0.2);
}

.bg-red-400\/5 {
  background-color:        rgb(248 113 113 / 0.05);
}

.bg-red-400\/\[0\.03\] {
  background-color:        rgb(248 113 113 / 0.03);
}

.bg-red-400\/\[0\.04\] {
  background-color:        rgb(248 113 113 / 0.04);
}

.bg-red-400\/\[0\.06\] {
  background-color:        rgb(248 113 113 / 0.06);
}

.bg-red-500\/10 {
  background-color:        rgb(239 68 68 / 0.1);
}

.bg-red-500\/15 {
  background-color:        rgb(239 68 68 / 0.15);
}

.bg-red-950\/40 {
  background-color:        rgb(69 10 10 / 0.4);
}

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

.bg-sage-dim {
  background-color:        var(--sage-dim);
}

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

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

.bg-sage\/20 {
  background-color:        rgb(var(--sage-rgb) / 0.2);
}

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

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

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

.bg-sage\/\[0\.06\] {
  background-color:        rgb(var(--sage-rgb) / 0.06);
}

.bg-sky-300\/10 {
  background-color:        rgb(125 211 252 / 0.1);
}

.bg-sky-400 {
  --tw-bg-opacity:        1;
  background-color:        rgb(56 189 248 / var(--tw-bg-opacity, 1));
}

.bg-sky-400\/10 {
  background-color:        rgb(56 189 248 / 0.1);
}

.bg-sky-400\/5 {
  background-color:        rgb(56 189 248 / 0.05);
}

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

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

.bg-yellow-400\/5 {
  background-color:        rgb(250 204 21 / 0.05);
}

.bg-zinc-800\/30 {
  background-color:        rgb(39 39 42 / 0.3);
}

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

.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-bg-card {
  --tw-gradient-from:        var(--bg-card) var(--tw-gradient-from-position);
  --tw-gradient-to:        rgb(var(--bg-card-rgb) / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops:        var(--tw-gradient-from), var(--tw-gradient-to);
}

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

.to-bg-card-dark {
  --tw-gradient-to:        var(--bg-card-dark) var(--tw-gradient-to-position);
}

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

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

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

.p-0 {
  padding:        0px;
}

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

.p-1 {
  padding:        0.25rem;
}

.p-10 {
  padding:        2.5rem;
}

.p-2 {
  padding:        0.5rem;
}

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

.p-3 {
  padding:        0.75rem;
}

.p-4 {
  padding:        1rem;
}

.p-5 {
  padding:        1.25rem;
}

.p-6 {
  padding:        1.5rem;
}

.p-8 {
  padding:        2rem;
}

.p-\[3px\] {
  padding:        3px;
}

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

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

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

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

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

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

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

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

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

.py-20 {
  padding-top:        5rem;
  padding-bottom:        5rem;
}

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

.py-3\.5 {
  padding-top:        0.875rem;
  padding-bottom:        0.875rem;
}

.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-8 {
  padding-top:        2rem;
  padding-bottom:        2rem;
}

.pb-0 {
  padding-bottom:        0px;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.pl-\[4\.5rem\] {
  padding-left:        4.5rem;
}

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

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

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

.pt-14 {
  padding-top:        3.5rem;
}

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

.pt-28 {
  padding-top:        7rem;
}

.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-8 {
  padding-top:        2rem;
}

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

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

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

.align-middle {
  vertical-align:        middle;
}

.font-display {
  font-family:        "Playfair Display", Georgia, serif;
}

.font-mono {
  font-family:        "IBM Plex Mono", "Courier New", monospace;
}

.font-sans {
  font-family:        "IBM Plex Sans", -apple-system, BlinkMacSystemFont, sans-serif;
}

.font-serif {
  font-family:        "Playfair Display", Georgia, 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-\[0\.64rem\] {
  font-size:        0.64rem;
}

.text-\[1\.65rem\] {
  font-size:        1.65rem;
}

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

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

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

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

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

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

.text-\[2\.5rem\] {
  font-size:        2.5rem;
}

.text-\[2\.6rem\] {
  font-size:        2.6rem;
}

.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-black {
  font-weight:        900;
}

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

.font-light {
  font-weight:        300;
}

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

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

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

.uppercase {
  text-transform:        uppercase;
}

.capitalize {
  text-transform:        capitalize;
}

.normal-case {
  text-transform:        none;
}

.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-4 {
  line-height:        1rem;
}

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

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

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

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

.leading-\[0\.95\] {
  line-height:        0.95;
}

.leading-\[0\.97\] {
  line-height:        0.97;
}

.leading-\[1\.02\] {
  line-height:        1.02;
}

.leading-\[1\.18\] {
  line-height:        1.18;
}

.leading-\[1\.55\] {
  line-height:        1.55;
}

.leading-\[1\.6\] {
  line-height:        1.6;
}

.leading-\[1\.7\] {
  line-height:        1.7;
}

.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\.08em\] {
  letter-spacing:        0.08em;
}

.tracking-\[0\.09em\] {
  letter-spacing:        0.09em;
}

.tracking-\[0\.10em\] {
  letter-spacing:        0.10em;
}

.tracking-\[0\.11em\] {
  letter-spacing:        0.11em;
}

.tracking-\[0\.12em\] {
  letter-spacing:        0.12em;
}

.tracking-\[0\.14em\] {
  letter-spacing:        0.14em;
}

.tracking-\[0\.15em\] {
  letter-spacing:        0.15em;
}

.tracking-\[0\.16em\] {
  letter-spacing:        0.16em;
}

.tracking-\[0\.18em\] {
  letter-spacing:        0.18em;
}

.tracking-\[0\.1em\] {
  letter-spacing:        0.1em;
}

.tracking-\[0\.22em\] {
  letter-spacing:        0.22em;
}

.tracking-\[0\.24em\] {
  letter-spacing:        0.24em;
}

.tracking-\[0\.25em\] {
  letter-spacing:        0.25em;
}

.tracking-\[0\.26em\] {
  letter-spacing:        0.26em;
}

.tracking-\[0\.28em\] {
  letter-spacing:        0.28em;
}

.tracking-\[0\.2em\] {
  letter-spacing:        0.2em;
}

.tracking-\[0\.35em\] {
  letter-spacing:        0.35em;
}

.tracking-\[0\.38em\] {
  letter-spacing:        0.38em;
}

.tracking-\[0\.3em\] {
  letter-spacing:        0.3em;
}

.tracking-\[0\.45em\] {
  letter-spacing:        0.45em;
}

.tracking-normal {
  letter-spacing:        0em;
}

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

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

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

.text-\[\#0d1f0d\] {
  --tw-text-opacity:        1;
  color:        rgb(13 31 13 / var(--tw-text-opacity, 1));
}

.text-\[\#160b06\] {
  --tw-text-opacity:        1;
  color:        rgb(22 11 6 / var(--tw-text-opacity, 1));
}

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

.text-\[\#38bdf8\] {
  --tw-text-opacity:        1;
  color:        rgb(56 189 248 / var(--tw-text-opacity, 1));
}

.text-\[\#3d4a39\] {
  --tw-text-opacity:        1;
  color:        rgb(61 74 57 / var(--tw-text-opacity, 1));
}

.text-\[\#6b7c67\] {
  --tw-text-opacity:        1;
  color:        rgb(107 124 103 / var(--tw-text-opacity, 1));
}

.text-\[\#7ab4f5\] {
  --tw-text-opacity:        1;
  color:        rgb(122 180 245 / var(--tw-text-opacity, 1));
}

.text-\[\#8aad7a\]\/60 {
  color:        rgb(138 173 122 / 0.6);
}

.text-\[\#C9A84C\] {
  --tw-text-opacity:        1;
  color:        rgb(201 168 76 / var(--tw-text-opacity, 1));
}

.text-\[\#C9A84C\]\/70 {
  color:        rgb(201 168 76 / 0.7);
}

.text-\[\#a3c4bc\] {
  --tw-text-opacity:        1;
  color:        rgb(163 196 188 / var(--tw-text-opacity, 1));
}

.text-\[\#a78bfa\] {
  --tw-text-opacity:        1;
  color:        rgb(167 139 250 / var(--tw-text-opacity, 1));
}

.text-\[\#c4622d\] {
  --tw-text-opacity:        1;
  color:        rgb(196 98 45 / var(--tw-text-opacity, 1));
}

.text-\[\#c46a37\] {
  --tw-text-opacity:        1;
  color:        rgb(196 106 55 / var(--tw-text-opacity, 1));
}

.text-\[\#c8cfc4\] {
  --tw-text-opacity:        1;
  color:        rgb(200 207 196 / var(--tw-text-opacity, 1));
}

.text-\[\#d4af37\] {
  --tw-text-opacity:        1;
  color:        rgb(212 175 55 / var(--tw-text-opacity, 1));
}

.text-\[\#d8ead2\] {
  --tw-text-opacity:        1;
  color:        rgb(216 234 210 / var(--tw-text-opacity, 1));
}

.text-\[\#e0a071\] {
  --tw-text-opacity:        1;
  color:        rgb(224 160 113 / var(--tw-text-opacity, 1));
}

.text-\[\#f3c5bb\] {
  --tw-text-opacity:        1;
  color:        rgb(243 197 187 / var(--tw-text-opacity, 1));
}

.text-\[\#f3daa0\] {
  --tw-text-opacity:        1;
  color:        rgb(243 218 160 / var(--tw-text-opacity, 1));
}

.text-\[\#f87171\] {
  --tw-text-opacity:        1;
  color:        rgb(248 113 113 / var(--tw-text-opacity, 1));
}

.text-\[\#f97316\] {
  --tw-text-opacity:        1;
  color:        rgb(249 115 22 / var(--tw-text-opacity, 1));
}

.text-\[\#f9a8d4\] {
  --tw-text-opacity:        1;
  color:        rgb(249 168 212 / var(--tw-text-opacity, 1));
}

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

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

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

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

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

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

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

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

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

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

.text-amber-100 {
  --tw-text-opacity:        1;
  color:        rgb(254 243 199 / var(--tw-text-opacity, 1));
}

.text-amber-200 {
  --tw-text-opacity:        1;
  color:        rgb(253 230 138 / var(--tw-text-opacity, 1));
}

.text-amber-200\/50 {
  color:        rgb(253 230 138 / 0.5);
}

.text-amber-200\/80 {
  color:        rgb(253 230 138 / 0.8);
}

.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-400 {
  --tw-text-opacity:        1;
  color:        rgb(251 191 36 / var(--tw-text-opacity, 1));
}

.text-amber-400\/60 {
  color:        rgb(251 191 36 / 0.6);
}

.text-amber-400\/80 {
  color:        rgb(251 191 36 / 0.8);
}

.text-amber-700 {
  --tw-text-opacity:        1;
  color:        rgb(180 83 9 / var(--tw-text-opacity, 1));
}

.text-bg-base {
  --tw-text-opacity:        1;
  color:        rgb(var(--bg-base-rgb) / var(--tw-text-opacity, 1));
}

.text-blue-300 {
  --tw-text-opacity:        1;
  color:        rgb(147 197 253 / var(--tw-text-opacity, 1));
}

.text-border-mid {
  color:        var(--border-mid);
}

.text-emerald-300 {
  --tw-text-opacity:        1;
  color:        rgb(110 231 183 / var(--tw-text-opacity, 1));
}

.text-emerald-400 {
  --tw-text-opacity:        1;
  color:        rgb(52 211 153 / var(--tw-text-opacity, 1));
}

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

.text-gold-pale {
  --tw-text-opacity:        1;
  color:        rgb(var(--gold-pale-rgb) / var(--tw-text-opacity, 1));
}

.text-gold\/60 {
  color:        rgb(var(--gold-rgb) / 0.6);
}

.text-gold\/70 {
  color:        rgb(var(--gold-rgb) / 0.7);
}

.text-gold\/80 {
  color:        rgb(var(--gold-rgb) / 0.8);
}

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

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

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

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

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

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

.text-gray-900 {
  --tw-text-opacity:        1;
  color:        rgb(17 24 39 / var(--tw-text-opacity, 1));
}

.text-green-300 {
  --tw-text-opacity:        1;
  color:        rgb(134 239 172 / var(--tw-text-opacity, 1));
}

.text-green-400 {
  --tw-text-opacity:        1;
  color:        rgb(74 222 128 / var(--tw-text-opacity, 1));
}

.text-ink {
  color:        var(--ink);
}

.text-ink-faint {
  --tw-text-opacity:        1;
  color:        rgb(var(--ink-faint-rgb) / var(--tw-text-opacity, 1));
}

.text-ink-muted {
  color:        var(--ink-muted);
}

.text-ink-soft {
  color:        var(--ink-soft);
}

.text-orange-300 {
  --tw-text-opacity:        1;
  color:        rgb(253 186 116 / var(--tw-text-opacity, 1));
}

.text-purple-300 {
  --tw-text-opacity:        1;
  color:        rgb(216 180 254 / var(--tw-text-opacity, 1));
}

.text-purple-400 {
  --tw-text-opacity:        1;
  color:        rgb(192 132 252 / var(--tw-text-opacity, 1));
}

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

.text-red-200\/80 {
  color:        rgb(254 202 202 / 0.8);
}

.text-red-300 {
  --tw-text-opacity:        1;
  color:        rgb(252 165 165 / var(--tw-text-opacity, 1));
}

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

.text-red-400\/60 {
  color:        rgb(248 113 113 / 0.6);
}

.text-red-400\/70 {
  color:        rgb(248 113 113 / 0.7);
}

.text-red-400\/80 {
  color:        rgb(248 113 113 / 0.8);
}

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

.text-sage-pale {
  --tw-text-opacity:        1;
  color:        rgb(var(--sage-pale-rgb) / var(--tw-text-opacity, 1));
}

.text-sage\/60 {
  color:        rgb(var(--sage-rgb) / 0.6);
}

.text-sage\/70 {
  color:        rgb(var(--sage-rgb) / 0.7);
}

.text-sky-200 {
  --tw-text-opacity:        1;
  color:        rgb(186 230 253 / var(--tw-text-opacity, 1));
}

.text-sky-300 {
  --tw-text-opacity:        1;
  color:        rgb(125 211 252 / var(--tw-text-opacity, 1));
}

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

.text-terra\/80 {
  color:        rgb(var(--terra-rgb) / 0.8);
}

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

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

.text-zinc-500 {
  --tw-text-opacity:        1;
  color:        rgb(113 113 122 / var(--tw-text-opacity, 1));
}

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

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

.decoration-ink-faint\/40 {
  text-decoration-color:        rgb(var(--ink-faint-rgb) / 0.4);
}

.decoration-dotted {
  text-decoration-style:        dotted;
}

.underline-offset-2 {
  text-underline-offset:        2px;
}

.underline-offset-4 {
  text-underline-offset:        4px;
}

.placeholder-ink-faint::-moz-placeholder {
  --tw-placeholder-opacity:        1;
  color:        rgb(var(--ink-faint-rgb) / var(--tw-placeholder-opacity, 1));
}

.placeholder-ink-faint::placeholder {
  --tw-placeholder-opacity:        1;
  color:        rgb(var(--ink-faint-rgb) / var(--tw-placeholder-opacity, 1));
}

.accent-\[\#c46a37\] {
  accent-color:        #c46a37;
}

.accent-\[\#c9960c\] {
  accent-color:        #c9960c;
}

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

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

.accent-gold {
  accent-color:        var(--gold);
}

.opacity-0 {
  opacity:        0;
}

.opacity-100 {
  opacity:        1;
}

.opacity-30 {
  opacity:        0.3;
}

.opacity-40 {
  opacity:        0.4;
}

.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\.03\] {
  opacity:        0.03;
}

.opacity-\[0\.045\] {
  opacity:        0.045;
}

.opacity-\[0\.04\] {
  opacity:        0.04;
}

.opacity-\[0\.06\] {
  opacity:        0.06;
}

.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_1px_rgba\(201\2c 150\2c 12\2c 0\.35\)\] {
  --tw-shadow:        0 0 0 1px rgba(201,150,12,0.35);
  --tw-shadow-colored:        0 0 0 1px var(--tw-shadow-color);
  box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-\[0_0_12px_rgba\(122\2c 171\2c 138\2c 0\.55\)\] {
  --tw-shadow:        0 0 12px rgba(122,171,138,0.55);
  --tw-shadow-colored:        0 0 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_24px_-4px\] {
  --tw-shadow:        0 0 24px -4px;
  --tw-shadow-colored:        0 0 24px -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_24px_80px_rgba\(0\2c 0\2c 0\2c 0\.45\)\] {
  --tw-shadow:        0 24px 80px rgba(0,0,0,0.45);
  --tw-shadow-colored:        0 24px 80px 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_24px_80px_rgba\(0\2c 0\2c 0\2c 0\.7\)\] {
  --tw-shadow:        0 24px 80px rgba(0,0,0,0.7);
  --tw-shadow-colored:        0 24px 80px 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_24px_80px_rgba\(0\2c 0\2c 0\2c 0\.85\)\] {
  --tw-shadow:        0 24px 80px rgba(0,0,0,0.85);
  --tw-shadow-colored:        0 24px 80px 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_8px_40px_rgba\(212\2c 175\2c 55\2c 0\.12\)\] {
  --tw-shadow:        0 8px 40px rgba(212,175,55,0.12);
  --tw-shadow-colored:        0 8px 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-lg {
  --tw-shadow:        0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored:        0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

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

.shadow-black\/60 {
  --tw-shadow-color:        rgb(0 0 0 / 0.6);
  --tw-shadow:        var(--tw-shadow-colored);
}

.shadow-gold\/10 {
  --tw-shadow-color:        rgb(var(--gold-rgb) / 0.1);
  --tw-shadow:        var(--tw-shadow-colored);
}

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

.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-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-current {
  --tw-ring-color:        currentColor;
}

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

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

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

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

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

.drop-shadow-\[0_0_16px_rgba\(122\2c 171\2c 138\2c 0\.28\)\] {
  --tw-drop-shadow:        drop-shadow(0 0 16px rgba(122,171,138,0.28));
  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-\[2px\] {
  --tw-backdrop-blur:        blur(2px);
  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);
}

.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-\[padding-left\] {
  transition-property:        padding-left;
  transition-timing-function:        cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration:        150ms;
}

.transition-\[transform\2c opacity\] {
  transition-property:        transform,opacity;
  transition-timing-function:        cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration:        150ms;
}

.transition-\[width\] {
  transition-property:        width;
  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-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;
}

.duration-\[220ms\] {
  transition-duration:        220ms;
}

.duration-\[600ms\] {
  transition-duration:        600ms;
}

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

.table-sticky-first th:first-child,
  .table-sticky-first td:first-child {
    position: sticky;
    left: 0;
    z-index: 1;
    background: var(--bg-card);
    box-shadow: 1px 0 0 0 var(--border);
  }

.table-sticky-first thead th:first-child {
    z-index: 2;
    background: var(--bg-card-dark);
  }

.page-headline {
    font-size: clamp(2.25rem, 1.45rem + 3.6vw, 3.75rem);
    line-height: 1.04;
    letter-spacing: -0.01em;
  }

.shadow-card {
    box-shadow:
      0 4px 24px rgba(0, 0, 0, 0.60),
      0 1px 4px rgba(0, 0, 0, 0.40),
      0 0 0 1px rgba(29, 58, 44, 0.30);
  }

.shadow-panel {
    box-shadow:
      0 2px 12px rgba(0, 0, 0, 0.50),
      0 0 0 1px rgba(31, 51, 34, 0.75),
      inset 0 1px 0 rgba(122, 171, 138, 0.05);
  }

.shadow-login-card {
    box-shadow:
      0 2px 12px rgba(0, 0, 0, 0.50),
      0 0 0 1px rgba(31, 51, 34, 0.75),
      inset 0 1px 0 rgba(122, 171, 138, 0.05),
      0 0 24px color-mix(in srgb, var(--gold) 6%, transparent);
  }

.shadow-inner-card {
    box-shadow:
      0 1px 4px rgba(0, 0, 0, 0.45),
      inset 0 1px 0 rgba(122, 171, 138, 0.06);
  }

.glass {
    background: color-mix(in srgb, var(--bg-card) 72%, transparent);
    backdrop-filter: blur(14px) saturate(1.15);
    -webkit-backdrop-filter: blur(14px) saturate(1.15);
    border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  }

.glass-gold {
    box-shadow:
      inset 0 1px 0 color-mix(in srgb, var(--gold) 10%, transparent),
      0 0 24px color-mix(in srgb, var(--gold) 6%, transparent);
  }

.glow-gold-sm  { filter: drop-shadow(0 0 6px  color-mix(in srgb, var(--gold) 25%, transparent)); }

.glow-gold-md  { filter: drop-shadow(0 0 10px color-mix(in srgb, var(--gold) 35%, transparent)); }

.glow-gold-lg  { filter: drop-shadow(0 0 18px color-mix(in srgb, var(--gold) 45%, transparent)); }

.glow-terra-sm { filter: drop-shadow(0 0 6px  color-mix(in srgb, var(--terra) 30%, transparent)); }

.glow-terra-md { filter: drop-shadow(0 0 10px color-mix(in srgb, var(--terra) 45%, transparent)); }

.card-hover {
    transition:
      transform 300ms var(--ease-out),
      border-color 300ms var(--ease-out),
      box-shadow 300ms var(--ease-out);
  }

.card-hover:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--gold) 30%, transparent);
    box-shadow:
      0 8px 32px rgba(0, 0, 0, 0.55),
      0 2px 8px rgba(0, 0, 0, 0.4),
      0 0 0 1px color-mix(in srgb, var(--gold) 12%, transparent);
  }

.card-hover:active {
    transform: translateY(0) scale(0.994);
    border-color: color-mix(in srgb, var(--gold) 42%, transparent);
    transition-duration: var(--duration-fast);
  }

[data-brand="ags"] { --brand-accent: #C4A882; --brand-text: #1A1A1A; }

[data-brand="phases"] { --brand-accent: #5B3F9F; --brand-text: #FFFFFF; }

[data-brand="sms"] { --brand-accent: #C44F14; --brand-text: #FFFFFF; }

[data-brand="champelli"] { --brand-accent: #1A1A1A; --brand-text: #FFFFFF; }

[data-brand="portfolio"] { --brand-accent: #C4A882; --brand-text: #1A1A1A; }

.brand-context-banner {
  background: var(--brand-accent);
  color: var(--brand-text);
}

.brand-context-banner[data-variant="tint"] {
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
  border-left-color: var(--brand-accent);
  color: var(--ink);
}

@keyframes brand-banner-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Retailer portal — smooth theme transition when brand changes */

.retailer-portal {
  transition: background-color 0.25s ease, color 0.25s ease;
}

.particle-field,
.ember-field {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.particle-field {
  background:
    radial-gradient(circle at 18% 22%, rgba(var(--particle-primary), 0.12), transparent 18rem),
    radial-gradient(circle at 78% 18%, rgba(var(--particle-accent), 0.08), transparent 16rem),
    radial-gradient(circle at 54% 86%, rgba(var(--particle-primary), 0.10), transparent 20rem);
}

.particle-field__point,
.ember-field__spark {
  position: absolute;
  display: block;
  border-radius: 999px;
  will-change: transform, opacity;
}

.particle-field__point {
  width: 0.28rem;
  height: 0.28rem;
  background: rgba(var(--particle-primary), 0.42);
  box-shadow: 0 0 18px rgba(var(--particle-accent), 0.22);
  opacity: 0.42;
}

.particle-field--animated .particle-field__point {
  animation: particle-field-drift 18s ease-in-out infinite alternate;
  animation-delay: calc(var(--i) * -0.9s);
}

.particle-field__point:nth-child(3n) {
  background: rgba(var(--particle-accent), 0.46);
}

.particle-field__point:nth-child(1) { left: 8%; top: 18%; }

.particle-field__point:nth-child(2) { left: 22%; top: 72%; }

.particle-field__point:nth-child(3) { left: 36%; top: 34%; }

.particle-field__point:nth-child(4) { left: 48%; top: 82%; }

.particle-field__point:nth-child(5) { left: 58%; top: 20%; }

.particle-field__point:nth-child(6) { left: 70%; top: 62%; }

.particle-field__point:nth-child(7) { left: 84%; top: 28%; }

.particle-field__point:nth-child(8) { left: 92%; top: 76%; }

.particle-field__point:nth-child(9) { left: 14%; top: 48%; }

.particle-field__point:nth-child(10) { left: 30%; top: 12%; }

.particle-field__point:nth-child(11) { left: 44%; top: 56%; }

.particle-field__point:nth-child(12) { left: 64%; top: 42%; }

.particle-field__point:nth-child(13) { left: 76%; top: 88%; }

.particle-field__point:nth-child(14) { left: 88%; top: 10%; }

.particle-field__point:nth-child(15) { left: 5%; top: 88%; }

.particle-field__point:nth-child(16) { left: 52%; top: 8%; }

.particle-field__point:nth-child(17) { left: 68%; top: 16%; }

.particle-field__point:nth-child(18) { left: 96%; top: 44%; }

@keyframes particle-field-drift {
  from { transform: translate3d(-0.45rem, 0.25rem, 0) scale(0.9); opacity: 0.28; }
  to { transform: translate3d(0.55rem, -0.35rem, 0) scale(1.25); opacity: 0.58; }
}

.ember-field {
  background:
    radial-gradient(circle at 18% 82%, rgba(196, 106, 55, 0.12), transparent 18rem),
    radial-gradient(circle at 82% 18%, rgba(122, 59, 30, 0.10), transparent 16rem);
}

.ember-field__spark {
  width: 0.22rem;
  height: 0.22rem;
  bottom: -1rem;
  background: rgba(196, 106, 55, 0.42);
  box-shadow: 0 0 16px rgba(196, 106, 55, 0.3);
  animation: ember-field-rise 15s linear infinite;
  animation-delay: calc(var(--i) * -0.72s);
}

.ember-field__spark:nth-child(1) { left: 6%; }

.ember-field__spark:nth-child(2) { left: 14%; }

.ember-field__spark:nth-child(3) { left: 21%; }

.ember-field__spark:nth-child(4) { left: 30%; }

.ember-field__spark:nth-child(5) { left: 38%; }

.ember-field__spark:nth-child(6) { left: 45%; }

.ember-field__spark:nth-child(7) { left: 52%; }

.ember-field__spark:nth-child(8) { left: 59%; }

.ember-field__spark:nth-child(9) { left: 66%; }

.ember-field__spark:nth-child(10) { left: 72%; }

.ember-field__spark:nth-child(11) { left: 78%; }

.ember-field__spark:nth-child(12) { left: 84%; }

.ember-field__spark:nth-child(13) { left: 90%; }

.ember-field__spark:nth-child(14) { left: 24%; }

.ember-field__spark:nth-child(15) { left: 48%; }

.ember-field__spark:nth-child(16) { left: 68%; }

@keyframes ember-field-rise {
  0% { transform: translate3d(0, 0, 0) scale(0.9); opacity: 0; }
  10% { opacity: 0.5; }
  100% { transform: translate3d(0.75rem, -105vh, 0) scale(1.2); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .particle-field__point,
  .ember-field__spark {
    animation: none !important;
  }
}

/* ─── Self-hosted Brand Fonts ────────────────────────────────────────── */

/* IBM Plex Mono */

@font-face { font-family: 'IBM Plex Mono'; src: url('/fonts/IBMPlexMono-Regular.ttf') format('truetype'); font-weight: 400; font-style: normal; font-display: swap; }

@font-face { font-family: 'IBM Plex Mono'; src: url('/fonts/IBMPlexMono-SemiBold.ttf') format('truetype'); font-weight: 600 700; font-style: normal; font-display: swap; }

/* IBM Plex Sans — variable font (replaces individual static files) */

@font-face {
  font-family: 'IBM Plex Sans';
  src: url('/fonts/IBMPlexSans-VariableFont_wdth,wght.ttf') format('truetype');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'IBM Plex Sans';
  src: url('/fonts/IBMPlexSans-Italic-VariableFont_wdth,wght.ttf') format('truetype');
  font-weight: 400 700;
  font-style: italic;
  font-display: swap;
}

/* Playfair Display — variable font (replaces individual static files) */

@font-face {
  font-family: 'Playfair Display';
  src: url('/fonts/PlayfairDisplay-VariableFont_wght.ttf') format('truetype');
  font-weight: 600 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Playfair Display';
  src: url('/fonts/PlayfairDisplay-Italic-VariableFont_wght.ttf') format('truetype');
  font-weight: 600 900;
  font-style: italic;
  font-display: swap;
}

/* ═══════════════════════════════════════════════════════════════════════
   BASE COLOR PALETTE
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  /* Forest greens */
  --forest:          #1d3a2c;
  --forest-deep:     #091209;
  --forest-mid:      #2c5440;
  --forest-light:    #3d7560;

  /* Channel triplets — keep in sync with the hex tokens; used by
     Tailwind alpha modifiers (e.g. border-gold/40 -> rgb(var(--gold-rgb)/.4)) */
  --gold-rgb:        201 150 12;
  --sage-rgb:        122 171 138;
  --terra-rgb:       196 106 55;
  --sage-pale-rgb:   196 219 201;
  --gold-pale-rgb:   245 233 196;

  /* Gold */
  --gold:            #c9960c;
  --gold-dim:        #a87a0a;
  --gold-glow:       rgba(201, 150, 12, 0.30);
  --gold-trace:      rgba(201, 150, 12, 0.10);
  --gold-orb:        #f9c04a;
  --gold-pale:       #f5e9c4;
  --gold-faint:      #faf5ec;

  /* KPI status green — brighter than sage for numeric emphasis */
  --kpi-green:       #4ade80;

  /* Sage */
  --sage:            #7aab8a;
  --sage-dim:        #6a9175;
  --sage-pale:       #c4dbc9;
  --success:         var(--sage);
  --success-bg:      rgba(122, 171, 138, 0.10);
  --success-border:  rgba(122, 171, 138, 0.32);
  --warning:         #d6a84a;
  --warning-bg:      rgba(214, 168, 74, 0.10);
  --warning-border:  rgba(214, 168, 74, 0.32);
  --error:           #f87171;
  --error-bg:        rgba(248, 113, 113, 0.10);
  --error-border:    rgba(248, 113, 113, 0.32);

  /* Roots / Terra */
  --terra:           #c46a37;
  --terra-dim:       #a3552a;
  --terra-trace:     rgba(196, 106, 55, 0.12);
  --roots-tile:      #7A3B1E;
  --roots-deep:      #3D1A0A;
  --cream:           #f4ead6;

  /* Font stacks */
  --font-serif:      'Playfair Display', Georgia, serif;
  --font-sans:       'IBM Plex Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:       'IBM Plex Mono', 'Courier New', monospace;

  /* Type scale — semantic steps (use these; avoid arbitrary [px] values) */
  --text-display:    clamp(2.6rem, 5vw, 4rem);      /* hero / page display title    */
  --text-h1:         clamp(1.75rem, 3vw, 2.25rem);  /* primary page heading         */
  --text-h2:         clamp(1.25rem, 2vw, 1.5rem);   /* section heading              */
  --text-h3:         1.0625rem;                     /* sub-section heading          */
  --text-body:       0.9375rem;                     /* default body copy (≈15px)    */
  --text-small:      0.875rem;                      /* secondary body / captions    */
  --text-micro:      0.64rem;                       /* micro labels, badges, stamps */

  /* Long-form readability */
  --prose-max-width: 70ch;
  --prose-leading:   1.75;

  /* Phase colors */
  --phase-1:         #c9960c;
  --phase-1-bg:      #fef9ec;
  --phase-1-text:    #7a5a08;
  --phase-2:         #2c5440;
  --phase-2-bg:      #edf5f0;
  --phase-2-text:    #1d3a2c;
  --phase-3:         #3d6b8a;
  --phase-3-bg:      #edf3f8;
  --phase-3-text:    #1d3650;
  --phase-4:         #3d7560;
  --phase-4-bg:      #edf5f2;
  --phase-4-text:    #1d4035;

  /* Spacing tokens */
  --sidebar-width:   236px;
  --header-height:   56px;
  --content-max:     1280px;

  /* Motion — mirrored in src/components/viz/motion.ts (the vocabulary) */
  --ease-out:        cubic-bezier(0.16, 1, 0.3, 1);
  --ease-standard:   cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --duration-fast:   120ms;
  --duration-base:   200ms;
  --duration-slow:   420ms;
  --duration-modal:  400ms;
}

/* ═══════════════════════════════════════════════════════════════════════
   CONTEXT 1 — MIDNIGHT (default dark)
   ═══════════════════════════════════════════════════════════════════════ */

:root,
[data-theme="midnight"] {
  /* Dark is the platform default; native UI (scrollbars, inputs) follows */
  color-scheme: dark;
  --bg-base-rgb:     7 12 9;
  --bg-card-rgb:     13 22 16;
  --border-rgb:      21 32 22;
  --ink-faint-rgb:   79 98 84;
  --bg-base:         #070c09;
  --bg-card:         #0d1610;
  --bg-card-dark:    #080f0a;
  --bg-card-hover:   #111e14;
  --bg-header:       rgba(7, 12, 9, 0.93);
  --header-bg:       rgba(7, 12, 9, 0.93);

  --border:          #152016;
  --border-mid:      #1e3320;
  --border-strong:   #2c5440;

  --ink:             #dce8de;
  --ink-soft:        #a8bfac;
  --ink-muted:       #6b7d6f;
  /* Lifted to ~3.5:1 on bg-base and ~3.3:1 on bg-card for legible faint labels */
  --ink-faint:       #586d5d;

  --accent:          var(--gold);
  --accent-dim:      var(--gold-dim);
  --accent-trace:    var(--gold-trace);

  --grid-line:       rgba(61, 117, 96, 0.13);
  --grid-size:       44px;

  --card-shadow:     0 4px 24px rgba(0,0,0,0.6), 0 1px 4px rgba(0,0,0,0.4), 0 0 0 1px rgba(29,58,44,0.3);
  --particle-primary: rgba(61,117,96,1);
  --particle-accent:  rgba(201,150,12,1);
  --particle-line:    rgba(61,117,96,1);
  --particle-cursor:  rgba(201,150,12,1);
  --particle-strength: 1;

  --panel-gradient-start: rgba(13, 22, 16, 0.98);
  --panel-gradient-end:   rgba(8, 15, 10, 0.99);
}

/* ═══════════════════════════════════════════════════════════════════════
   CONTEXT 2 — FOREST DARK (slightly lifted dark)
   ═══════════════════════════════════════════════════════════════════════ */

[data-theme="forest"] {
  color-scheme: dark;
  --bg-base-rgb:     15 26 18;
  --bg-card-rgb:     22 32 24;
  --border-rgb:      30 50 32;
  --ink-faint-rgb:   90 110 96;
  --bg-base:         #0f1a12;
  --bg-card:         #162018;
  --bg-card-dark:    #0c1510;
  --bg-card-hover:   #1a2a1e;
  --bg-header:       rgba(18, 30, 21, 0.94);
  --header-bg:       rgba(15, 26, 18, 0.94);

  --border:          #1e3220;
  --border-mid:      #2a4830;
  --border-strong:   #3d7060;

  --ink:             #dce8de;
  --ink-soft:        #b0c8b4;
  --ink-muted:       #7a9080;
  /* Lifted from #4e6054 for ~3:1 faint-label contrast on the forest bg */
  --ink-faint:       #5a6e60;

  --accent:          var(--gold);
  --accent-dim:      var(--gold-dim);
  --accent-trace:    var(--gold-trace);

  --grid-line:       rgba(61, 117, 96, 0.13);
  --grid-size:       44px;

  --card-shadow:     0 4px 20px rgba(0,0,0,0.5), 0 1px 4px rgba(0,0,0,0.3);
  --particle-primary: rgba(122,171,138,1);
  --particle-accent:  rgba(201,150,12,1);
  --particle-line:    rgba(61,117,96,1);
  --particle-cursor:  rgba(201,150,12,1);

  --panel-gradient-start: rgba(22, 32, 24, 0.98);
  --panel-gradient-end:   rgba(12, 21, 16, 0.99);
}

/* ═══════════════════════════════════════════════════════════════════════
   CONTEXT 3 — CREAM (warm amber-parchment)
   ═══════════════════════════════════════════════════════════════════════ */

[data-theme="cream"] {
  color-scheme: light;
  --gold-rgb:        158 114 8;
  --bg-base-rgb:     240 232 213;
  --bg-card-rgb:     232 223 200;
  --border-rgb:      120 90 40;
  --ink-faint-rgb:   138 112 80;
  --bg-base:         #f0e8d5;
  --bg-card:         #e8dfc8;
  --bg-card-dark:    #ddd5bf;
  --bg-card-hover:   #e8dfc8;
  /* Header/sidebar stay dark in cream — forest green */
  --bg-header:       rgba(29, 58, 44, 0.97);
  --header-bg:       rgba(29, 58, 44, 0.97);

  --border:          rgba(120, 90, 40, 0.28);
  --border-mid:      rgba(120, 90, 40, 0.40);
  --border-strong:   #2c5440;

  --ink:             #1a1408;
  --ink-soft:        #2d2010;
  --ink-muted:       #5a4020;
  --ink-faint:       #7e6644;

  /* Darker gold for legibility on light backgrounds */
  --gold:            #9e7208;
  --gold-dim:        #7d5a06;
  --gold-trace:      rgba(158, 114, 8, 0.12);
  --forest-light:    #2c6048;

  --accent:          var(--gold);
  --accent-dim:      var(--gold-dim);
  --accent-trace:    var(--gold-trace);

  --grid-line:       rgba(29, 58, 44, 0.07);
  --grid-size:       44px;

  --card-shadow:     0 2px 16px rgba(0,0,0,0.09), 0 1px 4px rgba(0,0,0,0.05);
  --particle-primary: rgba(160,100,30,1);
  --particle-accent:  rgba(196,140,20,1);
  --particle-line:    rgba(140,80,20,1);
  --particle-cursor:  rgba(196,140,20,1);
  /* Light surface: geometry needs stronger alpha to hold contrast */
  --particle-strength: 1.45;

  /* Sidebar/header stay dark */
  --panel-gradient-start: rgba(13, 22, 16, 0.98);
  --panel-gradient-end:   rgba(8, 15, 10, 0.99);
}

/* ═══════════════════════════════════════════════════════════════════════
   CONTEXT 4 — LIGHT (aged paper/parchment)
   ═══════════════════════════════════════════════════════════════════════ */

[data-theme="light"] {
  color-scheme: light;
  --gold-rgb:        158 114 8;
  --bg-base-rgb:     221 216 200;
  --bg-card-rgb:     208 202 188;
  --border-rgb:      80 65 35;
  --ink-faint-rgb:   58 48 32;
  --bg-base:         #ddd8c8;
  --bg-card:         #d0cabc;
  --bg-card-dark:    #c8c2b4;
  --bg-card-hover:   #d0cabc;
  /* Header/sidebar stay dark in light — forest green */
  --bg-header:       rgba(29, 58, 44, 0.97);
  --header-bg:       rgba(29, 58, 44, 0.97);

  --border:          rgba(80, 65, 35, 0.33);
  --border-mid:      rgba(80, 65, 35, 0.45);
  --border-strong:   #2c5440;

  --ink:             #141008;
  --ink-soft:        #2a2010;
  --ink-muted:       #4a3820;
  --ink-faint:       #3a3020;

  /* Darker gold for legibility on light backgrounds */
  --gold:            #9e7208;
  --gold-dim:        #7d5a06;
  --gold-trace:      rgba(158, 114, 8, 0.10);
  --forest-light:    #2c6048;

  --accent:          var(--gold);
  --accent-dim:      var(--gold-dim);
  --accent-trace:    var(--gold-trace);

  --grid-line:       rgba(29, 58, 44, 0.05);
  --grid-size:       44px;

  --card-shadow:     0 2px 12px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.04);
  --particle-primary: rgba(40,70,40,1);
  --particle-accent:  rgba(100,70,20,1);
  --particle-line:    rgba(40,60,30,1);
  --particle-cursor:  rgba(100,70,20,1);
  /* Light surface: geometry needs stronger alpha to hold contrast */
  --particle-strength: 1.45;

  /* Sidebar/header stay dark */
  --panel-gradient-start: rgba(13, 22, 16, 0.98);
  --panel-gradient-end:   rgba(8, 15, 10, 0.99);
}

/* ═══════════════════════════════════════════════════════════════════════
   CONTEXT 3 — CANOPY ROOTS (terracotta brand)
   ═══════════════════════════════════════════════════════════════════════ */

[data-theme="roots"] {
  color-scheme: dark;
  --gold-rgb:        196 98 45;
  --bg-base-rgb:     26 14 8;
  --bg-card-rgb:     36 20 8;
  --border-rgb:      58 24 6;
  --ink-faint-rgb:   112 80 64;
  --bg-base:         #1a0e08;
  --bg-card:         #241408;
  --bg-card-dark:    #160b04;
  --bg-card-hover:   #2c1a0a;
  --bg-header:       rgba(26, 14, 8, 0.96);

  --border:          #3a1806;
  --border-mid:      #4f2010;
  --border-strong:   #7a3b1e;

  --ink:             #f4ead6;
  --ink-soft:        #d4c4b0;
  --ink-muted:       #a08070;
  /* Lifted from #705040 (2.6:1) to ~3.4:1 on the roots bg for legible faint labels */
  --ink-faint:       #846050;

  --gold:            #c4622d;
  --gold-dim:        #a3552a;
  --gold-trace:      rgba(196, 98, 45, 0.14);

  --accent:          var(--terra);
  --accent-dim:      var(--terra-dim);
  --accent-trace:    var(--terra-trace);

  --grid-line:       rgba(122, 59, 30, 0.10);
  --grid-size:       44px;

  --panel-gradient-start: rgba(26, 14, 8, 0.98);
  --panel-gradient-end:   rgba(20, 10, 6, 0.99);

  /* Roots page background — owned by the design system */
  --roots-page-bg:
    radial-gradient(circle at top center, rgba(196, 98, 45, 0.09), transparent 26%),
    linear-gradient(180deg, rgba(28, 18, 8, 0.98), rgba(22, 15, 9, 1));
  --roots-overlay-bg:
    radial-gradient(circle at 20% 20%, rgba(245, 237, 214, 0.08) 0, transparent 28%),
    radial-gradient(circle at 70% 80%, rgba(107, 127, 94, 0.12) 0, transparent 30%),
    radial-gradient(rgba(245, 237, 214, 0.25) 0.8px, transparent 0.8px);
  --roots-overlay-bg-size: auto, auto, 12px 12px;
  --roots-overlay-opacity: 0.08;
}

/* ═══════════════════════════════════════════════════════════════════════
   GLOBAL BASE
   ═══════════════════════════════════════════════════════════════════════ */

* {
  box-sizing: border-box;
}

html {
  background: var(--bg-base);
  min-height: 100%;
  overflow-x: hidden;
}

body {
  min-width: 320px;
  min-height: 100%;
  margin: 0;
  background: var(--bg-base);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.6;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

button,
a,
input,
select,
textarea,
[role='button'] {
  transition-duration: var(--duration-base);
  transition-timing-function: var(--ease-standard);
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role='button']:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

/* Additive: extend the brand focus ring to disclosure + tabbable elements */

summary:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

button:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

input,
select,
textarea {
  border-color: var(--border);
}

input:not([type='checkbox']):not([type='radio']),
select,
textarea {
  background: var(--bg-card-dark);
  color: var(--ink);
}

input::-moz-placeholder, textarea::-moz-placeholder {
  color: var(--ink-faint);
}

input::placeholder,
textarea::placeholder {
  color: var(--ink-faint);
}

input:focus,
select:focus,
textarea:focus {
  border-color: color-mix(in srgb, var(--accent) 62%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

table {
  font-size: 0.933rem;
  border-collapse: separate;
  border-spacing: 0;
}

thead th,
table th {
  color: var(--ink-soft);
  letter-spacing: 0.16em;
  position: sticky;
  top: 0;
  z-index: 3;
  background: color-mix(in srgb, var(--bg-card) 92%, black);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

table th,
table td {
  padding-top: 0.875rem;
  padding-bottom: 0.875rem;
}

tbody tr {
  transition: background-color 160ms var(--ease-standard), color 160ms var(--ease-standard);
}

tbody tr:nth-child(even) {
  background: color-mix(in srgb, var(--bg-card-dark) 36%, transparent);
}

tbody tr:hover {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

span[class*="rounded"][class*="font-mono"][class*="uppercase"],
span[class*="rounded"][class*="font-mono"][class*="tracking"] {
  min-height: 1.45rem;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

.ciq-button {
  display: inline-flex;
  min-height: 2.5rem;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  padding: 0.5rem 0.875rem;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ciq-button--primary {
  border-color: var(--accent);
  background: var(--accent);
  color: #07120a;
}

.ciq-button--secondary {
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
}

.ciq-button--tertiary {
  border-color: transparent;
  background: transparent;
  color: var(--ink-muted);
}

.ciq-button--tertiary:hover:not(:disabled) {
  color: var(--ink);
  background: color-mix(in srgb, var(--ink) 6%, transparent);
}

.ciq-button--destructive {
  border-color: var(--error-border);
  background: var(--error-bg);
  color: var(--error);
}

.ciq-button:hover:not(:disabled) {
  filter: brightness(1.08);
  transform: translateY(-1px);
  box-shadow:
    0 4px 14px -6px color-mix(in srgb, var(--accent) 45%, transparent),
    0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

[data-perf="field"] .ciq-button:hover:not(:disabled) {
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 28%, transparent);
}

.ciq-button:active:not(:disabled) {
  transform: translateY(1px) scale(0.98);
  transition-duration: var(--duration-fast);
}

@media (prefers-reduced-motion: reduce) {
  .ciq-button:active:not(:disabled) { transform: none; }
}

/* Mobile-only shrink for oversized font-display h1 headers (audit P1.4).
   Only fires below 640px; md: and >=640px sizes are untouched. */

@media (max-width: 639px) {
  .h1-mobile-fit {
    font-size: 2.5rem;
    line-height: 1.05;
  }
}

.ciq-skeleton {
  display: grid;
  gap: 0.75rem;
}

.ciq-skeleton > span {
  display: block;
  height: 0.85rem;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--border) 78%, transparent),
    color-mix(in srgb, var(--border-mid) 82%, transparent),
    color-mix(in srgb, var(--border) 78%, transparent)
  );
  background-size: 200% 100%;
  animation: ciq-skeleton-shimmer 1.25s ease-in-out infinite;
}

@keyframes ciq-skeleton-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.ciq-empty-state,
.ciq-error-state {
  display: flex;
  min-height: 9rem;
  align-items: flex-start;
  gap: 1rem;
  border-radius: 0.75rem;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg-card) 90%, transparent);
  padding: 1.25rem;
  box-shadow: var(--card-shadow);
}

.ciq-error-state {
  border-color: var(--error-border);
  background: color-mix(in srgb, var(--error-bg) 52%, var(--bg-card));
}

.ciq-state-icon {
  display: inline-grid;
  height: 2.5rem;
  width: 2.5rem;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 0.75rem;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent);
}

.ciq-state-icon--error {
  border-color: var(--error-border);
  background: var(--error-bg);
  color: var(--error);
}

.ciq-state-title {
  color: var(--ink);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.35;
}

.ciq-state-copy {
  margin-top: 0.25rem;
  color: var(--ink-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.ciq-state-action {
  margin-left: auto;
  flex-shrink: 0;
}

.ags-portal .ciq-empty-state,
.ags-portal .ciq-error-state {
  border-color: var(--ags-cream-3);
  background: #fff;
  color: var(--ags-text-dark);
  box-shadow: 0 10px 24px rgba(28, 18, 8, 0.08);
}

.ags-portal .ciq-error-state {
  border-color: rgba(95, 29, 19, 0.28);
  background: rgba(95, 29, 19, 0.04);
}

.ags-portal .ciq-state-title {
  color: var(--ags-text-dark);
}

.ags-portal .ciq-state-copy {
  color: var(--ags-text-muted);
}

.ags-portal .ciq-state-icon {
  border-color: var(--ags-cream-3);
  background: var(--ags-cream-2);
  color: var(--ags-warning);
}

.ags-portal .ciq-state-icon--error {
  border-color: rgba(95, 29, 19, 0.28);
  background: rgba(95, 29, 19, 0.08);
  color: #5f1d13;
}

.ags-portal .ciq-button--secondary {
  border-color: var(--ags-dark-border);
  background: var(--ags-dark);
  color: var(--ags-cream);
}

.ags-portal .ciq-skeleton > span {
  background: linear-gradient(90deg, #ede8dc, #d4c4a0, #ede8dc);
  background-size: 200% 100%;
}

.ags-portal table th {
  background: var(--ags-cream-2);
  color: var(--ags-text-muted);
}

.ags-portal tbody tr:nth-child(even) {
  background: rgba(212, 196, 160, 0.18);
}

.ags-portal tbody tr:hover {
  background: rgba(196, 168, 130, 0.18);
}

.ags-portal input:not([type='checkbox']):not([type='radio']),
.ags-portal select,
.ags-portal textarea {
  background: #fff;
  color: var(--ags-text-dark);
}

/* ═══════════════════════════════════════════════════════════════════════
   MULTI-BRAND PORTAL THEMES
   Overrides --ags-* variables when a specific brand is selected.
   Applied via data-brand attribute on .ags-portal wrapper.
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── PHASES: deep purple ─── */

.ags-portal[data-brand="phases"] {
  --ags-cream:       #f4f0ff;
  --ags-cream-2:     #ece6ff;
  --ags-cream-3:     rgba(91, 63, 159, 0.18);
  --ags-gold:        #7C5CC8;
  --ags-dark:        #2D1B69;
  --ags-dark-border: rgba(91, 63, 159, 0.45);
  --ags-text-dark:   #1a1030;
  --ags-text-muted:  #5a4a8a;
  --ags-warning:     #9b6de3;
}

.ags-portal[data-brand="phases"] .ciq-skeleton > span {
  background: linear-gradient(90deg, #ece6ff, #d8ccf8, #ece6ff);
  background-size: 200% 100%;
}

.ags-portal[data-brand="phases"] tbody tr:nth-child(even) {
  background: rgba(91, 63, 159, 0.06);
}

.ags-portal[data-brand="phases"] tbody tr:hover {
  background: rgba(124, 92, 200, 0.10);
}

/* ─── SMACKED STUDIOS: bold orange ─── */

.ags-portal[data-brand="sms"] {
  --ags-cream:       #fff5f0;
  --ags-cream-2:     #ffe9de;
  --ags-cream-3:     rgba(196, 79, 20, 0.18);
  --ags-gold:        #C44F14;
  --ags-dark:        #6B2000;
  --ags-dark-border: rgba(196, 79, 20, 0.45);
  --ags-text-dark:   #2a0e00;
  --ags-text-muted:  #8a3a1a;
  --ags-warning:     #e07a14;
}

.ags-portal[data-brand="sms"] .ciq-skeleton > span {
  background: linear-gradient(90deg, #ffe9de, #ffd0b8, #ffe9de);
  background-size: 200% 100%;
}

.ags-portal[data-brand="sms"] tbody tr:nth-child(even) {
  background: rgba(196, 79, 20, 0.05);
}

.ags-portal[data-brand="sms"] tbody tr:hover {
  background: rgba(196, 79, 20, 0.09);
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: var(--grid-size) var(--grid-size);
  pointer-events: none;
  z-index: 0;
}

#root {
  min-height: 100vh;
}

.app-main {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  padding: calc(var(--header-height) + 1.2rem) 1rem calc(6.5rem + env(safe-area-inset-bottom));
}

.app-header-shell {
  top: 0.75rem;
  left: 0.75rem;
  right: 0.75rem;
  border: 1px solid rgba(201, 150, 12, 0.22);
  border-radius: 22px;
  background: rgba(7, 12, 9, 0.82);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.42), 0 1px 0 rgba(255, 255, 255, 0.03) inset;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.app-footer {
  left: 0.75rem;
  right: 5rem;
  bottom: calc(0.75rem + env(safe-area-inset-bottom));
  border: 1px solid rgba(201, 150, 12, 0.18);
  border-radius: 20px;
  background: rgba(7, 12, 9, 0.82);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

[data-theme="forest"] .app-header-shell,
[data-theme="forest"] .app-footer {
  background: rgba(8, 16, 10, 0.82);
  border-color: rgba(122, 171, 138, 0.2);
}

[data-theme="roots"] .app-header-shell,
[data-theme="roots"] .app-footer {
  background: rgba(13, 7, 4, 0.84);
  border-color: rgba(196, 106, 55, 0.22);
}

[data-theme="cream"] .app-header-shell,
[data-theme="cream"] .app-footer {
  background: rgba(232, 220, 192, 0.9);
  border-color: rgba(120, 90, 40, 0.24);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

[data-theme="light"] .app-header-shell,
[data-theme="light"] .app-footer {
  background: rgba(204, 197, 176, 0.92);
  border-color: rgba(60, 50, 25, 0.28);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

.intro-overlay {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

.intro-overlay-inner {
  min-height: calc(100dvh - 2.5rem);
}

@keyframes gate-login-shake {
  0%,
  100% {
    transform: translateX(0);
  }
  20% {
    transform: translateX(-8px);
  }
  40% {
    transform: translateX(8px);
  }
  60% {
    transform: translateX(-5px);
  }
  80% {
    transform: translateX(5px);
  }
}

.gate-login-shake {
  animation: gate-login-shake 360ms cubic-bezier(0.36, 0.07, 0.19, 0.97);
}

.gate-password-input::-ms-reveal,
.gate-password-input::-ms-clear {
  display: none;
}

.gate-password-input::-webkit-credentials-auto-fill-button {
  visibility: hidden;
  display: none !important;
  pointer-events: none;
}

/* ─── Sidebar — floating island ──────────────────────────────────── */

.sidebar-shell {
  background: rgba(10, 14, 8, 0.44);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  border: 1.5px solid rgba(201, 150, 12, 0.22);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.55), 0 2px 8px rgba(0, 0, 0, 0.30), inset 0 0 0 0.5px rgba(255, 255, 255, 0.035);
}

[data-theme="forest"] .sidebar-shell {
  background: rgba(8, 16, 10, 0.55);
  border-color: rgba(122, 171, 138, 0.22);
}

[data-theme="roots"] .sidebar-shell {
  background: rgba(13, 7, 4, 0.55);
  border-color: rgba(196, 106, 55, 0.25);
}

[data-theme="cream"] .sidebar-shell {
  background: rgba(232, 220, 192, 0.88);
  border-color: rgba(120, 90, 40, 0.3);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.07);
}

[data-theme="light"] .sidebar-shell {
  background: rgba(204, 197, 176, 0.88);
  border-color: rgba(60, 50, 25, 0.35);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.07);
}

/* ─── Sidebar nav fade overlay ───────────────────────────────────── */

.sidebar-nav-fade {
  position: relative;
}

.sidebar-nav-fade::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 48px;
  background: linear-gradient(to bottom, transparent, rgba(10, 14, 8, 0.95));
  pointer-events: none;
  z-index: 2;
}

[data-theme="forest"] .sidebar-nav-fade::after {
  background: linear-gradient(to bottom, transparent, rgba(8, 16, 10, 0.95));
}

[data-theme="roots"] .sidebar-nav-fade::after {
  background: linear-gradient(to bottom, transparent, rgba(13, 7, 4, 0.95));
}

[data-theme="cream"] .sidebar-nav-fade::after {
  background: linear-gradient(to bottom, transparent, rgba(232, 220, 192, 0.95));
}

[data-theme="light"] .sidebar-nav-fade::after {
  background: linear-gradient(to bottom, transparent, rgba(204, 197, 176, 0.95));
}

/* ─── Nav hover pill ─────────────────────────────────────────────── */

.nav-pill {
  transition: background-color 150ms ease;
}

a:hover .nav-pill {
  background-color: rgba(201, 150, 12, 0.45);
}

a[aria-current="page"] .nav-pill {
  background-color: var(--gold);
}

[data-theme="roots"] a:hover .nav-pill {
  background-color: rgba(196, 106, 55, 0.45);
}

[data-theme="roots"] a[aria-current="page"] .nav-pill {
  background-color: var(--terra);
}

/* ─── Chat panel ────────────────────────────────────────────────── */

.chat-panel-border {
  border-left: 2px solid rgba(201,150,12,0.4);
  box-shadow: -4px 0 20px rgba(0,0,0,0.5), -1px 0 0 rgba(201,150,12,0.2);
}

/* ─── Allocation slider ─────────────────────────────────────────── */

.allocation-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 9999px;
  background: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,150,12,0.18), 0 0 16px rgba(201,150,12,0.35);
}

.allocation-range::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border: 0;
  border-radius: 9999px;
  background: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,150,12,0.18), 0 0 16px rgba(201,150,12,0.35);
}

/* ─── Wide-table mobile story ────────────────────────────────────────
   Inside an overflow-x-auto wrapper, .table-sticky-first pins the
   identity column while the metrics scroll. Cell backgrounds must be
   opaque so scrolled content does not bleed through. */

/* ─── Type scale ─────────────────────────────────────────────────────
   Page-level display headline: one fluid clamp instead of per-page
   text-4xl/5xl/6xl breakpoint chains (2.25rem at 360px → 3.75rem wide). */

/* ─── Elevation system ──────────────────────────────────────────────
   The four-step scale, lowest to highest (brand-tinted ring, not pure
   black): .shadow-inner-card → .shadow-panel → .shadow-card →
   .shadow-card-raised (hover). Modals sit above all four with their own
   shadow. Hover raises one step via .card-hover (Field tier: no lift). */

/* ─── Glasshouse surfaces ───────────────────────────────────────── */

/* Token-driven glass. Tier gating below: Studio = blur everywhere,
   Core = blur on nav/modals (.glass-nav) only, Field = solid surfaces. */

/* ─── Card hover physics (design constitution) ──────────────────── */

[data-theme="roots"] .card-hover:hover {
  border-color: color-mix(in srgb, var(--terra) 30%, transparent);
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.55),
    0 2px 8px rgba(0, 0, 0, 0.4),
    0 0 0 1px color-mix(in srgb, var(--terra) 12%, transparent);
}

[data-theme="cream"] .card-hover:hover,
[data-theme="light"] .card-hover:hover {
  box-shadow:
    0 6px 20px rgba(0, 0, 0, 0.12),
    0 2px 6px rgba(0, 0, 0, 0.08),
    0 0 0 1px color-mix(in srgb, var(--gold) 14%, transparent);
}

/* Field tier / reduced motion: hover feedback stays (border, shadow) but the
   lift physics go — no transform, no transition cost. */

[data-perf="field"] .card-hover {
  transition-duration: 0ms;
}

[data-perf="field"] .card-hover:hover {
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .card-hover { transition-duration: 0ms; }
  .card-hover:hover { transform: none; }
  .card-hover:active { transform: none; }
}

[data-theme="roots"] .card-hover:active {
  border-color: color-mix(in srgb, var(--terra) 42%, transparent);
}

[data-perf="field"] .card-hover:active {
  transform: none;
}

/* Studio: brand banner tint variant picks up glass blur */

[data-perf="studio"] .brand-context-banner[data-variant="tint"] {
  backdrop-filter: blur(14px) saturate(1.15);
  -webkit-backdrop-filter: blur(14px) saturate(1.15);
}

/* ─── Performance tiers (data-perf on <html>) ───────────────────── */

/* Core: app shells drop to the lighter nav blur */

[data-perf="core"] .app-header-shell,
[data-perf="core"] .app-footer,
[data-perf="core"] .sidebar-shell {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* Core: glass blur only on nav and modal surfaces */

[data-perf="core"] .glass:not(.glass-nav) {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  background: color-mix(in srgb, var(--bg-card) 94%, transparent);
}

[data-perf="core"] .glass-nav {
  backdrop-filter: blur(8px) saturate(1.1);
  -webkit-backdrop-filter: blur(8px) saturate(1.1);
}

/* Field: solid surfaces, no blur anywhere, no ambient animation */

[data-perf="field"] .glass {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background: var(--bg-card);
}

[data-perf="field"] .app-header-shell,
[data-perf="field"] .app-footer,
[data-perf="field"] .sidebar-shell,
[data-perf="field"] thead th,
[data-perf="field"] table th {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

[data-perf="field"] .sidebar-shell {
  background: var(--bg-card);
}

[data-perf="field"] .animate-breathe,
[data-perf="field"] .animate-breathe-subtle,
[data-perf="field"] .anim-breathe,
[data-perf="field"] .logo-glow {
  animation: none !important;
}

/* ─── Cream / Light card accent ────────────────────────────────── */

[data-theme="cream"] .shadow-card,
[data-theme="light"] .shadow-card {
  border-left: 2px solid var(--forest-light);
}

/* ─── Sparkline draw-in (living data layer) ─────────────────────── */

.spark-draw-in {
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  animation: spark-draw 0.9s var(--ease-out) 150ms forwards;
}

@keyframes spark-draw {
  to { stroke-dashoffset: 0; }
}

.spark-fill-in {
  opacity: 0;
  animation: spark-fade 0.6s ease-out 650ms forwards;
}

@keyframes spark-fade {
  to { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .spark-draw-in { stroke-dashoffset: 0; animation: none; }
  .spark-fill-in { opacity: 1; animation: none; }
}

/* ─── Row reveal (staggered table/list entrances, tier-gated) ─────
   Apply via rowReveal(i) in src/components/viz/motion.ts:
   className="row-reveal" + style={{ animationDelay: '<i*28>ms' }}.
   `backwards` fill keeps rows hidden until their delay elapses. */

@keyframes row-reveal {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.row-reveal {
  animation: row-reveal var(--duration-base) var(--ease-out) backwards;
}

[data-perf="field"] .row-reveal {
  animation: none;
}

@media (prefers-reduced-motion: reduce) {
  .row-reveal { animation: none; }
}

/* ─── Motion ────────────────────────────────────────────────────── */

@keyframes breathe {
  0%, 100% { transform: scale(1) translateZ(0); opacity: 0.88; }
  50%       { transform: scale(1.06) translateZ(0); opacity: 1; }
}

@keyframes breathe-subtle {
  0%, 100% { transform: scale(1) translateZ(0); opacity: 0.82; }
  50%       { transform: scale(1.03) translateZ(0); opacity: 0.96; }
}

.animate-breathe-subtle {
  will-change: transform;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  animation: breathe-subtle 4.2s ease-in-out infinite;
}

@keyframes logo-glow-pulse {
  0%, 100% { filter: drop-shadow(0 0 8px rgba(122,171,138,0.22)) drop-shadow(0 0 20px rgba(201,150,12,0.08)); }
  50%       { filter: drop-shadow(0 0 16px rgba(122,171,138,0.48)) drop-shadow(0 0 32px rgba(201,150,12,0.18)); }
}

.anim-breathe,
.animate-breathe {
  animation: breathe 3.6s ease-in-out infinite;
}

.logo-glow {
  will-change: transform, filter;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  animation:
    breathe 3.6s ease-in-out infinite,
    logo-glow-pulse 3.6s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}

/* ─── Print ─────────────────────────────────────────────────────── */

@media print {
  :root {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  body::before { display: none; }

  .app-shell-nav,
  .app-shell-header,
  .app-shell-footer,
  .page-print-cta {
    display: none !important;
  }

  main {
    position: static !important;
    inset: auto !important;
    overflow: visible !important;
    padding: 0 !important;
  }

  [data-print-page] {
    margin: 0 !important;
    max-width: none !important;
    padding: 0 !important;
  }
}

/* ─── Prefers-reduced-motion ─────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .animate-breathe,
  .logo-glow,
  .anim-breathe,
  [class*="animate-"] {
    animation: none !important;
  }
  * {
    transition-duration: 0.01ms !important;
  }
}

/* ─── Touch-friendly range slider thumb ─────────────────────────────── */

@media (hover: none) {
  input[type="range"]::-webkit-slider-thumb {
    width: 24px;
    height: 24px;
  }
  input[type="range"]::-moz-range-thumb {
    width: 24px;
    height: 24px;
  }
}

@media (max-width: 1023px) {
  .app-main {
    padding-top: calc(var(--header-height) + 1.35rem);
  }
}

/* ─── Branded loader: breathing mark inside an orbiting accent ring ── */

.brand-loader {
  display: grid;
  justify-items: center;
  gap: 0.85rem;
  padding: 0.5rem;
}

.brand-loader__stage {
  position: relative;
  display: grid;
  place-items: center;
}

.brand-loader__mark {
  width: 56%;
  height: 56%;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: 18%;
  animation: breathe-subtle 2.6s ease-in-out infinite;
  filter: drop-shadow(0 0 10px color-mix(in srgb, var(--accent) 35%, transparent));
}

.brand-loader__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: conic-gradient(
    from 0deg,
    transparent 0deg 250deg,
    color-mix(in srgb, var(--accent) 85%, transparent) 360deg
  );
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 2.5px), #000 calc(100% - 2px));
  mask: radial-gradient(farthest-side, transparent calc(100% - 2.5px), #000 calc(100% - 2px));
  animation: brand-loader-spin 1.3s linear infinite;
}

.brand-loader__orbit {
  position: absolute;
  inset: -7px;
  border-radius: 50%;
  animation: brand-loader-spin 2.6s linear infinite reverse;
}

.brand-loader__orbit i {
  position: absolute;
  top: 0;
  left: 50%;
  width: 4px;
  height: 4px;
  margin-left: -2px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 60%, transparent);
}

.brand-loader__label {
  margin: 0;
  font-family: var(--font-mono);
  font-size: 0.64rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

@keyframes brand-loader-spin {
  to { transform: rotate(360deg); }
}

/* Field tier and reduced motion: static mark with a quiet arc, no orbit */

[data-perf="field"] .brand-loader__mark,
[data-perf="field"] .brand-loader__ring {
  animation: none;
}

[data-perf="field"] .brand-loader__orbit {
  display: none;
}

@media (prefers-reduced-motion: reduce) {
  .brand-loader__orbit { display: none; }
  .brand-loader__ring {
    background: none;
    border: 1.5px solid color-mix(in srgb, var(--accent) 35%, transparent);
    -webkit-mask: none;
    mask: none;
  }
}

.route-loader {
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: var(--bg-card);
  padding: 1.5rem;
}

.route-loader__mark {
  display: inline-grid;
  width: 2.75rem;
  height: 2.75rem;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--gold) 72%, transparent);
  border-radius: 999px;
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 0 0 0.35rem color-mix(in srgb, var(--gold) 9%, transparent);
  animation: route-loader-spin 1.1s linear infinite;
}

@keyframes route-loader-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .route-loader__mark {
    animation: none;
  }
}

@media (max-width: 639px) {
  .app-main {
    padding-bottom: calc(7rem + env(safe-area-inset-bottom));
  }

  .app-header-shell {
    top: 0.65rem;
    left: 0.65rem;
    right: 0.65rem;
  }

  .app-footer {
    left: 0.65rem;
    right: 4.7rem;
    bottom: calc(0.65rem + env(safe-area-inset-bottom));
  }

  .intro-overlay-inner {
    min-height: calc(100dvh - 1.5rem);
  }
}

@media (min-width: 640px) {
  .app-main {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .app-header-shell {
    left: 1rem;
    right: 1rem;
  }

  .app-footer {
    left: 1rem;
    right: 1rem;
  }
}

@media (min-width: 1024px) {
  .app-main {
    padding: calc(var(--header-height) + 1rem) 2rem calc(5rem + env(safe-area-inset-bottom));
  }

  .app-header-shell {
    top: 0;
    left: 0;
    right: 0;
    border-top: 0;
    border-left: 0;
    border-right: 0;
    border-bottom: 1px solid var(--border-mid);
    border-radius: 0;
    background: var(--bg-header);
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .app-footer {
    left: 0;
    right: 0;
    bottom: 0;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    border-top: 1px solid var(--border);
    border-radius: 0;
    background: var(--bg-base);
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

.placeholder\:text-ink-faint::-moz-placeholder {
  --tw-text-opacity:        1;
  color:        rgb(var(--ink-faint-rgb) / var(--tw-text-opacity, 1));
}

.placeholder\:text-ink-faint::placeholder {
  --tw-text-opacity:        1;
  color:        rgb(var(--ink-faint-rgb) / var(--tw-text-opacity, 1));
}

.after\:absolute::after {
  content:        var(--tw-content);
  position:        absolute;
}

.after\:-inset-3::after {
  content:        var(--tw-content);
  inset:        -0.75rem;
}

.after\:content-\[\'\'\]::after {
  --tw-content:        '';
  content:        var(--tw-content);
}

.first\:rounded-l-lg:first-child {
  border-top-left-radius:        0.5rem;
  border-bottom-left-radius:        0.5rem;
}

.last\:rounded-r-lg:last-child {
  border-top-right-radius:        0.5rem;
  border-bottom-right-radius:        0.5rem;
}

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

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

.last\:pb-0:last-child {
  padding-bottom:        0px;
}

.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\:-translate-y-1:hover {
  --tw-translate-y:        -0.25rem;
  transform:        translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.hover\:-translate-y-px:hover {
  --tw-translate-y:        -1px;
  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-\[\#a78bfa\]\/20:hover {
  border-color:        rgb(167 139 250 / 0.2);
}

.hover\:border-\[\#c46a37\]\/45:hover {
  border-color:        rgb(196 106 55 / 0.45);
}

.hover\:border-\[\#d4af37\]:hover {
  --tw-border-opacity:        1;
  border-color:        rgb(212 175 55 / var(--tw-border-opacity, 1));
}

.hover\:border-\[\#d4af37\]\/70:hover {
  border-color:        rgb(212 175 55 / 0.7);
}

.hover\:border-\[\#f97316\]\/20:hover {
  border-color:        rgb(249 115 22 / 0.2);
}

.hover\:border-\[rgba\(196\2c 98\2c 45\2c 0\.38\)\]:hover {
  border-color:        rgba(196,98,45,0.38);
}

.hover\:border-\[rgba\(196\2c 98\2c 45\2c 0\.4\)\]:hover {
  border-color:        rgba(196,98,45,0.4);
}

.hover\:border-\[var\(--ags-gold\)\]:hover {
  border-color:        var(--ags-gold);
}

.hover\:border-amber-400\/40:hover {
  border-color:        rgb(251 191 36 / 0.4);
}

.hover\:border-amber-400\/50:hover {
  border-color:        rgb(251 191 36 / 0.5);
}

.hover\:border-border-mid:hover {
  border-color:        var(--border-mid);
}

.hover\:border-gold:hover {
  --tw-border-opacity:        1;
  border-color:        rgb(var(--gold-rgb) / var(--tw-border-opacity, 1));
}

.hover\:border-gold\/20:hover {
  border-color:        rgb(var(--gold-rgb) / 0.2);
}

.hover\:border-gold\/25:hover {
  border-color:        rgb(var(--gold-rgb) / 0.25);
}

.hover\:border-gold\/30:hover {
  border-color:        rgb(var(--gold-rgb) / 0.3);
}

.hover\:border-gold\/40:hover {
  border-color:        rgb(var(--gold-rgb) / 0.4);
}

.hover\:border-gold\/50:hover {
  border-color:        rgb(var(--gold-rgb) / 0.5);
}

.hover\:border-gold\/60:hover {
  border-color:        rgb(var(--gold-rgb) / 0.6);
}

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

.hover\:border-sage:hover {
  --tw-border-opacity:        1;
  border-color:        rgb(var(--sage-rgb) / var(--tw-border-opacity, 1));
}

.hover\:border-sage\/40:hover {
  border-color:        rgb(var(--sage-rgb) / 0.4);
}

.hover\:border-terra\/60:hover {
  border-color:        rgb(var(--terra-rgb) / 0.6);
}

.hover\:bg-\[\#b8943d\]:hover {
  --tw-bg-opacity:        1;
  background-color:        rgb(184 148 61 / var(--tw-bg-opacity, 1));
}

.hover\:bg-\[\#c46a37\]\/10:hover {
  background-color:        rgb(196 106 55 / 0.1);
}

.hover\:bg-\[\#c46a37\]\/20:hover {
  background-color:        rgb(196 106 55 / 0.2);
}

.hover\:bg-\[\#d4af37\]\/10:hover {
  background-color:        rgb(212 175 55 / 0.1);
}

.hover\:bg-\[\#d4af37\]\/20:hover {
  background-color:        rgb(212 175 55 / 0.2);
}

.hover\:bg-\[rgba\(196\2c 106\2c 55\2c 0\.06\)\]:hover {
  background-color:        rgba(196,106,55,0.06);
}

.hover\:bg-\[rgba\(196\2c 98\2c 45\2c 0\.09\)\]:hover {
  background-color:        rgba(196,98,45,0.09);
}

.hover\:bg-amber-400\/20:hover {
  background-color:        rgb(251 191 36 / 0.2);
}

.hover\:bg-amber-500\/15:hover {
  background-color:        rgb(245 158 11 / 0.15);
}

.hover\:bg-bg-base\/60:hover {
  background-color:        rgb(var(--bg-base-rgb) / 0.6);
}

.hover\:bg-bg-card-dark:hover {
  background-color:        var(--bg-card-dark);
}

.hover\:bg-gold-dim:hover {
  background-color:        var(--gold-dim);
}

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

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

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

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

.hover\:bg-gold\/60:hover {
  background-color:        rgb(var(--gold-rgb) / 0.6);
}

.hover\:bg-gold\/90:hover {
  background-color:        rgb(var(--gold-rgb) / 0.9);
}

.hover\:bg-gold\/\[0\.05\]:hover {
  background-color:        rgb(var(--gold-rgb) / 0.05);
}

.hover\:bg-green-500\/15:hover {
  background-color:        rgb(34 197 94 / 0.15);
}

.hover\:bg-green-500\/20:hover {
  background-color:        rgb(34 197 94 / 0.2);
}

.hover\:bg-red-400\/15:hover {
  background-color:        rgb(248 113 113 / 0.15);
}

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

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

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

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

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

.hover\:bg-white\/\[0\.025\]:hover {
  background-color:        rgb(255 255 255 / 0.025);
}

.hover\:bg-white\/\[0\.02\]:hover {
  background-color:        rgb(255 255 255 / 0.02);
}

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

.hover\:bg-yellow-400\/10:hover {
  background-color:        rgb(250 204 21 / 0.1);
}

.hover\:text-\[\#E8521A\]:hover {
  --tw-text-opacity:        1;
  color:        rgb(232 82 26 / var(--tw-text-opacity, 1));
}

.hover\:text-\[\#a78bfa\]:hover {
  --tw-text-opacity:        1;
  color:        rgb(167 139 250 / var(--tw-text-opacity, 1));
}

.hover\:text-\[\#f97316\]:hover {
  --tw-text-opacity:        1;
  color:        rgb(249 115 22 / var(--tw-text-opacity, 1));
}

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

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

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

.hover\:text-amber-100:hover {
  --tw-text-opacity:        1;
  color:        rgb(254 243 199 / var(--tw-text-opacity, 1));
}

.hover\:text-amber-300:hover {
  --tw-text-opacity:        1;
  color:        rgb(252 211 77 / var(--tw-text-opacity, 1));
}

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

.hover\:text-gold\/70:hover {
  color:        rgb(var(--gold-rgb) / 0.7);
}

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

.hover\:text-ink:hover {
  color:        var(--ink);
}

.hover\:text-ink-muted:hover {
  color:        var(--ink-muted);
}

.hover\:text-ink-soft:hover {
  color:        var(--ink-soft);
}

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

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

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

.hover\:opacity-70:hover {
  opacity:        0.7;
}

.hover\:opacity-80:hover {
  opacity:        0.8;
}

.hover\:shadow-\[0_0_24px_rgba\(212\2c 175\2c 55\2c 0\.15\)\]:hover {
  --tw-shadow:        0 0 24px rgba(212,175,55,0.15);
  --tw-shadow-colored:        0 0 24px var(--tw-shadow-color);
  box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_4px_16px_rgba\(0\2c 0\2c 0\2c 0\.3\)\]:hover {
  --tw-shadow:        0 4px 16px rgba(0,0,0,0.3);
  --tw-shadow-colored:        0 4px 16px var(--tw-shadow-color);
  box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_4px_16px_rgba\(212\2c 175\2c 55\2c 0\.08\)\]:hover {
  --tw-shadow:        0 4px 16px rgba(212,175,55,0.08);
  --tw-shadow-colored:        0 4px 16px var(--tw-shadow-color);
  box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_8px_24px_rgba\(201\2c 150\2c 12\2c 0\.18\)\]:hover {
  --tw-shadow:        0 8px 24px rgba(201,150,12,0.18);
  --tw-shadow-colored:        0 8px 24px var(--tw-shadow-color);
  box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_8px_32px_rgba\(0\2c 0\2c 0\2c 0\.4\)\]:hover {
  --tw-shadow:        0 8px 32px rgba(0,0,0,0.4);
  --tw-shadow-colored:        0 8px 32px var(--tw-shadow-color);
  box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.hover\:shadow-\[0_8px_32px_rgba\(212\2c 175\2c 55\2c 0\.12\)\2c 0_2px_8px_rgba\(0\2c 0\2c 0\2c 0\.5\)\2c inset_0_1px_0_rgba\(122\2c 171\2c 138\2c 0\.1\)\]:hover {
  --tw-shadow:        0 8px 32px rgba(212,175,55,0.12),0 2px 8px rgba(0,0,0,0.5),inset 0 1px 0 rgba(122,171,138,0.1);
  --tw-shadow-colored:        0 8px 32px var(--tw-shadow-color), 0 2px 8px var(--tw-shadow-color), inset 0 1px 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);
}

.hover\:brightness-110:hover {
  --tw-brightness:        brightness(1.1);
  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);
}

.hover\:shadow-card-raised:hover {
    box-shadow:
      0 6px 24px rgba(0, 0, 0, 0.55),
      0 1px 4px rgba(0, 0, 0, 0.40),
      0 0 0 1px rgba(45, 75, 48, 0.85),
      inset 0 1px 0 rgba(122, 171, 138, 0.11);
  }

.focus\:not-sr-only:focus {
  position:        static;
  width:        auto;
  height:        auto;
  padding:        0;
  margin:        0;
  overflow:        visible;
  clip:        auto;
  white-space:        normal;
}

.focus\:fixed:focus {
  position:        fixed;
}

.focus\:left-3:focus {
  left:        0.75rem;
}

.focus\:top-3:focus {
  top:        0.75rem;
}

.focus\:z-\[100\]:focus {
  z-index:        100;
}

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

.focus\:border-\[\#c46a37\]\/70:focus {
  border-color:        rgb(196 106 55 / 0.7);
}

.focus\:border-\[\#d4af37\]\/60:focus {
  border-color:        rgb(212 175 55 / 0.6);
}

.focus\:border-\[\#d98d7c\]\/80:focus {
  border-color:        rgb(217 141 124 / 0.8);
}

.focus\:border-\[\#e0a071\]\/80:focus {
  border-color:        rgb(224 160 113 / 0.8);
}

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

.focus\:border-gold:focus {
  --tw-border-opacity:        1;
  border-color:        rgb(var(--gold-rgb) / var(--tw-border-opacity, 1));
}

.focus\:border-gold\/40:focus {
  border-color:        rgb(var(--gold-rgb) / 0.4);
}

.focus\:border-gold\/50:focus {
  border-color:        rgb(var(--gold-rgb) / 0.5);
}

.focus\:border-gold\/60:focus {
  border-color:        rgb(var(--gold-rgb) / 0.6);
}

.focus\:border-gold\/70:focus {
  border-color:        rgb(var(--gold-rgb) / 0.7);
}

.focus\:bg-bg-card:focus {
  --tw-bg-opacity:        1;
  background-color:        rgb(var(--bg-card-rgb) / var(--tw-bg-opacity, 1));
}

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

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

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

.focus\:text-ink:focus {
  color:        var(--ink);
}

.focus\:shadow-2xl:focus {
  --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);
}

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

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

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

.focus\:outline-gold:focus {
  outline-color:        var(--gold);
}

.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-\[\#c46a37\]\/15:focus {
  --tw-ring-color:        rgb(196 106 55 / 0.15);
}

.focus\:ring-\[\#d4af37\]\/20:focus {
  --tw-ring-color:        rgb(212 175 55 / 0.2);
}

.focus\:ring-\[\#d98d7c\]\/20:focus {
  --tw-ring-color:        rgb(217 141 124 / 0.2);
}

.focus\:ring-\[\#e0a071\]\/15:focus {
  --tw-ring-color:        rgb(224 160 113 / 0.15);
}

.focus\:ring-gold\/10:focus {
  --tw-ring-color:        rgb(var(--gold-rgb) / 0.1);
}

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

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

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

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

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

.focus-visible\:outline-\[\#d4af37\]:focus-visible {
  outline-color:        #d4af37;
}

.focus-visible\:outline-gold:focus-visible {
  outline-color:        var(--gold);
}

.focus-visible\:outline-gold\/60:focus-visible {
  outline-color:        rgb(var(--gold-rgb) / 0.6);
}

.focus-visible\:outline-sage\/60:focus-visible {
  outline-color:        rgb(var(--sage-rgb) / 0.6);
}

.focus-visible\:outline-terra\/60:focus-visible {
  outline-color:        rgb(var(--terra-rgb) / 0.6);
}

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

.focus-visible\:ring-inset:focus-visible {
  --tw-ring-inset:        inset;
}

.focus-visible\:ring-\[rgba\(196\2c 106\2c 55\2c 0\.6\)\]:focus-visible {
  --tw-ring-color:        rgba(196,106,55,0.6);
}

.focus-visible\:ring-gold\/50:focus-visible {
  --tw-ring-color:        rgb(var(--gold-rgb) / 0.5);
}

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

.active\:scale-95:active {
  --tw-scale-x:        .95;
  --tw-scale-y:        .95;
  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));
}

.active\:scale-\[0\.97\]:active {
  --tw-scale-x:        0.97;
  --tw-scale-y:        0.97;
  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));
}

.active\:scale-\[0\.98\]:active {
  --tw-scale-x:        0.98;
  --tw-scale-y:        0.98;
  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));
}

.active\:scale-\[0\.99\]:active {
  --tw-scale-x:        0.99;
  --tw-scale-y:        0.99;
  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));
}

.active\:cursor-grabbing:active {
  cursor:        grabbing;
}

.active\:bg-\[\#d4af37\]\/25:active {
  background-color:        rgb(212 175 55 / 0.25);
}

.enabled\:hover\:bg-gold-dim:hover:enabled {
  background-color:        var(--gold-dim);
}

.disabled\:cursor-not-allowed:disabled {
  cursor:        not-allowed;
}

.disabled\:cursor-wait:disabled {
  cursor:        wait;
}

.disabled\:opacity-25:disabled {
  opacity:        0.25;
}

.disabled\:opacity-40:disabled {
  opacity:        0.4;
}

.disabled\:opacity-45:disabled {
  opacity:        0.45;
}

.disabled\:opacity-50:disabled {
  opacity:        0.5;
}

.disabled\:opacity-60:disabled {
  opacity:        0.6;
}

.disabled\:hover\:border-border:hover:disabled {
  --tw-border-opacity:        1;
  border-color:        rgb(var(--border-rgb) / var(--tw-border-opacity, 1));
}

.disabled\:hover\:text-ink-soft:hover:disabled {
  color:        var(--ink-soft);
}

.disabled\:active\:scale-100:active:disabled {
  --tw-scale-x:        1;
  --tw-scale-y:        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\:block {
  display:        block;
}

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

.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-gold {
  --tw-text-opacity:        1;
  color:        rgb(var(--gold-rgb) / var(--tw-text-opacity, 1));
}

.group:hover .group-hover\:text-gold\/90 {
  color:        rgb(var(--gold-rgb) / 0.9);
}

.group:hover .group-hover\:text-ink-soft {
  color:        var(--ink-soft);
}

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

.group:hover .group-hover\:brightness-125 {
  --tw-brightness:        brightness(1.25);
  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);
}

@media (prefers-reduced-motion: no-preference) {

  .motion-safe\:animate-\[brand-banner-in_200ms_ease-out\] {
    animation:        brand-banner-in 200ms ease-out;
  }
}

@media (min-width: 420px) {

  .min-\[420px\]\:inline {
    display:        inline;
  }
}

@media (min-width: 640px) {

  .sm\:inset-auto {
    inset:        auto;
  }

  .sm\:bottom-\[calc\(4\.75rem_\+_env\(safe-area-inset-bottom\)\)\] {
    bottom:        calc(4.75rem + env(safe-area-inset-bottom));
  }

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

  .sm\:right-0 {
    right:        0px;
  }

  .sm\:right-6 {
    right:        1.5rem;
  }

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

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

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

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

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

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

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

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

  .sm\:block {
    display:        block;
  }

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

  .sm\:inline {
    display:        inline;
  }

  .sm\:flex {
    display:        flex;
  }

  .sm\:grid {
    display:        grid;
  }

  .sm\:hidden {
    display:        none;
  }

  .sm\:h-7 {
    height:        1.75rem;
  }

  .sm\:h-9 {
    height:        2.25rem;
  }

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

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

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

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

  .sm\:max-h-\[85vh\] {
    max-height:        85vh;
  }

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

  .sm\:w-7 {
    width:        1.75rem;
  }

  .sm\:w-9 {
    width:        2.25rem;
  }

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

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

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

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

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

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

  .sm\:max-w-\[90vw\] {
    max-width:        90vw;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .sm\:gap-2\.5 {
    gap:        0.625rem;
  }

  .sm\:gap-3 {
    gap:        0.75rem;
  }

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

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

  .sm\:self-auto {
    align-self:        auto;
  }

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

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

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

  .sm\:border-t-0 {
    border-top-width:        0px;
  }

  .sm\:border-border-mid {
    border-color:        var(--border-mid);
  }

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

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

  .sm\:p-7 {
    padding:        1.75rem;
  }

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

  .sm\:px-1\.5 {
    padding-left:        0.375rem;
    padding-right:        0.375rem;
  }

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

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

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

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

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

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

  .sm\:py-7 {
    padding-top:        1.75rem;
    padding-bottom:        1.75rem;
  }

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

  .sm\:pt-24 {
    padding-top:        6rem;
  }

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

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

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

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

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

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

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

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

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

  .sm\:text-\[0\.64rem\] {
    font-size:        0.64rem;
  }

  .sm\:text-\[1\.7rem\] {
    font-size:        1.7rem;
  }

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

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

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

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

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

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

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

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

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

  .sm\:tracking-\[0\.18em\] {
    letter-spacing:        0.18em;
  }

  .sm\:tracking-\[0\.22em\] {
    letter-spacing:        0.22em;
  }

  .sm\:tracking-\[0\.2em\] {
    letter-spacing:        0.2em;
  }

  .sm\:tracking-\[0\.32em\] {
    letter-spacing:        0.32em;
  }

  .sm\:tracking-\[0\.35em\] {
    letter-spacing:        0.35em;
  }

  .sm\:tracking-\[0\.5em\] {
    letter-spacing:        0.5em;
  }

  .sm\:shadow-\[0_24px_80px_rgba\(0\2c 0\2c 0\2c 0\.9\)\] {
    --tw-shadow:        0 24px 80px rgba(0,0,0,0.9);
    --tw-shadow-colored:        0 24px 80px var(--tw-shadow-color);
    box-shadow:        var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  }
}

@media (min-width: 768px) {

  .md\:static {
    position:        static;
  }

  .md\:left-auto {
    left:        auto;
  }

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

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

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

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

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

  .md\:block {
    display:        block;
  }

  .md\:flex {
    display:        flex;
  }

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

  .md\:grid {
    display:        grid;
  }

  .md\:hidden {
    display:        none;
  }

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

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

  .md\:max-h-\[92vh\] {
    max-height:        92vh;
  }

  .md\:w-80 {
    width:        20rem;
  }

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

  .md\:min-w-44 {
    min-width:        11rem;
  }

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

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

  .md\:grid-cols-\[3fr_2fr\] {
    grid-template-columns:        3fr 2fr;
  }

  .md\:grid-cols-\[44px_1fr_auto_auto\] {
    grid-template-columns:        44px 1fr auto auto;
  }

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

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

  .md\:place-items-center {
    place-items:        center;
  }

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

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

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

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

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

  .md\:border {
    border-width:        1px;
  }

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

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

  .md\:border-border {
    --tw-border-opacity:        1;
    border-color:        rgb(var(--border-rgb) / var(--tw-border-opacity, 1));
  }

  .md\:bg-bg-card {
    --tw-bg-opacity:        1;
    background-color:        rgb(var(--bg-card-rgb) / var(--tw-bg-opacity, 1));
  }

  .md\:bg-black\/70 {
    background-color:        rgb(0 0 0 / 0.7);
  }

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

  .md\:p-10 {
    padding:        2.5rem;
  }

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

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

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

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

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

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

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

@media (min-width: 1024px) {

  .lg\:sticky {
    position:        sticky;
  }

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

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

  .lg\:right-0 {
    right:        0px;
  }

  .lg\:top-0 {
    top:        0px;
  }

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

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

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

  .lg\:col-span-4 {
    grid-column:        span 4 / span 4;
  }

  .lg\:col-span-8 {
    grid-column:        span 8 / span 8;
  }

  .lg\:block {
    display:        block;
  }

  .lg\:inline {
    display:        inline;
  }

  .lg\:flex {
    display:        flex;
  }

  .lg\:hidden {
    display:        none;
  }

  .lg\:w-48 {
    width:        12rem;
  }

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

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

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

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

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

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

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

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

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

  .lg\:grid-cols-\[0\.9fr_1\.1fr\] {
    grid-template-columns:        0.9fr 1.1fr;
  }

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

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

  .lg\:grid-cols-\[auto_auto_1fr\] {
    grid-template-columns:        auto auto 1fr;
  }

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

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

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

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

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

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

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

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

  .lg\:\!pl-\[260px\] {
    padding-left:        260px !important;
  }

  .lg\:\!pl-\[276px\] {
    padding-left:        276px !important;
  }

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

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

  .lg\:text-7xl {
    font-size:        4.5rem;
    line-height:        1;
  }
}

@media (min-width: 1280px) {

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

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

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

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

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

  .xl\:grid-cols-\[0\.8fr_1\.2fr\] {
    grid-template-columns:        0.8fr 1.2fr;
  }

  .xl\:grid-cols-\[1\.2fr_0\.9fr\] {
    grid-template-columns:        1.2fr 0.9fr;
  }

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

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

  .xl\:grid-cols-\[minmax\(0\2c 0\.9fr\)_minmax\(0\2c 1\.1fr\)\] {
    grid-template-columns:        minmax(0,0.9fr) minmax(0,1.1fr);
  }

  .xl\:grid-cols-\[minmax\(0\2c 1fr\)_380px\] {
    grid-template-columns:        minmax(0,1fr) 380px;
  }

  .xl\:grid-cols-\[minmax\(320px\2c 0\.4fr\)_minmax\(0\2c 0\.6fr\)\] {
    grid-template-columns:        minmax(320px,0.4fr) minmax(0,0.6fr);
  }
}
