/* [project]/src/styles/globals.css [app-client] (css) */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-border-style: solid;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
    }

    ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-border-style: solid;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --spacing: .25rem;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
  }
}

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

  ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

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

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

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

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

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

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

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

  b, strong {
    font-weight: bolder;
  }

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

  small {
    font-size: 80%;
  }

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

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.5em;
  }

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

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

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

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

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

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

  ::-webkit-file-upload-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: rgba(0, 0, 0, 0);
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: rgba(0, 0, 0, 0);
    border-radius: 0;
  }

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

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

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

  :where(select:-webkit-any([multiple], [size])) optgroup option:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    padding-left: 20px;
  }

  :where(select:-moz-any([multiple], [size])) optgroup option:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    padding-left: 20px;
  }

  :where(select:is([multiple], [size])) optgroup option:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    padding-left: 20px;
  }

  :where(select:-webkit-any([multiple], [size])) optgroup option:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    padding-right: 20px;
  }

  :where(select:-moz-any([multiple], [size])) optgroup option:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    padding-right: 20px;
  }

  :where(select:is([multiple], [size])) optgroup option:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    padding-right: 20px;
  }

  :not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)))::-webkit-file-upload-button {
    margin-right: 4px;
  }

  :not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)))::file-selector-button {
    margin-right: 4px;
  }

  :not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)))::file-selector-button {
    margin-right: 4px;
  }

  :-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))::-webkit-file-upload-button {
    margin-left: 4px;
  }

  :-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))::file-selector-button {
    margin-left: 4px;
  }

  :is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))::file-selector-button {
    margin-left: 4px;
  }

  ::placeholder {
    opacity: 1;
  }

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

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

  textarea {
    resize: vertical;
  }

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

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

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

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

  ::-webkit-datetime-edit {
    padding-top: 0;
    padding-bottom: 0;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@layer components;

@layer utilities {
  .collapse {
    visibility: collapse;
  }

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .start:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: var(--spacing);
  }

  .start:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: var(--spacing);
  }

  .start:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    left: var(--spacing);
  }

  .start:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: var(--spacing);
  }

  .start:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: var(--spacing);
  }

  .start:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    right: var(--spacing);
  }

  .end:not(:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--spacing);
  }

  .end:not(:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--spacing);
  }

  .end:not(:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi))) {
    right: var(--spacing);
  }

  .end:-webkit-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--spacing);
  }

  .end:-moz-any(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--spacing);
  }

  .end:is(:lang(ae), :lang(ar), :lang(arc), :lang(bcc), :lang(bqi), :lang(ckb), :lang(dv), :lang(fa), :lang(glk), :lang(he), :lang(ku), :lang(mzn), :lang(nqo), :lang(pnb), :lang(ps), :lang(sd), :lang(ug), :lang(ur), :lang(yi)) {
    left: var(--spacing);
  }

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

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

  .table {
    display: table;
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .resize {
    resize: both;
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .italic {
    font-style: italic;
  }

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

  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

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

  .transition {
    transition-property: color, background-color, border-color, outline-color, -webkit-text-decoration-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
}

:root {
  --ex-font-sans: "Poppins", "Avenir Next", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --ex-font-serif: "Source Serif 4", "Georgia", "Times New Roman", serif;
  --ex-font-mono: "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;
  --ex-color-bg: #f7f5f2;
  --ex-color-surface: #fff;
  --ex-color-ink: #1f2328;
  --ex-color-muted: #5a646d;
  --ex-color-border: #e5e0d8;
  --ex-color-primary: #1a5b4f;
  --ex-color-primary-ink: #f7fff8;
  --ex-color-accent: #f08b4f;
  --ex-color-accent-ink: #2b1a10;
  --ex-color-info: #2f74b5;
  --ex-color-success: #2f8f5b;
  --ex-color-warning: #d07b1a;
  --ex-color-danger: #c13d3d;
  --ex-radius-xs: 6px;
  --ex-radius-sm: 10px;
  --ex-radius-md: 16px;
  --ex-radius-lg: 22px;
  --ex-shadow-xs: 0 4px 10px rgba(20, 16, 12, .08);
  --ex-shadow-sm: 0 10px 28px rgba(20, 16, 12, .12);
  --ex-shadow-md: 0 18px 44px rgba(20, 16, 12, .18);
  --ex-space-1: 4px;
  --ex-space-2: 8px;
  --ex-space-3: 12px;
  --ex-space-4: 16px;
  --ex-space-5: 20px;
  --ex-space-6: 24px;
  --ex-space-7: 32px;
  --ex-space-8: 40px;
  --ex-space-9: 56px;
  --ex-space-10: 72px;
  --ex-container: 1200px;
  --ex-gutter: 24px;
  --ex-transition: .18s ease;
}

*, :before, :after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--ex-font-sans);
  color: var(--ex-color-ink);
  background: var(--ex-color-bg);
  margin: 0;
  line-height: 1.6;
}

img, svg {
  max-width: 100%;
  display: block;
}

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

a:hover {
  color: var(--ex-color-primary);
}

button, input, select, textarea {
  font: inherit;
}

.ex-container {
  width: min(100% - 2 * var(--ex-gutter), var(--ex-container));
  margin: 0 auto;
}

.ex-section {
  padding: var(--ex-space-9) 0;
}

.ex-grid {
  gap: var(--ex-space-6);
  display: grid;
}

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

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

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

@media (max-width: 960px) {
  .ex-grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .ex-grid-2, .ex-grid-3, .ex-grid-4 {
    grid-template-columns: 1fr;
  }

  .ex-section {
    padding: var(--ex-space-7) 0;
  }
}

.ex-card {
  background: var(--ex-color-surface);
  border-radius: var(--ex-radius-md);
  box-shadow: var(--ex-shadow-xs);
  border: 1px solid var(--ex-color-border);
  padding: var(--ex-space-6);
}

.ex-pill {
  align-items: center;
  gap: var(--ex-space-2);
  color: var(--ex-color-primary);
  background: rgba(26, 91, 79, .12);
  border-radius: 999px;
  padding: 4px 12px;
  font-size: .85rem;
  font-weight: 600;
  display: inline-flex;
}

.ex-eyebrow {
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ex-color-muted);
  font-size: .78rem;
}

.ex-heading-xl {
  margin: 0 0 var(--ex-space-4);
  font-size: max(2.4rem, min(3vw + 1rem, 3.4rem));
  line-height: 1.1;
}

.ex-heading-lg {
  margin: 0 0 var(--ex-space-3);
  font-size: max(1.8rem, min(1.6vw + 1rem, 2.4rem));
}

.ex-heading-md {
  margin: 0 0 var(--ex-space-2);
  font-size: 1.35rem;
}

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

.ex-surface {
  background: var(--ex-color-surface);
}

.ex-divider {
  background: var(--ex-color-border);
  height: 1px;
  margin: var(--ex-space-6) 0;
}

.ex-hero {
  background: linear-gradient(130deg, rgba(26, 91, 79, .12), rgba(240, 139, 79, .22)), var(--ex-color-surface);
  border: 1px solid var(--ex-color-border);
  border-radius: var(--ex-radius-lg);
  box-shadow: var(--ex-shadow-sm);
  padding: max(32px, min(4vw, 56px));
}

.ex-hero-grid {
  gap: var(--ex-space-6);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  display: grid;
}

@media (max-width: 840px) {
  .ex-hero-grid {
    grid-template-columns: 1fr;
  }
}

.ex-stack {
  gap: var(--ex-space-4);
  flex-direction: column;
  display: flex;
}

.ex-inline {
  align-items: center;
  gap: var(--ex-space-2);
  display: inline-flex;
}

.ex-navbar {
  z-index: 10;
  border-bottom: 1px solid var(--ex-color-border);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  background: rgba(247, 245, 242, .92);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}

.ex-navbar-inner {
  justify-content: space-between;
  align-items: center;
  gap: var(--ex-space-6);
  padding: var(--ex-space-4) 0;
  display: flex;
}

.ex-brand {
  letter-spacing: .04em;
  font-size: 1.2rem;
  font-weight: 700;
}

.ex-brand img {
  width: auto;
  height: 28px;
  display: block;
}

.ex-nav-links {
  align-items: center;
  gap: var(--ex-space-4);
  font-weight: 500;
  display: flex;
}

.ex-nav-actions {
  align-items: center;
  gap: var(--ex-space-3);
  display: inline-flex;
}

.ex-btn {
  justify-content: center;
  align-items: center;
  gap: var(--ex-space-2);
  transition: transform var(--ex-transition), box-shadow var(--ex-transition), background var(--ex-transition);
  cursor: pointer;
  border: 1px solid rgba(0, 0, 0, 0);
  border-radius: 999px;
  padding: 10px 18px;
  font-weight: 600;
  display: inline-flex;
}

.ex-btn-primary {
  background: var(--ex-color-primary);
  color: var(--ex-color-primary-ink);
  box-shadow: var(--ex-shadow-xs);
}

.ex-btn-primary:hover {
  box-shadow: var(--ex-shadow-sm);
  transform: translateY(-1px);
}

.ex-btn-ghost {
  border-color: var(--ex-color-border);
  background: none;
}

.ex-btn-accent {
  background: var(--ex-color-accent);
  color: var(--ex-color-accent-ink);
}

.ex-badge {
  color: var(--ex-color-info);
  background: rgba(47, 116, 181, .14);
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  padding: 2px 10px;
  font-size: .75rem;
  font-weight: 600;
  display: inline-flex;
}

.ex-product-card {
  gap: var(--ex-space-4);
  padding: var(--ex-space-5);
  border-radius: var(--ex-radius-md);
  border: 1px solid var(--ex-color-border);
  background: var(--ex-color-surface);
  box-shadow: var(--ex-shadow-xs);
  display: grid;
}

.ex-product-thumb {
  border-radius: var(--ex-radius-sm);
  aspect-ratio: 4 / 3;
  background: #efe9e2;
}

.ex-price {
  font-size: 1.2rem;
  font-weight: 700;
}

.ex-price small {
  color: var(--ex-color-muted);
  margin-left: 6px;
  font-weight: 500;
}

.ex-tag {
  color: var(--ex-color-primary);
  background: rgba(26, 91, 79, .12);
  border-radius: 6px;
  align-items: center;
  padding: 2px 8px;
  font-size: .75rem;
  display: inline-flex;
}

.ex-table {
  border-collapse: collapse;
  background: var(--ex-color-surface);
  border: 1px solid var(--ex-color-border);
  border-radius: var(--ex-radius-md);
  width: 100%;
  overflow: hidden;
}

.ex-table th, .ex-table td {
  text-align: left;
  border-bottom: 1px solid var(--ex-color-border);
  padding: 12px 16px;
}

.ex-table th {
  background: rgba(26, 91, 79, .08);
  font-weight: 600;
}

.ex-form {
  gap: var(--ex-space-4);
  display: grid;
}

.ex-input, .ex-select, .ex-textarea {
  border-radius: var(--ex-radius-sm);
  border: 1px solid var(--ex-color-border);
  background: var(--ex-color-surface);
  width: 100%;
  padding: 10px 12px;
}

.ex-input:focus, .ex-select:focus, .ex-textarea:focus {
  border-color: var(--ex-color-primary);
  outline: 2px solid rgba(26, 91, 79, .2);
}

.ex-field {
  gap: 8px;
  display: grid;
}

.ex-alert {
  border-radius: var(--ex-radius-sm);
  border: 1px solid var(--ex-color-border);
  color: var(--ex-color-info);
  background: rgba(47, 116, 181, .1);
  padding: 14px 18px;
  font-weight: 500;
}

.ex-alert-success {
  color: var(--ex-color-success);
  background: rgba(47, 143, 91, .12);
}

.ex-alert-warning {
  color: var(--ex-color-warning);
  background: rgba(208, 123, 26, .14);
}

.ex-alert-danger {
  color: var(--ex-color-danger);
  background: rgba(193, 61, 61, .12);
}

.ex-tabs {
  gap: var(--ex-space-2);
  border-bottom: 1px solid var(--ex-color-border);
  display: flex;
}

.ex-tab {
  cursor: pointer;
  border-radius: var(--ex-radius-sm) var(--ex-radius-sm) 0 0;
  border-bottom: 2px solid rgba(0, 0, 0, 0);
  padding: 10px 16px;
  font-weight: 600;
  transition: background .15s, color .15s;
}

.ex-tab:hover:not(.is-active) {
  background: rgba(26, 91, 79, .04);
}

.ex-tab.is-active {
  border-bottom-color: var(--ex-color-primary);
  color: var(--ex-color-primary);
  background: rgba(26, 91, 79, .08);
}

.ex-accordion {
  border: 1px solid var(--ex-color-border);
  border-radius: var(--ex-radius-md);
  overflow: hidden;
}

.ex-accordion-item + .ex-accordion-item {
  border-top: 1px solid var(--ex-color-border);
}

.ex-accordion-header {
  background: var(--ex-color-surface);
  cursor: pointer;
  justify-content: space-between;
  padding: 16px;
  font-weight: 600;
  display: flex;
}

.ex-accordion-body {
  padding: 16px;
  display: none;
}

.ex-accordion-item.is-open .ex-accordion-body {
  display: block;
}

.ex-modal-backdrop {
  padding: var(--ex-space-6);
  z-index: 20;
  background: rgba(20, 16, 12, .45);
  justify-content: center;
  align-items: center;
  display: none;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

.ex-modal {
  background: var(--ex-color-surface);
  border-radius: var(--ex-radius-md);
  padding: var(--ex-space-6);
  width: 100%;
  max-width: 520px;
  box-shadow: var(--ex-shadow-md);
}

.ex-modal-backdrop.is-open {
  display: flex;
}

.ex-sidebar {
  background: var(--ex-color-surface);
  border: 1px solid var(--ex-color-border);
  border-radius: var(--ex-radius-md);
  padding: var(--ex-space-5);
  gap: var(--ex-space-3);
  display: grid;
}

.ex-stat {
  padding: var(--ex-space-4);
  border-radius: var(--ex-radius-sm);
  background: rgba(26, 91, 79, .08);
  gap: 4px;
  display: grid;
}

.ex-stat strong {
  font-size: 1.4rem;
}

.ex-footer {
  color: #f7f5f2;
  padding: var(--ex-space-8) 0;
  background: #1f2328;
}

.ex-footer a:hover {
  color: #f7f5f2;
  opacity: .8;
}

@media (max-width: 840px) {
  .ex-nav-links {
    display: none;
  }
}

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

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

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

.ex-mt-1 {
  margin-top: var(--ex-space-1);
}

.ex-mt-2 {
  margin-top: var(--ex-space-2);
}

.ex-mt-3 {
  margin-top: var(--ex-space-3);
}

.ex-mt-4 {
  margin-top: var(--ex-space-4);
}

.ex-mt-5 {
  margin-top: var(--ex-space-5);
}

.ex-mt-6 {
  margin-top: var(--ex-space-6);
}

.ex-mb-1 {
  margin-bottom: var(--ex-space-1);
}

.ex-mb-2 {
  margin-bottom: var(--ex-space-2);
}

.ex-mb-3 {
  margin-bottom: var(--ex-space-3);
}

.ex-mb-4 {
  margin-bottom: var(--ex-space-4);
}

.ex-mb-5 {
  margin-bottom: var(--ex-space-5);
}

.ex-mb-6 {
  margin-bottom: var(--ex-space-6);
}

.ex-p-3 {
  padding: var(--ex-space-3);
}

.ex-p-4 {
  padding: var(--ex-space-4);
}

.ex-p-5 {
  padding: var(--ex-space-5);
}

.ex-flex {
  display: flex;
}

.ex-flex-between {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.ex-flex-center {
  justify-content: center;
  align-items: center;
  display: flex;
}

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

.ex-gap-2 {
  gap: var(--ex-space-2);
}

.ex-gap-3 {
  gap: var(--ex-space-3);
}

.ex-gap-4 {
  gap: var(--ex-space-4);
}

.ex-bg-surface {
  background: var(--ex-color-surface);
}

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

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

.ex-radius-sm {
  border-radius: var(--ex-radius-sm);
}

.ex-radius-md {
  border-radius: var(--ex-radius-md);
}

.ex-shadow-xs {
  box-shadow: var(--ex-shadow-xs);
}

.ex-shadow-sm {
  box-shadow: var(--ex-shadow-sm);
}

.ex-hidden {
  display: none;
}

@media (max-width: 720px) {
  .ex-hide-mobile {
    display: none;
  }
}

:root {
  --ex-brand-navy: #22304f;
  --ex-brand-navy-light: #344569;
  --ex-brand-navy-dark: #161f35;
  --ex-brand-navy-ink: #f5f7ff;
  --ex-brand-red: #fc414a;
  --ex-brand-red-light: #ff7880;
  --ex-brand-red-dark: #d42832;
  --ex-brand-red-ink: #fff;
  --ex-brand-gray-80: #333;
  --ex-brand-gray-60: #666;
  --ex-brand-gray-30: #b3b3b3;
  --ex-brand-orange: #ff8022;
  --ex-brand-green: #00946b;
  --ex-brand-purple: #8e0070;
  --ex-brand-blue: #006097;
  --ex-color-bg: #f4f6fb;
  --ex-color-surface: #fff;
  --ex-color-ink: var(--ex-brand-navy-dark);
  --ex-color-muted: var(--ex-brand-gray-60);
  --ex-color-border: #dde3ef;
  --ex-color-primary: var(--ex-brand-navy);
  --ex-color-primary-ink: var(--ex-brand-navy-ink);
  --ex-color-accent: var(--ex-brand-red);
  --ex-color-accent-ink: var(--ex-brand-red-ink);
  --ex-color-info: var(--ex-brand-blue);
  --ex-color-success: var(--ex-brand-green);
  --ex-color-warning: var(--ex-brand-orange);
  --ex-color-danger: var(--ex-brand-red);
  --ex-font-sans: "Noto Sans JP", "Kozuka Gothic Pro", "Hiragino Kaku Gothic ProN", "Meiryo UI", "Meiryo", Arial, "Helvetica Neue", sans-serif;
  --ex-font-serif: "Source Serif 4", "Georgia", serif;
  --ex-font-mono: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;
  --ex-logo-width: 140px;
  --ex-logo-width-min: 80px;
  --ex-logo-width-jp: 165px;
  --ex-brand-gradient: linear-gradient(135deg, var(--ex-brand-navy-dark) 0%, var(--ex-brand-navy) 60%, var(--ex-brand-navy-light) 100%);
  --ex-globe-gradient: radial-gradient(ellipse at 30% 30%, rgba(255, 128, 34, .7) 0%, rgba(0, 96, 151, .9) 60%, #22304f 100%);
}

.ex-navbar {
  background: rgba(244, 246, 251, .94);
}

.ex-navbar--dark {
  color: var(--ex-brand-navy-ink);
  background: rgba(22, 31, 53, .96);
  border-bottom-color: rgba(255, 255, 255, .1);
}

.ex-navbar--dark .ex-nav-links a:hover {
  color: var(--ex-brand-red);
}

.ex-hero--brand {
  background: var(--ex-brand-gradient);
  color: var(--ex-brand-navy-ink);
  border: none;
}

.ex-hero--brand .ex-heading-xl, .ex-hero--brand .ex-heading-lg {
  color: #fff;
}

.ex-hero--brand .ex-text-muted {
  color: rgba(245, 247, 255, .7);
}

.ex-btn-brand {
  background: var(--ex-brand-red);
  color: var(--ex-brand-red-ink);
  box-shadow: var(--ex-shadow-xs);
}

.ex-btn-brand:hover {
  background: var(--ex-brand-red-dark);
  box-shadow: var(--ex-shadow-sm);
  transform: translateY(-1px);
}

.ex-btn-outline {
  border: 1.5px solid var(--ex-brand-navy);
  color: var(--ex-brand-navy);
  background: none;
}

.ex-btn-outline:hover {
  background: var(--ex-brand-navy);
  color: var(--ex-brand-navy-ink);
}

.ex-badge--dc {
  color: #c05800;
  background: rgba(255, 128, 34, .14);
}

.ex-badge--macs, .ex-badge--proj {
  color: var(--ex-brand-purple);
  background: rgba(142, 0, 112, .12);
}

.ex-badge--bi {
  color: var(--ex-brand-blue);
  background: rgba(0, 96, 151, .12);
}

.ex-badge--cloud {
  color: #006d4e;
  background: rgba(0, 148, 107, .12);
}

.ex-badge--gene {
  color: var(--ex-brand-red-dark);
  background: rgba(252, 65, 74, .12);
}

.ex-footer {
  background: var(--ex-brand-navy-dark);
  color: var(--ex-brand-navy-ink);
}

.ex-footer .ex-brand {
  color: #fff;
}

.ex-highlight--red {
  color: var(--ex-brand-red);
}

.ex-globe-dot {
  background: var(--ex-brand-red);
  border-radius: 50%;
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  display: inline-block;
}

:root {
  --ex-brand-camp: #00946b;
  --ex-brand-camp-light: #2fb88a;
  --ex-brand-camp-dark: #006d4e;
  --ex-brand-camp-ink: #fff;
  --ex-color-primary: var(--ex-brand-camp);
  --ex-color-primary-ink: var(--ex-brand-camp-ink);
  --ex-color-bg: #f2f8f5;
  --ex-color-border: #d4e8df;
}

body .ex-navbar {
  background: rgba(242, 248, 245, .94);
}

.ex-pill {
  color: var(--ex-brand-camp);
  background: rgba(0, 148, 107, .1);
}

.ex-highlight {
  color: var(--ex-brand-camp);
}

.ex-footer {
  background: var(--ex-brand-camp-dark);
}

@keyframes ex-spin {
  to {
    transform: rotate(360deg);
  }
}

.ex-spinner {
  vertical-align: middle;
  border: 2px solid;
  border-right-color: rgba(0, 0, 0, 0);
  border-radius: 50%;
  width: 16px;
  height: 16px;
  animation: .6s linear infinite ex-spin;
  display: inline-block;
}

.ex-spinner-lg {
  border-width: 3px;
  width: 24px;
  height: 24px;
}

@keyframes ex-like-pop {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.3);
  }

  100% {
    transform: scale(1);
  }
}

.ex-like-pop {
  animation: .3s ease-out ex-like-pop;
}

@keyframes ex-highlight-flash {
  0% {
    background-color: var(--ex-color-success);
    opacity: .15;
  }

  100% {
    opacity: 1;
    background-color: rgba(0, 0, 0, 0);
  }
}

.ex-highlight-flash {
  animation: .6s ease-out ex-highlight-flash;
}

.camp-tabs-pc {
  border-bottom: 1px solid var(--ex-color-border);
  z-index: 500;
  background: #fff;
  position: relative;
}

.camp-tab-list {
  align-items: center;
  gap: 0;
  display: flex;
}

.camp-tab-item {
  color: #666;
  white-space: nowrap;
  border-bottom: 2px solid rgba(0, 0, 0, 0);
  padding: 12px 14px;
  font-size: .9rem;
  text-decoration: none;
  transition: color .15s, border-color .15s;
}

.camp-tab-item:hover {
  color: var(--ex-brand-camp);
}

.camp-tab-active {
  color: var(--ex-brand-camp);
  border-bottom-color: var(--ex-brand-camp);
  font-weight: 600;
}

.camp-more-menu-pc {
  margin-left: auto;
  position: relative;
}

.camp-more-summary-pc {
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  background: none;
  border: none;
  color: #999 !important;
  border-bottom: none !important;
  font-size: .85rem !important;
}

.camp-more-summary-pc:hover {
  color: var(--ex-brand-camp) !important;
}

.camp-more-dropdown-pc {
  border: 1px solid var(--ex-color-border);
  z-index: 200;
  background: #fff;
  border-radius: 8px;
  min-width: 160px;
  padding: 4px 0;
  position: absolute;
  top: 100%;
  right: 0;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .1);
}

.camp-bottom-nav {
  border-top: 1px solid var(--ex-color-border);
  z-index: 100;
  padding: 4px 0 env(safe-area-inset-bottom, 0);
  background: #fff;
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
}

.camp-bottom-nav-item {
  color: #999;
  flex-direction: column;
  flex: 1;
  align-items: center;
  gap: 2px;
  padding: 6px 0;
  font-size: .7rem;
  text-decoration: none;
  display: flex;
}

.camp-bottom-nav-active {
  color: var(--ex-brand-camp);
}

.camp-bottom-nav-icon {
  font-size: 1.2rem;
}

.camp-bottom-nav-label {
  line-height: 1;
}

.camp-more-menu {
  position: relative;
}

.camp-more-dropdown {
  border: 1px solid var(--ex-color-border);
  background: #fff;
  border-radius: 8px;
  min-width: 140px;
  margin-bottom: 8px;
  padding: 4px 0;
  position: absolute;
  bottom: 100%;
  right: 0;
  box-shadow: 0 -4px 16px rgba(0, 0, 0, .1);
}

.camp-more-item {
  color: #333;
  padding: 10px 16px;
  font-size: .85rem;
  text-decoration: none;
  display: block;
}

.camp-more-item:hover {
  background: var(--ex-color-bg);
}

.camp-main {
  padding-bottom: 20px;
}

@media (max-width: 768px) {
  .camp-tabs-pc {
    display: none;
  }

  .camp-bottom-nav {
    display: flex;
  }

  .camp-main {
    padding-bottom: 80px;
  }

  .chat-container {
    height: calc(100vh - 270px);
  }
}

.camp-card {
  border: 1px solid var(--ex-color-border);
  color: inherit;
  background: #fff;
  border-radius: 12px;
  padding: 20px;
  text-decoration: none;
  transition: box-shadow .15s;
  display: block;
}

.camp-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, .08);
}

.camp-card-title {
  margin-bottom: 4px;
  font-size: 1.1rem;
  font-weight: 600;
}

.camp-card-date {
  color: #888;
  font-size: .85rem;
}

.camp-card-members {
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 8px;
  display: flex;
}

.camp-status {
  border-radius: 12px;
  padding: 2px 8px;
  font-size: .75rem;
  font-weight: 500;
  display: inline-block;
}

.camp-status-planning {
  color: #0277bd;
  background: #e0f2fe;
}

.camp-status-site_decided {
  color: #2e7d32;
  background: #e8f5e9;
}

.camp-status-reserved {
  color: #e65100;
  background: #fff3e0;
}

.camp-status-ongoing {
  color: #c62828;
  background: #fce4ec;
}

.camp-status-completed {
  color: #6a1b9a;
  background: #f3e5f5;
}

.camp-grid {
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: 16px;
  display: grid;
}

.vote-bar {
  background: #e0e0e0;
  border-radius: 3px;
  height: 6px;
  margin-top: 4px;
  overflow: hidden;
}

.vote-bar-fill {
  background: var(--ex-brand-camp);
  border-radius: 3px;
  height: 100%;
  transition: width .3s;
}

.chat-container {
  flex-direction: column;
  height: calc(100vh - 200px);
  display: flex;
}

.chat-messages {
  flex: 1;
  padding: 16px 0;
  overflow-y: auto;
}

.chat-bubble {
  border-radius: 16px;
  max-width: 70%;
  margin-bottom: 8px;
  padding: 10px 14px;
  font-size: .9rem;
  line-height: 1.4;
}

.chat-bubble-mine {
  background: var(--ex-brand-camp);
  color: #fff;
  border-bottom-right-radius: 4px;
  margin-left: auto;
}

.chat-bubble-other {
  color: #333;
  background: #e8e8e8;
  border-bottom-left-radius: 4px;
}

.chat-sender {
  color: #888;
  margin-bottom: 2px;
  font-size: .75rem;
}

.chat-time {
  color: #aaa;
  margin-top: 2px;
  font-size: .7rem;
}

.chat-input-area {
  border-top: 1px solid var(--ex-color-border);
  gap: 8px;
  padding: 12px 0;
  display: flex;
}

.chat-input-area input {
  flex: 1;
}

.photo-grid {
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 8px;
  display: grid;
}

.photo-grid-item {
  aspect-ratio: 1;
  cursor: pointer;
  border-radius: 8px;
  position: relative;
  overflow: hidden;
}

.photo-grid-item img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: transform .2s;
}

.photo-grid-item:hover img {
  transform: scale(1.05);
}

.settlement-card {
  border: 1px solid var(--ex-color-border);
  background: #fff;
  border-radius: 12px;
  padding: 16px;
}

.settlement-arrow {
  border-bottom: 1px solid #f0f0f0;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  display: flex;
}

.settlement-amount {
  color: var(--ex-brand-camp);
  font-size: 1.1rem;
  font-weight: 700;
}

.modal-overlay {
  z-index: 200;
  background: rgba(0, 0, 0, .4);
  justify-content: center;
  align-items: center;
  padding: 16px;
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

.modal-content {
  background: #fff;
  border-radius: 16px;
  width: 100%;
  max-width: 500px;
  max-height: 90vh;
  padding: 24px;
  overflow-y: auto;
}

@keyframes ex-pulse {
  0%, 100% {
    opacity: 1;
  }

  50% {
    opacity: .5;
  }
}

.ex-pulse {
  animation: 1.5s ease-in-out infinite ex-pulse;
}

@keyframes ex-toast-in {
  from {
    opacity: 0;
    transform: translateY(100%);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes ex-toast-out {
  from {
    opacity: 1;
    transform: translateY(0);
  }

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

.ex-toast-enter {
  animation: .25s ease-out forwards ex-toast-in;
}

.ex-toast-exit {
  animation: .2s ease-in forwards ex-toast-out;
}

@property --tw-rotate-x {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-y {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-z {
  syntax: "*";
  inherits: false
}

@property --tw-skew-x {
  syntax: "*";
  inherits: false
}

@property --tw-skew-y {
  syntax: "*";
  inherits: false
}

@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

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

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

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

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

@property --tw-hue-rotate {
  syntax: "*";
  inherits: false
}

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

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

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

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

@property --tw-drop-shadow {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false
}

/*# sourceMappingURL=src_styles_globals_47180df9.css.map*/