/* [project]/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, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-space-x-reverse: 0;
      --tw-divide-y-reverse: 0;
      --tw-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-ordinal: initial;
      --tw-slashed-zero: initial;
      --tw-numeric-figure: initial;
      --tw-numeric-spacing: initial;
      --tw-numeric-fraction: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --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;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: 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;
    --color-red-700: #bf000f;
    --color-neutral-100: #f5f5f5;
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-xs: 20rem;
    --container-sm: 24rem;
    --container-md: 28rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-5xl: 64rem;
    --container-6xl: 72rem;
    --container-7xl: 80rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --tracking-wide: .025em;
    --tracking-wider: .05em;
    --tracking-widest: .1em;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;
    --radius-sm: .25rem;
    --radius-md: .375rem;
    --radius-lg: .5rem;
    --radius-xl: .75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --shadow-sm: 0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;
    --shadow-md: 0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;
    --shadow-lg: 0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;
    --shadow-xl: 0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;
    --shadow-2xl: 0 25px 50px -12px #00000040;
    --ease-out: cubic-bezier(0, 0, .2, 1);
    --animate-spin: spin 1s linear infinite;
    --blur-sm: 8px;
    --blur-3xl: 64px;
    --aspect-video: 16 / 9;
    --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);
    --color-primary-50: #eef7f6;
    --color-primary-100: #d2ecea;
    --color-primary-200: #a4d8d5;
    --color-primary-300: #6fbeba;
    --color-primary-400: #3da19d;
    --color-primary-500: #1a8e8c;
    --color-primary-600: #0e7c7b;
    --color-primary-700: #0a6362;
    --color-primary-800: #084b4a;
    --color-primary-900: #063736;
    --color-secondary-50: #faf7f2;
    --color-secondary-100: #f2ede3;
    --color-secondary-200: #e5dfd5;
    --color-secondary-300: #d3cabb;
    --color-secondary-400: #9a9188;
    --color-secondary-500: #6b645c;
    --color-secondary-600: #4a4540;
    --color-secondary-700: #36322d;
    --color-secondary-800: #2d2a26;
    --color-secondary-900: #1f1c17;
    --color-accent-50: #fbf5e8;
    --color-accent-100: #f6e7c1;
    --color-accent-200: #ecce8c;
    --color-accent-300: #e0b566;
    --color-accent-400: #daab59;
    --color-accent-500: #d4a24c;
    --color-accent-600: #b5863a;
    --color-accent-700: #8e6829;
    --color-heritage-50: #eaf6f5;
    --color-heritage-100: #cce9e7;
    --color-heritage-200: #9dd6d2;
    --color-heritage-300: #6fc3be;
    --color-heritage-400: #54b9b3;
    --color-heritage-500: #3bafa9;
    --color-heritage-600: #2e938e;
    --color-heritage-700: #247471;
    --color-celebration-100: #f2dcdd;
    --color-celebration-500: #a63d40;
    --color-celebration-600: #8a2e31;
    --color-celebration-700: #5c2628;
    --color-surface-background: #faf7f2;
    --color-surface-card: #fff;
    --color-surface-sunken: #f2ede3;
    --color-surface-overlay: #1f1c178c;
  }

  @supports (color: lab(0% 0 0)) {
    :root, :host {
      --color-red-700: lab(40.4273% 67.2623 53.7441);
      --color-neutral-100: lab(96.52% -.0000298023 .0000119209);
    }
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    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%;
    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: #0000;
    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: #0000;
    border-radius: 0;
  }

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

  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  ::file-selector-button {
    margin-inline-end: 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-block: 0;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  :root {
    --brand-teal: #0e7c7b;
    --brand-turquoise: #3bafa9;
    --brand-saffron: #d4a24c;
    --brand-pomegranate: #a63d40;
    --brand-stone-bg: #faf7f2;
    --brand-stone-dark: #1f1c17;
    --brand-ink: #2d2a26;
    --brand-ink-muted: #6b645c;
    --brand-divider: #e5dfd5;
    --brand-success: #2e8b6f;
    --brand-warning: #c8892e;
    --brand-error: #b33a3a;
  }
}

@layer components;

@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }

  .collapse {
    visibility: collapse;
  }

  .invisible {
    visibility: hidden;
  }

  .visible {
    visibility: visible;
  }

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

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .static {
    position: static;
  }

  .sticky {
    position: sticky;
  }

  .-inset-1\.5 {
    inset: calc(var(--spacing) * -1.5);
  }

  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }

  .inset-x-0 {
    inset-inline: calc(var(--spacing) * 0);
  }

  .-start-6 {
    inset-inline-start: calc(var(--spacing) * -6);
  }

  .start-0 {
    inset-inline-start: calc(var(--spacing) * 0);
  }

  .start-6 {
    inset-inline-start: calc(var(--spacing) * 6);
  }

  .start-\[-10\%\] {
    inset-inline-start: -10%;
  }

  .-end-1 {
    inset-inline-end: calc(var(--spacing) * -1);
  }

  .end-0 {
    inset-inline-end: calc(var(--spacing) * 0);
  }

  .end-3 {
    inset-inline-end: calc(var(--spacing) * 3);
  }

  .end-\[-12\%\] {
    inset-inline-end: -12%;
  }

  .-top-1 {
    top: calc(var(--spacing) * -1);
  }

  .-top-3 {
    top: calc(var(--spacing) * -3);
  }

  .-top-24 {
    top: calc(var(--spacing) * -24);
  }

  .-top-32 {
    top: calc(var(--spacing) * -32);
  }

  .top-0 {
    top: calc(var(--spacing) * 0);
  }

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

  .top-3 {
    top: calc(var(--spacing) * 3);
  }

  .top-24 {
    top: calc(var(--spacing) * 24);
  }

  .right-0 {
    right: calc(var(--spacing) * 0);
  }

  .-bottom-24 {
    bottom: calc(var(--spacing) * -24);
  }

  .bottom-6 {
    bottom: calc(var(--spacing) * 6);
  }

  .bottom-10 {
    bottom: calc(var(--spacing) * 10);
  }

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

  .isolate {
    isolation: isolate;
  }

  .-z-10 {
    z-index: calc(10 * -1);
  }

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

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

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

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

  .order-first {
    order: -9999;
  }

  .float-start {
    float: inline-start;
  }

  .container {
    width: 100%;
  }

  @media (min-width: 40rem) {
    .container {
      max-width: 40rem;
    }
  }

  @media (min-width: 48rem) {
    .container {
      max-width: 48rem;
    }
  }

  @media (min-width: 64rem) {
    .container {
      max-width: 64rem;
    }
  }

  @media (min-width: 80rem) {
    .container {
      max-width: 80rem;
    }
  }

  @media (min-width: 96rem) {
    .container {
      max-width: 96rem;
    }
  }

  .-mx-4 {
    margin-inline: calc(var(--spacing) * -4);
  }

  .-mx-6 {
    margin-inline: calc(var(--spacing) * -6);
  }

  .mx-3 {
    margin-inline: calc(var(--spacing) * 3);
  }

  .mx-auto {
    margin-inline: auto;
  }

  .my-1 {
    margin-block: calc(var(--spacing) * 1);
  }

  .my-2 {
    margin-block: calc(var(--spacing) * 2);
  }

  .my-3 {
    margin-block: calc(var(--spacing) * 3);
  }

  .my-4 {
    margin-block: calc(var(--spacing) * 4);
  }

  .my-6 {
    margin-block: calc(var(--spacing) * 6);
  }

  .my-8 {
    margin-block: calc(var(--spacing) * 8);
  }

  .my-10 {
    margin-block: calc(var(--spacing) * 10);
  }

  .my-12 {
    margin-block: calc(var(--spacing) * 12);
  }

  .-ms-5 {
    margin-inline-start: calc(var(--spacing) * -5);
  }

  .ms-1 {
    margin-inline-start: calc(var(--spacing) * 1);
  }

  .ms-4 {
    margin-inline-start: calc(var(--spacing) * 4);
  }

  .ms-\[12px\] {
    margin-inline-start: 12px;
  }

  .ms-auto {
    margin-inline-start: auto;
  }

  .me-1 {
    margin-inline-end: calc(var(--spacing) * 1);
  }

  .me-2 {
    margin-inline-end: calc(var(--spacing) * 2);
  }

  .mt-0\.5 {
    margin-top: calc(var(--spacing) * .5);
  }

  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }

  .mt-1\.5 {
    margin-top: calc(var(--spacing) * 1.5);
  }

  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }

  .mt-2\.5 {
    margin-top: calc(var(--spacing) * 2.5);
  }

  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }

  .mt-3\.5 {
    margin-top: calc(var(--spacing) * 3.5);
  }

  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }

  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }

  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }

  .mt-7 {
    margin-top: calc(var(--spacing) * 7);
  }

  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }

  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }

  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }

  .mt-24 {
    margin-top: calc(var(--spacing) * 24);
  }

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

  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }

  .mb-1\.5 {
    margin-bottom: calc(var(--spacing) * 1.5);
  }

  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }

  .mb-3\.5 {
    margin-bottom: calc(var(--spacing) * 3.5);
  }

  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }

  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }

  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }

  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }

  .mb-10 {
    margin-bottom: calc(var(--spacing) * 10);
  }

  .mb-16 {
    margin-bottom: calc(var(--spacing) * 16);
  }

  .mb-20 {
    margin-bottom: calc(var(--spacing) * 20);
  }

  .ml-4 {
    margin-left: calc(var(--spacing) * 4);
  }

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

  .block {
    display: block;
  }

  .contents {
    display: contents;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .inline {
    display: inline;
  }

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

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

  .list-item {
    display: list-item;
  }

  .table {
    display: table;
  }

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

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

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

  .aspect-video {
    aspect-ratio: var(--aspect-video);
  }

  .size-1\.5 {
    width: calc(var(--spacing) * 1.5);
    height: calc(var(--spacing) * 1.5);
  }

  .size-4 {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }

  .size-10 {
    width: calc(var(--spacing) * 10);
    height: calc(var(--spacing) * 10);
  }

  .size-12 {
    width: calc(var(--spacing) * 12);
    height: calc(var(--spacing) * 12);
  }

  .size-14 {
    width: calc(var(--spacing) * 14);
    height: calc(var(--spacing) * 14);
  }

  .size-20 {
    width: calc(var(--spacing) * 20);
    height: calc(var(--spacing) * 20);
  }

  .size-\[30px\] {
    width: 30px;
    height: 30px;
  }

  .size-\[88px\] {
    width: 88px;
    height: 88px;
  }

  .h-1 {
    height: calc(var(--spacing) * 1);
  }

  .h-1\.5 {
    height: calc(var(--spacing) * 1.5);
  }

  .h-2 {
    height: calc(var(--spacing) * 2);
  }

  .h-4 {
    height: calc(var(--spacing) * 4);
  }

  .h-5 {
    height: calc(var(--spacing) * 5);
  }

  .h-8 {
    height: calc(var(--spacing) * 8);
  }

  .h-9 {
    height: calc(var(--spacing) * 9);
  }

  .h-10 {
    height: calc(var(--spacing) * 10);
  }

  .h-11 {
    height: calc(var(--spacing) * 11);
  }

  .h-12 {
    height: calc(var(--spacing) * 12);
  }

  .h-14 {
    height: calc(var(--spacing) * 14);
  }

  .h-16 {
    height: calc(var(--spacing) * 16);
  }

  .h-20 {
    height: calc(var(--spacing) * 20);
  }

  .h-24 {
    height: calc(var(--spacing) * 24);
  }

  .h-28 {
    height: calc(var(--spacing) * 28);
  }

  .h-32 {
    height: calc(var(--spacing) * 32);
  }

  .h-40 {
    height: calc(var(--spacing) * 40);
  }

  .h-48 {
    height: calc(var(--spacing) * 48);
  }

  .h-72 {
    height: calc(var(--spacing) * 72);
  }

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

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

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

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

  .h-full {
    height: 100%;
  }

  .h-px {
    height: 1px;
  }

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

  .min-h-14 {
    min-height: calc(var(--spacing) * 14);
  }

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

  .w-1\.5 {
    width: calc(var(--spacing) * 1.5);
  }

  .w-2 {
    width: calc(var(--spacing) * 2);
  }

  .w-4 {
    width: calc(var(--spacing) * 4);
  }

  .w-5 {
    width: calc(var(--spacing) * 5);
  }

  .w-6 {
    width: calc(var(--spacing) * 6);
  }

  .w-8 {
    width: calc(var(--spacing) * 8);
  }

  .w-9 {
    width: calc(var(--spacing) * 9);
  }

  .w-10 {
    width: calc(var(--spacing) * 10);
  }

  .w-12 {
    width: calc(var(--spacing) * 12);
  }

  .w-14 {
    width: calc(var(--spacing) * 14);
  }

  .w-16 {
    width: calc(var(--spacing) * 16);
  }

  .w-20 {
    width: calc(var(--spacing) * 20);
  }

  .w-28 {
    width: calc(var(--spacing) * 28);
  }

  .w-72 {
    width: calc(var(--spacing) * 72);
  }

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

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

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

  .w-full {
    width: 100%;
  }

  .max-w-2xl {
    max-width: var(--container-2xl);
  }

  .max-w-3xl {
    max-width: var(--container-3xl);
  }

  .max-w-5xl {
    max-width: var(--container-5xl);
  }

  .max-w-6xl {
    max-width: var(--container-6xl);
  }

  .max-w-7xl {
    max-width: var(--container-7xl);
  }

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

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

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

  .max-w-\[calc\(100vw-7rem\)\] {
    max-width: calc(100vw - 7rem);
  }

  .max-w-md {
    max-width: var(--container-md);
  }

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

  .max-w-sm {
    max-width: var(--container-sm);
  }

  .max-w-xl {
    max-width: var(--container-xl);
  }

  .max-w-xs {
    max-width: var(--container-xs);
  }

  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }

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

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

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

  .flex-1 {
    flex: 1;
  }

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

  .shrink {
    flex-shrink: 1;
  }

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

  .-translate-x-1\/2 {
    --tw-translate-x: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .rotate-45 {
    rotate: 45deg;
  }

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

  .animate-spin {
    animation: var(--animate-spin);
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .resize {
    resize: both;
  }

  .resize-y {
    resize: vertical;
  }

  .scroll-mt-24 {
    scroll-margin-top: calc(var(--spacing) * 24);
  }

  .scrollbar-thin {
    scrollbar-width: thin;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .gap-0\.5 {
    gap: calc(var(--spacing) * .5);
  }

  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }

  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  .gap-2\.5 {
    gap: calc(var(--spacing) * 2.5);
  }

  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }

  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }

  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }

  .gap-8 {
    gap: calc(var(--spacing) * 8);
  }

  .gap-10 {
    gap: calc(var(--spacing) * 10);
  }

  .gap-23 {
    gap: calc(var(--spacing) * 23);
  }

  :where(.space-y-0\.5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * .5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * .5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-1\.5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-2 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-3 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-4 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-6 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-8 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)));
  }

  .gap-x-6 {
    column-gap: calc(var(--spacing) * 6);
  }

  :where(.-space-x-3 > :not(:last-child)) {
    --tw-space-x-reverse: 0;
    margin-inline-start: calc(calc(var(--spacing) * -3) * var(--tw-space-x-reverse));
    margin-inline-end: calc(calc(var(--spacing) * -3) * calc(1 - var(--tw-space-x-reverse)));
  }

  .gap-y-3 {
    row-gap: calc(var(--spacing) * 3);
  }

  :where(.divide-y > :not(:last-child)) {
    --tw-divide-y-reverse: 0;
    border-bottom-style: var(--tw-border-style);
    border-top-style: var(--tw-border-style);
    border-top-width: calc(1px * var(--tw-divide-y-reverse));
    border-bottom-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
  }

  :where(.divide-\[var\(--color-secondary-100\)\] > :not(:last-child)) {
    border-color: var(--color-secondary-100);
  }

  :where(.divide-secondary-100 > :not(:last-child)) {
    border-color: var(--color-secondary-100);
  }

  :where(.divide-secondary-200 > :not(:last-child)) {
    border-color: var(--color-secondary-200);
  }

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

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

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

  .overflow-auto {
    overflow: auto;
  }

  .overflow-hidden {
    overflow: hidden;
  }

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

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

  .rounded {
    border-radius: .25rem;
  }

  .rounded-2xl {
    border-radius: var(--radius-2xl);
  }

  .rounded-3xl {
    border-radius: var(--radius-3xl);
  }

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

  .rounded-full {
    border-radius: 3.40282e38px;
  }

  .rounded-lg {
    border-radius: var(--radius-lg);
  }

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

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

  .rounded-xl {
    border-radius: var(--radius-xl);
  }

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

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

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

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

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

  .border-s-2 {
    border-inline-start-style: var(--tw-border-style);
    border-inline-start-width: 2px;
  }

  .border-s-4 {
    border-inline-start-style: var(--tw-border-style);
    border-inline-start-width: 4px;
  }

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

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

  .border-t-2 {
    border-top-style: var(--tw-border-style);
    border-top-width: 2px;
  }

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

  .border-r-2 {
    border-right-style: var(--tw-border-style);
    border-right-width: 2px;
  }

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

  .border-b-2 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 2px;
  }

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

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

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

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

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

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

  .border-accent-200 {
    border-color: var(--color-accent-200);
  }

  .border-accent-500 {
    border-color: var(--color-accent-500);
  }

  .border-accent-500\/40 {
    border-color: #d4a24c66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-accent-500\/40 {
      border-color: color-mix(in oklab, var(--color-accent-500) 40%, transparent);
    }
  }

  .border-heritage-200 {
    border-color: var(--color-heritage-200);
  }

  .border-primary-200 {
    border-color: var(--color-primary-200);
  }

  .border-primary-300 {
    border-color: var(--color-primary-300);
  }

  .border-primary-400 {
    border-color: var(--color-primary-400);
  }

  .border-secondary-100 {
    border-color: var(--color-secondary-100);
  }

  .border-secondary-200 {
    border-color: var(--color-secondary-200);
  }

  .border-secondary-300 {
    border-color: var(--color-secondary-300);
  }

  .border-white\/40 {
    border-color: #fff6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-white\/40 {
      border-color: color-mix(in oklab, var(--color-white) 40%, transparent);
    }
  }

  .bg-\[\#0E7C7B\] {
    background-color: #0e7c7b;
  }

  .bg-\[\#FAF7F2\] {
    background-color: #faf7f2;
  }

  .bg-\[\#FF00FF\] {
    background-color: #f0f;
  }

  .bg-\[\#hex\] {
    background-color: #hex;
  }

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

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

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

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

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

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

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

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

  @supports (color: color-mix(in lab, red, red)) {
    .bg-\[var\(--color-semantic-error-50\)\]\/40 {
      background-color: color-mix(in oklab, var(--color-semantic-error-50) 40%, transparent);
    }
  }

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

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

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

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

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

  .bg-accent-50\/40 {
    background-color: #fbf5e866;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-accent-50\/40 {
      background-color: color-mix(in oklab, var(--color-accent-50) 40%, transparent);
    }
  }

  .bg-accent-50\/60 {
    background-color: #fbf5e899;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-accent-50\/60 {
      background-color: color-mix(in oklab, var(--color-accent-50) 60%, transparent);
    }
  }

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

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

  .bg-accent-500\/10 {
    background-color: #d4a24c1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-accent-500\/10 {
      background-color: color-mix(in oklab, var(--color-accent-500) 10%, transparent);
    }
  }

  .bg-black\/40 {
    background-color: #0006;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/40 {
      background-color: color-mix(in oklab, var(--color-black) 40%, transparent);
    }
  }

  .bg-celebration-100 {
    background-color: var(--color-celebration-100);
  }

  .bg-heritage-50 {
    background-color: var(--color-heritage-50);
  }

  .bg-heritage-100 {
    background-color: var(--color-heritage-100);
  }

  .bg-heritage-200 {
    background-color: var(--color-heritage-200);
  }

  .bg-heritage-300 {
    background-color: var(--color-heritage-300);
  }

  .bg-heritage-500 {
    background-color: var(--color-heritage-500);
  }

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

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

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

  .bg-secondary-50 {
    background-color: var(--color-secondary-50);
  }

  .bg-secondary-100 {
    background-color: var(--color-secondary-100);
  }

  .bg-secondary-200 {
    background-color: var(--color-secondary-200);
  }

  .bg-secondary-900 {
    background-color: var(--color-secondary-900);
  }

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

  .bg-surface-background\/95 {
    background-color: #faf7f2f2;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-surface-background\/95 {
      background-color: color-mix(in oklab, var(--color-surface-background) 95%, transparent);
    }
  }

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

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

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

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

  .bg-white\/15 {
    background-color: #ffffff26;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-white\/15 {
      background-color: color-mix(in oklab, var(--color-white) 15%, transparent);
    }
  }

  .bg-white\/25 {
    background-color: #ffffff40;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-white\/25 {
      background-color: color-mix(in oklab, var(--color-white) 25%, transparent);
    }
  }

  .bg-gradient-to-br {
    --tw-gradient-position: to bottom right in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }

  .from-accent-400 {
    --tw-gradient-from: var(--color-accent-400);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .from-heritage-400 {
    --tw-gradient-from: var(--color-heritage-400);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .from-primary-400 {
    --tw-gradient-from: var(--color-primary-400);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .from-secondary-300 {
    --tw-gradient-from: var(--color-secondary-300);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .to-accent-600 {
    --tw-gradient-to: var(--color-accent-600);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .to-heritage-500 {
    --tw-gradient-to: var(--color-heritage-500);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .to-primary-700 {
    --tw-gradient-to: var(--color-primary-700);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .to-secondary-500 {
    --tw-gradient-to: var(--color-secondary-500);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

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

  .p-0 {
    padding: calc(var(--spacing) * 0);
  }

  .p-2 {
    padding: calc(var(--spacing) * 2);
  }

  .p-3 {
    padding: calc(var(--spacing) * 3);
  }

  .p-3\.5 {
    padding: calc(var(--spacing) * 3.5);
  }

  .p-4 {
    padding: calc(var(--spacing) * 4);
  }

  .p-5 {
    padding: calc(var(--spacing) * 5);
  }

  .p-6 {
    padding: calc(var(--spacing) * 6);
  }

  .p-7 {
    padding: calc(var(--spacing) * 7);
  }

  .p-8 {
    padding: calc(var(--spacing) * 8);
  }

  .p-12 {
    padding: calc(var(--spacing) * 12);
  }

  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }

  .px-1\.5 {
    padding-inline: calc(var(--spacing) * 1.5);
  }

  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }

  .px-2\.5 {
    padding-inline: calc(var(--spacing) * 2.5);
  }

  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }

  .px-3\.5 {
    padding-inline: calc(var(--spacing) * 3.5);
  }

  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }

  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }

  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }

  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }

  .py-0\.5 {
    padding-block: calc(var(--spacing) * .5);
  }

  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }

  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }

  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }

  .py-2\.5 {
    padding-block: calc(var(--spacing) * 2.5);
  }

  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }

  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }

  .py-5 {
    padding-block: calc(var(--spacing) * 5);
  }

  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }

  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }

  .py-10 {
    padding-block: calc(var(--spacing) * 10);
  }

  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }

  .py-14 {
    padding-block: calc(var(--spacing) * 14);
  }

  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }

  .py-20 {
    padding-block: calc(var(--spacing) * 20);
  }

  .py-24 {
    padding-block: calc(var(--spacing) * 24);
  }

  .py-px {
    padding-block: 1px;
  }

  .ps-3 {
    padding-inline-start: calc(var(--spacing) * 3);
  }

  .ps-4 {
    padding-inline-start: calc(var(--spacing) * 4);
  }

  .ps-5 {
    padding-inline-start: calc(var(--spacing) * 5);
  }

  .ps-6 {
    padding-inline-start: calc(var(--spacing) * 6);
  }

  .pe-2 {
    padding-inline-end: calc(var(--spacing) * 2);
  }

  .pe-3 {
    padding-inline-end: calc(var(--spacing) * 3);
  }

  .pe-6 {
    padding-inline-end: calc(var(--spacing) * 6);
  }

  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }

  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }

  .pt-5 {
    padding-top: calc(var(--spacing) * 5);
  }

  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }

  .pt-7 {
    padding-top: calc(var(--spacing) * 7);
  }

  .pt-24 {
    padding-top: calc(var(--spacing) * 24);
  }

  .pr-6 {
    padding-right: calc(var(--spacing) * 6);
  }

  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }

  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }

  .pb-12 {
    padding-bottom: calc(var(--spacing) * 12);
  }

  .pb-16 {
    padding-bottom: calc(var(--spacing) * 16);
  }

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

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

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

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

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

  .font-mono {
    font-family: var(--font-mono);
  }

  .font-sans {
    font-family: var(--font-sans);
  }

  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }

  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }

  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }

  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }

  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }

  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }

  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }

  .text-\[0\.875em\] {
    font-size: .875em;
  }

  .text-\[1\.2rem\] {
    font-size: 1.2rem;
  }

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

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

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

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

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

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

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

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

  .leading-5 {
    --tw-leading: calc(var(--spacing) * 5);
    line-height: calc(var(--spacing) * 5);
  }

  .leading-6 {
    --tw-leading: calc(var(--spacing) * 6);
    line-height: calc(var(--spacing) * 6);
  }

  .leading-7 {
    --tw-leading: calc(var(--spacing) * 7);
    line-height: calc(var(--spacing) * 7);
  }

  .leading-\[1\.75\] {
    --tw-leading: 1.75;
    line-height: 1.75;
  }

  .leading-\[1\.85\] {
    --tw-leading: 1.85;
    line-height: 1.85;
  }

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

  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }

  .leading-snug {
    --tw-leading: var(--leading-snug);
    line-height: var(--leading-snug);
  }

  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }

  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .font-extrabold {
    --tw-font-weight: var(--font-weight-extrabold);
    font-weight: var(--font-weight-extrabold);
  }

  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .tracking-\[-0\.08em\] {
    --tw-tracking: -.08em;
    letter-spacing: -.08em;
  }

  .tracking-\[0\.01em\] {
    --tw-tracking: .01em;
    letter-spacing: .01em;
  }

  .tracking-\[0\.3px\] {
    --tw-tracking: .3px;
    letter-spacing: .3px;
  }

  .tracking-\[0\.04em\] {
    --tw-tracking: .04em;
    letter-spacing: .04em;
  }

  .tracking-\[0\.5px\] {
    --tw-tracking: .5px;
    letter-spacing: .5px;
  }

  .tracking-\[1px\] {
    --tw-tracking: 1px;
    letter-spacing: 1px;
  }

  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }

  .tracking-wider {
    --tw-tracking: var(--tracking-wider);
    letter-spacing: var(--tracking-wider);
  }

  .tracking-widest {
    --tw-tracking: var(--tracking-widest);
    letter-spacing: var(--tracking-widest);
  }

  .text-balance {
    text-wrap: balance;
  }

  .text-pretty {
    text-wrap: pretty;
  }

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

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

  .text-\[\#2D2A26\] {
    color: #2d2a26;
  }

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

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

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

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

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

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

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

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

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

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

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

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

  .text-accent-600 {
    color: var(--color-accent-600);
  }

  .text-accent-700 {
    color: var(--color-accent-700);
  }

  .text-celebration-700 {
    color: var(--color-celebration-700);
  }

  .text-heritage-500 {
    color: var(--color-heritage-500);
  }

  .text-heritage-600 {
    color: var(--color-heritage-600);
  }

  .text-heritage-700 {
    color: var(--color-heritage-700);
  }

  .text-primary-600 {
    color: var(--color-primary-600);
  }

  .text-primary-700 {
    color: var(--color-primary-700);
  }

  .text-primary-800 {
    color: var(--color-primary-800);
  }

  .text-primary-900 {
    color: var(--color-primary-900);
  }

  .text-red-700 {
    color: var(--color-red-700);
  }

  .text-secondary-50 {
    color: var(--color-secondary-50);
  }

  .text-secondary-100 {
    color: var(--color-secondary-100);
  }

  .text-secondary-300 {
    color: var(--color-secondary-300);
  }

  .text-secondary-400 {
    color: var(--color-secondary-400);
  }

  .text-secondary-500 {
    color: var(--color-secondary-500);
  }

  .text-secondary-600 {
    color: var(--color-secondary-600);
  }

  .text-secondary-700 {
    color: var(--color-secondary-700);
  }

  .text-secondary-800 {
    color: var(--color-secondary-800);
  }

  .text-secondary-900 {
    color: var(--color-secondary-900);
  }

  .text-surface-card {
    color: var(--color-surface-card);
  }

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

  .lowercase {
    text-transform: lowercase;
  }

  .uppercase {
    text-transform: uppercase;
  }

  .italic {
    font-style: italic;
  }

  .tabular-nums {
    --tw-numeric-spacing: tabular-nums;
    font-variant-numeric: var(--tw-ordinal, ) var(--tw-slashed-zero, ) var(--tw-numeric-figure, ) var(--tw-numeric-spacing, ) var(--tw-numeric-fraction, );
  }

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

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

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

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

  .antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  .accent-primary-600 {
    accent-color: var(--color-primary-600);
  }

  .opacity-0 {
    opacity: 0;
  }

  .opacity-30 {
    opacity: .3;
  }

  .opacity-50 {
    opacity: .5;
  }

  .opacity-55 {
    opacity: .55;
  }

  .opacity-60 {
    opacity: .6;
  }

  .opacity-70 {
    opacity: .7;
  }

  .opacity-90 {
    opacity: .9;
  }

  .opacity-100 {
    opacity: 1;
  }

  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-\[0_0_0_1px_rgba\(31\,28\,23\,0\.06\)\] {
    --tw-shadow: 0 0 0 1px var(--tw-shadow-color, #1f1c170f);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, #0000001a), 0 4px 6px -4px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-xl {
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, #0000001a), 0 8px 10px -6px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring, .ring-1 {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring-4 {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring-heritage-100 {
    --tw-ring-color: var(--color-heritage-100);
  }

  .ring-primary-200 {
    --tw-ring-color: var(--color-primary-200);
  }

  .ring-secondary-100 {
    --tw-ring-color: var(--color-secondary-100);
  }

  .ring-surface-card {
    --tw-ring-color: var(--color-surface-card);
  }

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

  .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(var(--blur-3xl));
    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-\[70px\] {
    --tw-blur: blur(70px);
    filter: var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, );
  }

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

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

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

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

  .transition {
    transition-property: color, background-color, border-color, outline-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));
  }

  .transition-\[padding\,background\] {
    transition-property: padding, background;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-shadow {
    transition-property: box-shadow;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .duration-300 {
    --tw-duration: .3s;
    transition-duration: .3s;
  }

  .duration-500 {
    --tw-duration: .5s;
    transition-duration: .5s;
  }

  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }

  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }

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

  .\[file\:line\] {
    file: line;
  }

  @media (hover: hover) {
    .group-hover\:scale-\[1\.02\]:is(:where(.group):hover *) {
      scale: 1.02;
    }
  }

  @media (hover: hover) {
    .group-hover\:text-heritage-700:is(:where(.group):hover *) {
      color: var(--color-heritage-700);
    }
  }

  @media (hover: hover) {
    .group-hover\:text-primary-800:is(:where(.group):hover *) {
      color: var(--color-primary-800);
    }
  }

  @media (hover: hover) {
    .group-hover\:opacity-100:is(:where(.group):hover *) {
      opacity: 1;
    }
  }

  .marker\:text-secondary-500 ::marker {
    color: var(--color-secondary-500);
  }

  .marker\:text-secondary-500::marker {
    color: var(--color-secondary-500);
  }

  .marker\:text-secondary-500 ::-webkit-details-marker {
    color: var(--color-secondary-500);
  }

  .marker\:text-secondary-500::-webkit-details-marker {
    color: var(--color-secondary-500);
  }

  .focus-within\:ring-\[3px\]:focus-within {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  @media (hover: hover) {
    .hover\:border-heritage-300:hover {
      border-color: var(--color-heritage-300);
    }
  }

  @media (hover: hover) {
    .hover\:border-primary-300:hover {
      border-color: var(--color-primary-300);
    }
  }

  @media (hover: hover) {
    .hover\:border-primary-400:hover {
      border-color: var(--color-primary-400);
    }
  }

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

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

  @media (hover: hover) {
    .hover\:bg-\[var\(--color-secondary-50\)\]:hover {
      background-color: var(--color-secondary-50);
    }
  }

  @media (hover: hover) {
    .hover\:bg-\[var\(--color-secondary-100\)\]:hover {
      background-color: var(--color-secondary-100);
    }
  }

  @media (hover: hover) {
    .hover\:bg-\[var\(--color-secondary-200\)\]:hover {
      background-color: var(--color-secondary-200);
    }
  }

  @media (hover: hover) {
    .hover\:bg-\[var\(--color-semantic-error-700\)\]:hover {
      background-color: var(--color-semantic-error-700);
    }
  }

  @media (hover: hover) {
    .hover\:bg-accent-50:hover {
      background-color: var(--color-accent-50);
    }
  }

  @media (hover: hover) {
    .hover\:bg-heritage-50:hover {
      background-color: var(--color-heritage-50);
    }
  }

  @media (hover: hover) {
    .hover\:bg-neutral-100:hover {
      background-color: var(--color-neutral-100);
    }
  }

  @media (hover: hover) {
    .hover\:bg-primary-50:hover {
      background-color: var(--color-primary-50);
    }
  }

  @media (hover: hover) {
    .hover\:bg-primary-700:hover {
      background-color: var(--color-primary-700);
    }
  }

  @media (hover: hover) {
    .hover\:bg-secondary-100:hover {
      background-color: var(--color-secondary-100);
    }
  }

  @media (hover: hover) {
    .hover\:bg-secondary-200:hover {
      background-color: var(--color-secondary-200);
    }
  }

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

  @media (hover: hover) {
    .hover\:text-\[var\(--color-secondary-700\)\]:hover {
      color: var(--color-secondary-700);
    }
  }

  @media (hover: hover) {
    .hover\:text-heritage-700:hover {
      color: var(--color-heritage-700);
    }
  }

  @media (hover: hover) {
    .hover\:text-primary-700:hover {
      color: var(--color-primary-700);
    }
  }

  @media (hover: hover) {
    .hover\:text-primary-800:hover {
      color: var(--color-primary-800);
    }
  }

  @media (hover: hover) {
    .hover\:underline:hover {
      text-decoration-line: underline;
    }
  }

  @media (hover: hover) {
    .hover\:opacity-80:hover {
      opacity: .8;
    }
  }

  @media (hover: hover) {
    .hover\:shadow-md:hover {
      --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }

  .focus\:not-sr-only:focus {
    clip-path: none;
    white-space: normal;
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    position: static;
    overflow: visible;
  }

  .focus\:fixed:focus {
    position: fixed;
  }

  .focus\:start-4:focus {
    inset-inline-start: calc(var(--spacing) * 4);
  }

  .focus\:top-4:focus {
    top: calc(var(--spacing) * 4);
  }

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

  .focus\:rounded-md:focus {
    border-radius: var(--radius-md);
  }

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

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

  .focus\:bg-primary-600:focus {
    background-color: var(--color-primary-600);
  }

  .focus\:px-4:focus {
    padding-inline: calc(var(--spacing) * 4);
  }

  .focus\:py-2:focus {
    padding-block: calc(var(--spacing) * 2);
  }

  .focus\:text-surface-card:focus {
    color: var(--color-surface-card);
  }

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

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

  .focus\:outline-2:focus {
    outline-style: var(--tw-outline-style);
    outline-width: 2px;
  }

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

  .focus\:outline-primary-600:focus {
    outline-color: var(--color-primary-600);
  }

  .focus\:outline-none:focus {
    --tw-outline-style: none;
    outline-style: none;
  }

  .focus-visible\:shadow-md:focus-visible {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

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

  .focus-visible\:outline-2:focus-visible {
    outline-style: var(--tw-outline-style);
    outline-width: 2px;
  }

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

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

  .active\:bg-accent-100:active {
    background-color: var(--color-accent-100);
  }

  .active\:bg-primary-800:active {
    background-color: var(--color-primary-800);
  }

  .active\:bg-secondary-300:active {
    background-color: var(--color-secondary-300);
  }

  .active\:text-primary-800:active {
    color: var(--color-primary-800);
  }

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

  .disabled\:cursor-not-allowed:disabled {
    cursor: not-allowed;
  }

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

  .disabled\:opacity-40:disabled {
    opacity: .4;
  }

  .disabled\:opacity-60:disabled {
    opacity: .6;
  }

  @media (min-width: 40rem) {
    .sm\:mx-0 {
      margin-inline: calc(var(--spacing) * 0);
    }
  }

  @media (min-width: 40rem) {
    .sm\:flex {
      display: flex;
    }
  }

  @media (min-width: 40rem) {
    .sm\:inline-flex {
      display: inline-flex;
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:flex-row {
      flex-direction: row;
    }
  }

  @media (min-width: 40rem) {
    .sm\:border-0 {
      border-style: var(--tw-border-style);
      border-width: 0;
    }
  }

  @media (min-width: 40rem) {
    .sm\:px-0 {
      padding-inline: calc(var(--spacing) * 0);
    }
  }

  @media (min-width: 40rem) {
    .sm\:px-6 {
      padding-inline: calc(var(--spacing) * 6);
    }
  }

  @media (min-width: 48rem) {
    .md\:sticky {
      position: sticky;
    }
  }

  @media (min-width: 48rem) {
    .md\:col-span-1 {
      grid-column: span 1 / span 1;
    }
  }

  @media (min-width: 48rem) {
    .md\:col-span-2 {
      grid-column: span 2 / span 2;
    }
  }

  @media (min-width: 48rem) {
    .md\:col-span-4 {
      grid-column: span 4 / span 4;
    }
  }

  @media (min-width: 48rem) {
    .md\:col-span-6 {
      grid-column: span 6 / span 6;
    }
  }

  @media (min-width: 48rem) {
    .md\:col-span-8 {
      grid-column: span 8 / span 8;
    }
  }

  @media (min-width: 48rem) {
    .md\:-mx-8 {
      margin-inline: calc(var(--spacing) * -8);
    }
  }

  @media (min-width: 48rem) {
    .md\:-mx-16 {
      margin-inline: calc(var(--spacing) * -16);
    }
  }

  @media (min-width: 48rem) {
    .md\:-ms-\[22px\] {
      margin-inline-start: -22px;
    }
  }

  @media (min-width: 48rem) {
    .md\:flex {
      display: flex;
    }
  }

  @media (min-width: 48rem) {
    .md\:hidden {
      display: none;
    }
  }

  @media (min-width: 48rem) {
    .md\:inline {
      display: inline;
    }
  }

  @media (min-width: 48rem) {
    .md\:inline-flex {
      display: inline-flex;
    }
  }

  @media (min-width: 48rem) {
    .md\:size-16 {
      width: calc(var(--spacing) * 16);
      height: calc(var(--spacing) * 16);
    }
  }

  @media (min-width: 48rem) {
    .md\:size-24 {
      width: calc(var(--spacing) * 24);
      height: calc(var(--spacing) * 24);
    }
  }

  @media (min-width: 48rem) {
    .md\:size-\[34px\] {
      width: 34px;
      height: 34px;
    }
  }

  @media (min-width: 48rem) {
    .md\:size-\[88px\] {
      width: 88px;
      height: 88px;
    }
  }

  @media (min-width: 48rem) {
    .md\:h-32 {
      height: calc(var(--spacing) * 32);
    }
  }

  @media (min-width: 48rem) {
    .md\:h-96 {
      height: calc(var(--spacing) * 96);
    }
  }

  @media (min-width: 48rem) {
    .md\:h-\[104px\] {
      height: 104px;
    }
  }

  @media (min-width: 48rem) {
    .md\:w-32 {
      width: calc(var(--spacing) * 32);
    }
  }

  @media (min-width: 48rem) {
    .md\:w-64 {
      width: calc(var(--spacing) * 64);
    }
  }

  @media (min-width: 48rem) {
    .md\:w-96 {
      width: calc(var(--spacing) * 96);
    }
  }

  @media (min-width: 48rem) {
    .md\:max-w-none {
      max-width: none;
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-8 {
      grid-template-columns: repeat(8, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-12 {
      grid-template-columns: repeat(12, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:flex-row {
      flex-direction: row;
    }
  }

  @media (min-width: 48rem) {
    .md\:items-center {
      align-items: center;
    }
  }

  @media (min-width: 48rem) {
    .md\:items-start {
      align-items: flex-start;
    }
  }

  @media (min-width: 48rem) {
    .md\:justify-between {
      justify-content: space-between;
    }
  }

  @media (min-width: 48rem) {
    .md\:gap-3 {
      gap: calc(var(--spacing) * 3);
    }
  }

  @media (min-width: 48rem) {
    .md\:gap-6 {
      gap: calc(var(--spacing) * 6);
    }
  }

  @media (min-width: 48rem) {
    .md\:gap-\[18px\] {
      gap: 18px;
    }
  }

  @media (min-width: 48rem) {
    .md\:p-7 {
      padding: calc(var(--spacing) * 7);
    }
  }

  @media (min-width: 48rem) {
    .md\:p-8 {
      padding: calc(var(--spacing) * 8);
    }
  }

  @media (min-width: 48rem) {
    .md\:p-10 {
      padding: calc(var(--spacing) * 10);
    }
  }

  @media (min-width: 48rem) {
    .md\:px-6 {
      padding-inline: calc(var(--spacing) * 6);
    }
  }

  @media (min-width: 48rem) {
    .md\:px-8 {
      padding-inline: calc(var(--spacing) * 8);
    }
  }

  @media (min-width: 48rem) {
    .md\:py-12 {
      padding-block: calc(var(--spacing) * 12);
    }
  }

  @media (min-width: 48rem) {
    .md\:py-20 {
      padding-block: calc(var(--spacing) * 20);
    }
  }

  @media (min-width: 48rem) {
    .md\:py-28 {
      padding-block: calc(var(--spacing) * 28);
    }
  }

  @media (min-width: 48rem) {
    .md\:py-36 {
      padding-block: calc(var(--spacing) * 36);
    }
  }

  @media (min-width: 48rem) {
    .md\:pt-12 {
      padding-top: calc(var(--spacing) * 12);
    }
  }

  @media (min-width: 48rem) {
    .md\:pt-28 {
      padding-top: calc(var(--spacing) * 28);
    }
  }

  @media (min-width: 48rem) {
    .md\:pt-32 {
      padding-top: calc(var(--spacing) * 32);
    }
  }

  @media (min-width: 48rem) {
    .md\:pb-16 {
      padding-bottom: calc(var(--spacing) * 16);
    }
  }

  @media (min-width: 48rem) {
    .md\:pb-24 {
      padding-bottom: calc(var(--spacing) * 24);
    }
  }

  @media (min-width: 48rem) {
    .md\:text-start {
      text-align: start;
    }
  }

  @media (min-width: 48rem) {
    .md\:text-2xl {
      font-size: var(--text-2xl);
      line-height: var(--tw-leading, var(--text-2xl--line-height));
    }
  }

  @media (min-width: 48rem) {
    .md\:text-3xl {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }

  @media (min-width: 48rem) {
    .md\:text-4xl {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }

  @media (min-width: 48rem) {
    .md\:text-5xl {
      font-size: var(--text-5xl);
      line-height: var(--tw-leading, var(--text-5xl--line-height));
    }
  }

  @media (min-width: 48rem) {
    .md\:text-lg {
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
    }
  }

  @media (min-width: 48rem) {
    .md\:text-xl {
      font-size: var(--text-xl);
      line-height: var(--tw-leading, var(--text-xl--line-height));
    }
  }

  @media (min-width: 48rem) {
    .md\:text-\[36px\] {
      font-size: 36px;
    }
  }

  @media (min-width: 48rem) {
    .md\:text-\[44px\] {
      font-size: 44px;
    }
  }

  @media (min-width: 64rem) {
    .lg\:block {
      display: block;
    }
  }

  @media (min-width: 64rem) {
    .lg\:hidden {
      display: none;
    }
  }

  @media (min-width: 64rem) {
    .lg\:w-72 {
      width: calc(var(--spacing) * 72);
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[1fr_260px\] {
      grid-template-columns: 1fr 260px;
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[1fr_280px\] {
      grid-template-columns: 1fr 280px;
    }
  }

  @media (min-width: 64rem) {
    .lg\:px-10 {
      padding-inline: calc(var(--spacing) * 10);
    }
  }

  @media (min-width: 64rem) {
    .lg\:py-10 {
      padding-block: calc(var(--spacing) * 10);
    }
  }

  @media (min-width: 64rem) {
    .lg\:text-5xl {
      font-size: var(--text-5xl);
      line-height: var(--tw-leading, var(--text-5xl--line-height));
    }
  }

  .rtl\:rotate-180:where(: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)), [dir="rtl"], [dir="rtl"] *) {
    rotate: 180deg;
  }

  .\[\&_code\]\:font-mono code {
    font-family: var(--font-mono);
  }

  .\[\&\:\:-moz-progress-bar\]\:bg-accent-500::-moz-progress-bar {
    background-color: var(--color-accent-500);
  }

  .\[\&\:\:-webkit-progress-bar\]\:bg-transparent::-webkit-progress-bar {
    background-color: #0000;
  }

  .\[\&\:\:-webkit-progress-value\]\:bg-accent-500::-webkit-progress-value {
    background-color: var(--color-accent-500);
  }

  @media (prefers-reduced-motion: reduce) {
    .motion-reduce\:\[\&\:\:-webkit-progress-value\]\:transition-none::-webkit-progress-value {
      transition-property: none;
    }
  }

  .\[\&\>a\]\:text-primary-700 > a {
    color: var(--color-primary-700);
  }

  .\[\&\>a\]\:underline > a {
    text-decoration-line: underline;
  }

  .\[\&\>a\]\:underline-offset-4 > a {
    text-underline-offset: 4px;
  }

  @media (hover: hover) {
    .hover\:\[\&\>a\]\:text-primary-800:hover > a {
      color: var(--color-primary-800);
    }
  }

  .\[\&\>blockquote\]\:my-6 > blockquote {
    margin-block: calc(var(--spacing) * 6);
  }

  .\[\&\>blockquote\]\:border-s-4 > blockquote {
    border-inline-start-style: var(--tw-border-style);
    border-inline-start-width: 4px;
  }

  .\[\&\>blockquote\]\:border-heritage-400 > blockquote {
    border-color: var(--color-heritage-400);
  }

  .\[\&\>blockquote\]\:ps-4 > blockquote {
    padding-inline-start: calc(var(--spacing) * 4);
  }

  .\[\&\>blockquote\]\:italic > blockquote {
    font-style: italic;
  }

  .\[\&\>h1\]\:mt-0 > h1 {
    margin-top: calc(var(--spacing) * 0);
  }

  .\[\&\>h1\]\:mb-6 > h1 {
    margin-bottom: calc(var(--spacing) * 6);
  }

  .\[\&\>h1\]\:font-bold > h1 {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .\[\&\>h1\]\:text-secondary-900 > h1 {
    color: var(--color-secondary-900);
  }

  .\[\&\>h2\]\:mt-10 > h2 {
    margin-top: calc(var(--spacing) * 10);
  }

  .\[\&\>h2\]\:mb-4 > h2 {
    margin-bottom: calc(var(--spacing) * 4);
  }

  .\[\&\>h2\]\:text-2xl > h2 {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }

  .\[\&\>h2\]\:font-bold > h2 {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .\[\&\>h2\]\:text-secondary-900 > h2 {
    color: var(--color-secondary-900);
  }

  @media (min-width: 48rem) {
    .md\:\[\&\>h2\]\:text-3xl > h2 {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }

  .\[\&\>h3\]\:mt-8 > h3 {
    margin-top: calc(var(--spacing) * 8);
  }

  .\[\&\>h3\]\:mb-3 > h3 {
    margin-bottom: calc(var(--spacing) * 3);
  }

  .\[\&\>h3\]\:text-xl > h3 {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }

  .\[\&\>h3\]\:font-semibold > h3 {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .\[\&\>h3\]\:text-secondary-800 > h3 {
    color: var(--color-secondary-800);
  }

  .\[\&\>ol\]\:mb-5 > ol {
    margin-bottom: calc(var(--spacing) * 5);
  }

  .\[\&\>ol\]\:list-decimal > ol {
    list-style-type: decimal;
  }

  .\[\&\>ol\]\:ps-6 > ol {
    padding-inline-start: calc(var(--spacing) * 6);
  }

  .\[\&\>ol\>li\]\:mb-2 > ol > li {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .\[\&\>p\]\:mb-5 > p {
    margin-bottom: calc(var(--spacing) * 5);
  }

  .\[\&\>p\]\:text-base > p {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }

  @media (min-width: 48rem) {
    .md\:\[\&\>p\]\:text-lg > p {
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
    }
  }

  .\[\&\>p\:first-of-type\:\:first-letter\]\:float-start > p:first-of-type:first-letter {
    float: inline-start;
  }

  .\[\&\>p\:first-of-type\:\:first-letter\]\:me-2 > p:first-of-type:first-letter {
    margin-inline-end: calc(var(--spacing) * 2);
  }

  .\[\&\>p\:first-of-type\:\:first-letter\]\:text-6xl > p:first-of-type:first-letter {
    font-size: var(--text-6xl);
    line-height: var(--tw-leading, var(--text-6xl--line-height));
  }

  .\[\&\>p\:first-of-type\:\:first-letter\]\:leading-none > p:first-of-type:first-letter {
    --tw-leading: 1;
    line-height: 1;
  }

  .\[\&\>p\:first-of-type\:\:first-letter\]\:font-bold > p:first-of-type:first-letter {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .\[\&\>p\:first-of-type\:\:first-letter\]\:text-primary-700 > p:first-of-type:first-letter {
    color: var(--color-primary-700);
  }

  .\[\&\>pre\]\:\!m-0 > pre {
    margin: calc(var(--spacing) * 0) !important;
  }

  .\[\&\>pre\]\:\!bg-transparent > pre {
    background-color: #0000 !important;
  }

  .\[\&\>pre\]\:p-4 > pre {
    padding: calc(var(--spacing) * 4);
  }

  .\[\&\>pre\]\:font-mono > pre {
    font-family: var(--font-mono);
  }

  .\[\&\>span\]\:rounded-full > span {
    border-radius: 3.40282e38px;
  }

  .\[\&\>span\]\:ring-4 > span {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .\[\&\>span\]\:ring-surface-card > span {
    --tw-ring-color: var(--color-surface-card);
  }

  .\[\&\>ul\]\:mb-5 > ul {
    margin-bottom: calc(var(--spacing) * 5);
  }

  .\[\&\>ul\]\:list-disc > ul {
    list-style-type: disc;
  }

  .\[\&\>ul\]\:ps-6 > ul {
    padding-inline-start: calc(var(--spacing) * 6);
  }

  .\[\&\>ul\>li\]\:mb-2 > ul > li {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .rtl-only {
    display: none;
  }

  :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)) .rtl-only {
    display: initial;
  }

  .ltr-only {
    display: none;
  }

  :not(: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)) .ltr-only {
    display: initial;
  }

  @keyframes otp-shake {
    0%, 100% {
      transform: translateX(0);
    }

    20%, 60% {
      transform: translateX(-6px);
    }

    40%, 80% {
      transform: translateX(6px);
    }
  }

  .animate-otp-shake {
    animation: .35s ease-in-out otp-shake;
  }

  @keyframes invite-live-pulse {
    0% {
      box-shadow: 0 0 #0e7c7b59;
    }

    70% {
      box-shadow: 0 0 0 6px #0e7c7b00;
    }

    100% {
      box-shadow: 0 0 #0e7c7b00;
    }
  }

  .animate-invite-live-pulse {
    animation: 1.8s cubic-bezier(.4, 0, .2, 1) infinite invite-live-pulse;
  }

  @keyframes invite-step-in {
    from {
      opacity: 0;
      transform: translateY(6px);
    }

    to {
      opacity: 1;
      transform: none;
    }
  }

  .animate-invite-step-in {
    animation: .28s cubic-bezier(0, 0, .2, 1) invite-step-in;
  }

  @media (prefers-reduced-motion: reduce) {
    .animate-otp-shake, .animate-invite-live-pulse, .animate-invite-step-in {
      animation: none;
    }
  }
}

@font-face {
  font-family: Vazirmatn Variable;
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("../media/vazirmatn-arabic-wght-normal.0985rt6pmu1_4.woff2") format("woff2-variations");
  unicode-range: U+6??, U+750-77F, U+870-88E, U+890-891, U+897-8E1, U+8E3-8FF, U+200C-200E, U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F, U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B, U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A, U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB, U+1EEF0-1EEF1;
}

@font-face {
  font-family: Vazirmatn Variable;
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("../media/vazirmatn-latin-ext-wght-normal.07kswpp8d59jc.woff2") format("woff2-variations");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Vazirmatn Variable;
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("../media/vazirmatn-latin-wght-normal.005f23f8f3ye6.woff2") format("woff2-variations");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Fraunces Variable;
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("../media/fraunces-vietnamese-wght-normal.05ntv1..6v~z7.woff2") format("woff2-variations");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Fraunces Variable;
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("../media/fraunces-latin-ext-wght-normal.08-a-oz-atsnn.woff2") format("woff2-variations");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Fraunces Variable;
  font-style: normal;
  font-display: swap;
  font-weight: 100 900;
  src: url("../media/fraunces-latin-wght-normal.0l9v6sgnyeoq8.woff2") format("woff2-variations");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-bold: 700;
}

html {
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizelegibility;
}

@supports (font-display: swap) {
  html {
    font-display: swap;
  }
}

:root {
  --font-display-en: "Fraunces", "Fraunces Variable", "Source Serif 4", Georgia,
    "Times New Roman", serif;
  --gradient-dawn: radial-gradient(at 20% 20%, var(--color-heritage-200) 0%, transparent 55%),
    radial-gradient(at 82% 8%, var(--color-accent-100) 0%, transparent 50%),
    radial-gradient(at 50% 90%, var(--color-secondary-100) 0%, transparent 60%),
    var(--color-surface-background);
  --gradient-dusk: radial-gradient(at 28% 78%, var(--color-primary-700) 0%, transparent 55%),
    radial-gradient(at 88% 22%, var(--color-accent-500) 0%, transparent 45%),
    radial-gradient(at 50% 50%, var(--color-heritage-600) 0%, transparent 70%),
    var(--color-secondary-800);
  --gradient-night: radial-gradient(at 50% 40%, var(--color-primary-800) 0%, transparent 65%),
    radial-gradient(at 20% 90%, var(--color-heritage-700) 0%, transparent 60%),
    var(--color-secondary-900);
  --gradient-ember: radial-gradient(at 30% 30%, var(--color-accent-300) 0%, transparent 55%),
    radial-gradient(at 80% 70%, var(--color-celebration-500) 0%, transparent 50%),
    var(--color-secondary-100);
  --grain-opacity: .04;
  --pattern-opacity-default: .04;
  --pattern-opacity-hero: .08;
  --pattern-opacity-accent: .12;
  --surface-night: var(--color-secondary-900);
  --surface-night-soft: var(--color-secondary-800);
  --surface-night-border: var(--color-secondary-700);
  --dur-xs: .12s;
  --dur-sm: .2s;
  --dur-md: .32s;
  --dur-lg: .52s;
  --dur-xl: .84s;
  --ease-standard: cubic-bezier(.2, 0, 0, 1);
  --ease-emphasized: cubic-bezier(.2, 0, 0, 1.2);
  --ease-decelerate: cubic-bezier(0, 0, 0, 1);
  --ease-accelerate: cubic-bezier(.4, 0, 1, 1);
  --ease-heritage: cubic-bezier(.33, 1, .68, 1);
  --glow-sm: 48px;
  --glow-md: 96px;
  --glow-lg: 192px;
  --glow-xl: 320px;
  --landing-hero-max-width: 88rem;
  --landing-section-gap: clamp(3rem, 6vw, 7rem);
}

@media (prefers-reduced-motion: reduce) {
  *, :before, :after {
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
  }
}

.heading-hero {
  letter-spacing: -.02em;
  font-size: clamp(2.75rem, 6vw, 5.5rem);
  line-height: 1.05;
}

.heading-display-lg {
  letter-spacing: -.02em;
  font-size: clamp(2.25rem, 4.5vw, 4rem);
  line-height: 1.08;
}

.heading-display-md {
  letter-spacing: -.015em;
  font-size: clamp(1.75rem, 3vw, 2.75rem);
  line-height: 1.12;
}

.heading-display-en {
  font-family: var(--font-display-en);
  letter-spacing: -.025em;
}

[dir="rtl"] svg[data-rtl="mirror"] {
  transform: scaleX(-1);
}

.clip-asym {
  border-start-start-radius: var(--radius-xl);
  border-start-end-radius: var(--radius-sm);
  border-end-end-radius: var(--radius-xl);
  border-end-start-radius: var(--radius-sm);
  overflow: hidden;
}

@keyframes touron-reveal-up {
  from {
    opacity: 0;
    transform: translateY(var(--reveal-y, 24px));
  }

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

.touron-reveal {
  animation: touron-reveal-up var(--reveal-duration, var(--dur-lg)) var(--ease-heritage) var(--reveal-delay, 0s) both;
  will-change: opacity, transform;
}

@media (prefers-reduced-motion: reduce) {
  .touron-reveal {
    will-change: auto;
    animation: none;
  }
}

:root {
  --lp-easing-default: cubic-bezier(.4, 0, .2, 1);
  --lp-easing-enter: cubic-bezier(0, 0, .2, 1);
  --lp-easing-exit: cubic-bezier(.4, 0, 1, 1);
  --lp-celebration-700: #6e2329;
}

.lp-root {
  background: var(--color-surface-background);
  max-width: 440px;
  color: var(--color-secondary-800);
  font-family: var(--font-sans);
  line-height: var(--leading-comfortable);
  margin: 0 auto;
  position: relative;
  overflow-x: clip;
}

.lp-root * {
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .lp-root {
    max-width: 680px;
  }
}

@media (min-width: 1024px) {
  .lp-root {
    max-width: 960px;
  }
}

.lp-section {
  padding: 56px 20px;
  position: relative;
}

.lp-section--tight {
  padding: 40px 20px;
}

.lp-eyebrow {
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-primary-700);
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  font-size: 11px;
  font-weight: 600;
  display: inline-flex;
}

.lp-eyebrow:before {
  content: "";
  background: var(--color-primary-600);
  border-radius: 2px;
  width: 20px;
  height: 2px;
}

.lp-section-title {
  letter-spacing: -.01em;
  color: var(--color-secondary-900);
  text-wrap: pretty;
  margin: 0 0 12px;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.3;
}

.lp-section-lead {
  color: var(--color-secondary-600);
  max-width: 360px;
  margin: 0 0 24px;
  font-size: 15px;
  line-height: 1.7;
}

.lp-btn {
  cursor: pointer;
  white-space: nowrap;
  border: none;
  border-start-start-radius: 12px;
  border-start-end-radius: 4px;
  border-end-end-radius: 12px;
  border-end-start-radius: 4px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 14px 22px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  transition: background .2s, transform .15s, box-shadow .2s;
  display: inline-flex;
}

.lp-btn:active {
  transform: scale(.97);
}

.lp-btn--primary {
  background: var(--color-primary-600);
  color: #fff;
  box-shadow: 0 2px 8px #0e7c7b3d;
}

.lp-btn--primary:hover {
  background: var(--color-primary-700);
  color: #fff;
  box-shadow: 0 4px 12px #0e7c7b52;
}

.lp-btn--saffron {
  background: var(--color-accent-500);
  color: var(--color-secondary-900);
  box-shadow: 0 2px 8px #d4a24c47;
}

.lp-btn--saffron:hover {
  background: var(--color-accent-600);
  color: #fff;
}

.lp-btn--ghost {
  color: var(--color-primary-700);
  border: 1px solid var(--color-secondary-300);
  background: none;
}

.lp-btn--ghost:hover {
  border-color: var(--color-primary-600);
  background: var(--color-primary-50);
  color: var(--color-primary-700);
}

.lp-btn--sm {
  padding: 10px 16px;
  font-size: 13px;
}

.lp-btn--lg {
  padding: 18px 28px;
  font-size: 16px;
}

.lp-trust-chips {
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
  display: flex;
}

.lp-trust-chip {
  background: var(--color-secondary-100);
  color: var(--color-secondary-600);
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  font-size: 11px;
  display: inline-flex;
}

.lp-trust-chip__dot {
  background: var(--color-primary-500);
  border-radius: 999px;
  width: 6px;
  height: 6px;
}

.lp-hero-install-row {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
  display: flex;
}

.lp-avatars {
  display: flex;
}

.lp-avatar {
  background: var(--color-primary-600);
  color: #fff;
  border: 2px solid #fff;
  border-radius: 999px;
  place-items: center;
  width: 32px;
  height: 32px;
  font-size: 11px;
  font-weight: 700;
  display: grid;
  box-shadow: 0 1px 2px #1f1c1714;
}

.lp-avatar + .lp-avatar {
  margin-inline-start: -8px;
}

.lp-avatar--heritage {
  background: var(--color-heritage-500);
}

.lp-avatar--saffron {
  background: var(--color-accent-600);
}

.lp-avatar--pom {
  background: var(--color-celebration-500);
}

.lp-reveal {
  opacity: 0;
  transition: opacity .7s var(--lp-easing-default), transform .7s var(--lp-easing-default);
  will-change: opacity, transform;
  transform: translateY(24px);
}

.lp-reveal.is-in {
  opacity: 1;
  transform: translateY(0);
}

.lp-reveal--d1 {
  transition-delay: 80ms;
}

.lp-reveal--d2 {
  transition-delay: .16s;
}

.lp-reveal--d3 {
  transition-delay: .24s;
}

.lp-reveal--d4 {
  transition-delay: .32s;
}

.lp-reveal--d5 {
  transition-delay: .4s;
}

@media (prefers-reduced-motion: reduce) {
  .lp-reveal {
    opacity: 1;
    transition: none;
    transform: none;
  }
}

.lp-hero {
  padding: 64px 20px 48px;
  position: relative;
  overflow: hidden;
}

.lp-hero:before {
  content: "";
  top: -60px;
  background: radial-gradient(circle at center, var(--color-heritage-100), transparent 65%);
  z-index: 0;
  border-radius: 50%;
  width: 280px;
  height: 280px;
  position: absolute;
  inset-inline-end: -60px;
}

.lp-hero:after {
  content: "";
  bottom: -40px;
  background-image: radial-gradient(circle, var(--color-heritage-300) 1px, transparent 1.5px);
  opacity: .5;
  z-index: 0;
  background-size: 16px 16px;
  width: 200px;
  height: 200px;
  position: absolute;
  inset-inline-start: -40px;
}

.lp-hero > * {
  z-index: 1;
  position: relative;
}

.lp-hero__eyebrow {
  color: var(--color-heritage-700);
}

.lp-hero__eyebrow:before {
  background: var(--color-heritage-600);
}

.lp-hero__title {
  letter-spacing: -.025em;
  color: var(--color-secondary-900);
  text-wrap: pretty;
  margin: 0 0 18px;
  font-size: 40px;
  font-weight: 700;
  line-height: 1.2;
}

.lp-hero__title em {
  color: var(--color-heritage-700);
  font-style: normal;
  display: inline-block;
  position: relative;
}

.lp-hero__title em:after {
  content: "";
  background: var(--color-heritage-100);
  z-index: -1;
  border-radius: 2px;
  height: 10px;
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
}

.lp-hero__lead {
  color: var(--color-secondary-600);
  text-wrap: pretty;
  max-width: 420px;
  margin: 0 0 28px;
  font-size: 16px;
  line-height: 1.75;
}

@media (min-width: 768px) {
  .lp-hero {
    padding: 88px 24px 64px;
  }

  .lp-hero__title {
    font-size: 48px;
  }
}

.lp-hero-art {
  justify-content: center;
  align-items: center;
  height: 320px;
  margin: 32px -20px -8px;
  display: flex;
  position: relative;
}

.lp-hero-phone {
  width: 200px;
  height: 280px;
  box-shadow: 0 24px 48px #1f1c1724, 0 0 0 1px var(--color-secondary-200) inset;
  z-index: 2;
  transition: transform .6s var(--lp-easing-default);
  background: #fff;
  border-radius: 28px;
  padding: 14px;
  position: relative;
  transform: rotate(-3deg);
}

.lp-hero-phone:hover {
  transform: rotate(-1deg)translateY(-4px);
}

.lp-hero-tile {
  inset-inline-start: 50%;
  background: var(--color-heritage-500);
  z-index: 1;
  width: 56px;
  height: 56px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%)rotate(45deg);
}

.lp-hero-tile--1 {
  top: 35%;
  background: var(--color-primary-600);
  inset-inline-start: 18%;
}

.lp-hero-tile--2 {
  top: 70%;
  background: var(--color-accent-500);
  width: 44px;
  height: 44px;
  inset-inline-start: 78%;
}

.lp-hero-tile--3 {
  top: 20%;
  background: var(--color-heritage-400);
  width: 38px;
  height: 38px;
  inset-inline-start: 80%;
}

.lp-hero-screen {
  background: linear-gradient(180deg, var(--color-heritage-50) 0%, #fff 40%);
  border-radius: 18px;
  flex-direction: column;
  gap: 8px;
  width: 100%;
  height: 100%;
  padding: 14px 12px;
  display: flex;
}

.lp-hero-screen__bar {
  background: var(--color-secondary-200);
  border-radius: 2px;
  height: 4px;
}

.lp-hero-screen__bar--t {
  background: var(--color-heritage-400);
  width: 40%;
}

.lp-hero-screen__row {
  color: var(--color-secondary-700);
  border-bottom: 1px dashed var(--color-secondary-200);
  justify-content: space-between;
  align-items: center;
  padding: 6px 4px;
  font-family: inherit;
  font-size: 9px;
  display: flex;
}

.lp-hero-screen__row:last-child {
  border-bottom: none;
}

.lp-hero-screen__amt {
  font-variant-numeric: tabular-nums;
  color: var(--color-secondary-900);
  font-weight: 700;
}

.lp-hero-screen__row--sum {
  color: var(--color-heritage-700);
  border-bottom: none;
  padding-top: 8px;
  font-weight: 700;
}

.lp-pillars {
  background: #fff;
  border-radius: 24px 24px 0 0;
  margin-top: 20px;
  padding: 48px 20px;
}

.lp-pillars__grid {
  gap: 16px;
  display: grid;
}

@media (min-width: 768px) {
  .lp-pillars__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.lp-pillar {
  border-radius: 18px;
  padding: 28px 24px;
  position: relative;
  overflow: hidden;
}

.lp-pillar--dang {
  background: linear-gradient(135deg, var(--color-primary-50) 0%, #fff 60%);
  border: 1px solid var(--color-primary-100);
}

.lp-pillar--explore {
  background: linear-gradient(135deg, var(--color-accent-50) 0%, #fff 60%);
  border: 1px solid var(--color-accent-100);
}

.lp-pillar__label {
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-primary-700);
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 700;
  display: flex;
}

.lp-pillar--explore .lp-pillar__label {
  color: var(--color-accent-700);
}

.lp-pillar__num {
  background: var(--color-primary-600);
  color: #fff;
  border-radius: 50%;
  place-items: center;
  width: 22px;
  height: 22px;
  font-size: 11px;
  display: grid;
}

.lp-pillar--explore .lp-pillar__num {
  background: var(--color-accent-600);
}

.lp-pillar h3 {
  color: var(--color-secondary-900);
  letter-spacing: -.01em;
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 700;
}

.lp-pillar p {
  color: var(--color-secondary-600);
  margin: 0 0 16px;
  font-size: 14px;
  line-height: 1.75;
}

.lp-pillar__ornament {
  inset-inline-end: -30px;
  background: var(--color-primary-100);
  opacity: .5;
  pointer-events: none;
  border-radius: 50%;
  width: 120px;
  height: 120px;
  position: absolute;
  bottom: -30px;
}

.lp-pillar--explore .lp-pillar__ornament {
  background: var(--color-accent-100);
}

.lp-tile-band {
  background-image: linear-gradient(45deg, var(--color-heritage-500) 25%, transparent 25%), linear-gradient(-45deg, var(--color-heritage-500) 25%, transparent 25%), linear-gradient(45deg, transparent 75%, var(--color-heritage-500) 75%), linear-gradient(-45deg, transparent 75%, var(--color-heritage-500) 75%);
  background-position: 0 0, 0 7px, 7px -7px, -7px 0;
  background-size: 14px 14px;
  background-color: var(--color-heritage-50);
  opacity: .85;
  height: 28px;
}

.lp-ornament {
  text-align: center;
  padding: 24px 20px 8px;
}

.lp-ornament__line-row {
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  display: flex;
}

.lp-ornament__line {
  background: var(--color-heritage-300);
  width: 40px;
  height: 1px;
}

.lp-ornament__mark {
  background: var(--color-heritage-500);
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
}

.lp-ornament__lead {
  text-align: center;
  margin: 0 auto 24px;
}

.lp-dang-flow {
  background: var(--color-surface-background);
  padding: 48px 20px;
  position: relative;
}

.lp-dang-flow__spine {
  inset-inline-start: 40px;
  background-image: linear-gradient(to bottom, var(--color-heritage-300) 50%, transparent 50%);
  pointer-events: none;
  background-size: 1px 8px;
  width: 2px;
  position: absolute;
  top: 160px;
  bottom: 80px;
}

.lp-dang-step {
  margin-bottom: 28px;
  padding-inline-start: 70px;
  position: relative;
}

.lp-dang-step__num {
  inset-inline-start: 22px;
  border: 2px solid var(--color-heritage-500);
  width: 38px;
  height: 38px;
  color: var(--color-heritage-700);
  font-variant-numeric: tabular-nums;
  z-index: 1;
  background: #fff;
  border-radius: 50%;
  place-items: center;
  font-size: 15px;
  font-weight: 700;
  display: grid;
  position: absolute;
  top: 0;
}

.lp-dang-step h4 {
  color: var(--color-secondary-900);
  margin: 6px 0;
  font-size: 17px;
  font-weight: 700;
}

.lp-dang-step p {
  color: var(--color-secondary-600);
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.7;
}

.lp-dang-visual {
  border: 1px solid var(--color-secondary-200);
  color: var(--color-secondary-700);
  background: #fff;
  border-radius: 12px;
  padding: 14px;
  font-size: 12px;
}

.lp-dang-visual__row {
  justify-content: space-between;
  padding: 5px 0;
  display: flex;
}

.lp-dang-visual__num {
  color: var(--color-secondary-900);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
}

.lp-dang-visual__caption {
  color: var(--color-secondary-500);
  margin-top: 8px;
  font-size: 11px;
}

.lp-dang-visual__split {
  background: var(--color-secondary-100);
  border-radius: 3px;
  height: 6px;
  margin: 8px 0 4px;
  display: flex;
  overflow: hidden;
}

.lp-dang-visual__split > span {
  height: 100%;
}

.lp-dang-visual__split > span:first-child {
  background: var(--color-primary-500);
  width: 25%;
}

.lp-dang-visual__split > span:nth-child(2) {
  background: var(--color-heritage-500);
  width: 25%;
}

.lp-dang-visual__split > span:nth-child(3) {
  background: var(--color-accent-500);
  width: 25%;
}

.lp-dang-visual__split > span:nth-child(4) {
  background: var(--color-secondary-400);
  width: 25%;
}

.lp-advantages {
  gap: 10px;
  max-width: 640px;
  margin: 16px auto 0;
  padding: 0 4px;
  display: grid;
}

.lp-adv {
  border: 1px solid var(--color-secondary-200);
  background: #fff;
  border-radius: 12px;
  grid-template-columns: 32px 1fr;
  align-items: start;
  gap: 14px;
  padding: 14px 16px;
  display: grid;
}

.lp-adv--accent {
  background: linear-gradient(135deg, var(--color-heritage-50), #fff);
  border-color: var(--color-heritage-200);
}

.lp-adv__num {
  background: var(--color-heritage-100);
  width: 28px;
  height: 28px;
  color: var(--color-heritage-700);
  border-radius: 50%;
  place-items: center;
  font-size: 13px;
  font-weight: 700;
  display: grid;
}

.lp-adv--accent .lp-adv__num {
  background: var(--color-heritage-600);
  color: #fff;
}

.lp-adv__title {
  color: var(--color-secondary-900);
  margin: 2px 0 4px;
  font-size: 14.5px;
  font-weight: 600;
}

.lp-adv__body {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 13px;
  line-height: 1.65;
}

.lp-adv--accent .lp-adv__body {
  color: var(--color-secondary-700);
}

.lp-explore {
  background: #fff;
  padding: 48px 0 16px;
}

.lp-explore__grid {
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 0 20px 48px;
  display: grid;
}

@media (min-width: 1024px) {
  .lp-explore__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.lp-explore-card {
  border: 1px solid var(--color-secondary-200);
  transition: transform .3s var(--lp-easing-default), box-shadow .3s var(--lp-easing-default);
  color: inherit;
  background: #fff;
  border-radius: 14px;
  text-decoration: none;
  display: block;
  overflow: hidden;
}

.lp-explore-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px #1f1c171a;
}

.lp-explore-card__image {
  background: linear-gradient(135deg, var(--color-heritage-300) 0%, var(--color-heritage-600) 100%);
  height: 110px;
  position: relative;
}

.lp-explore-card__image:before {
  content: "";
  background-image: linear-gradient(to top, #00000040, #0000 50%), radial-gradient(at bottom, #ffffff4d, #0000 50%);
  position: absolute;
  inset: 0;
}

.lp-explore-card__image svg {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.lp-explore-card__image--saffron {
  background: linear-gradient(135deg, var(--color-accent-400) 0%, var(--color-accent-700) 100%);
}

.lp-explore-card__image--pom {
  background: linear-gradient(135deg, #d89593 0%, var(--lp-celebration-700) 100%);
}

.lp-explore-card__image--teal {
  background: linear-gradient(135deg, var(--color-primary-400) 0%, var(--color-primary-800) 100%);
}

.lp-explore-card__body {
  padding: 12px 14px;
}

.lp-explore-card__title {
  color: var(--color-secondary-900);
  margin: 0 0 4px;
  font-size: 13px;
  font-weight: 700;
}

.lp-explore-card__meta {
  color: var(--color-secondary-500);
  font-size: 11px;
}

.lp-tl-strip {
  background: linear-gradient(135deg, var(--color-secondary-900) 0%, #2a2621 100%);
  color: #f5efe3;
  border-radius: 18px;
  margin: 32px 20px;
  padding: 28px 20px;
  position: relative;
  overflow: hidden;
}

.lp-tl-strip:after {
  content: "";
  pointer-events: none;
  background-image: radial-gradient(circle, #3bafa924 1px, #0000 2px);
  background-size: 18px 18px;
  position: absolute;
  inset: 0;
}

.lp-tl-strip__content {
  z-index: 1;
  position: relative;
}

.lp-tl-strip__label {
  letter-spacing: .12em;
  color: var(--color-heritage-400);
  text-transform: uppercase;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 600;
}

.lp-tl-strip h3 {
  color: #f5efe3;
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.35;
}

.lp-tl-strip p {
  color: #a89f92;
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.6;
}

.lp-tl-strip__cta {
  color: var(--color-accent-500);
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.lp-tl-strip__cta:hover {
  color: var(--color-accent-400);
}

.lp-testimonials {
  flex-direction: column;
  gap: 14px;
  padding: 8px 20px 40px;
  display: flex;
}

.lp-testimonial {
  border: 1px solid var(--color-secondary-100);
  background: #fff;
  border-radius: 14px;
  padding: 20px;
  position: relative;
}

.lp-testimonial:before {
  content: "“";
  top: 10px;
  color: var(--color-primary-200);
  font-family: Georgia, serif;
  font-size: 44px;
  line-height: 1;
  position: absolute;
  inset-inline-end: 18px;
}

.lp-testimonial p {
  color: var(--color-secondary-700);
  margin: 0 0 16px;
  padding-inline-start: 4px;
  font-size: 14px;
  line-height: 1.7;
}

.lp-testimonial__meta {
  align-items: center;
  gap: 10px;
  display: flex;
}

.lp-testimonial__meta .lp-avatar {
  width: 36px;
  height: 36px;
  font-size: 12px;
}

.lp-testimonial__name {
  color: var(--color-secondary-900);
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.3;
}

.lp-testimonial__role {
  color: var(--color-secondary-500);
  margin: 2px 0 0;
  font-size: 11px;
}

.lp-faq {
  background: #fff;
  padding: 40px 20px;
}

.lp-faq-item {
  border-bottom: 1px solid var(--color-secondary-200);
  padding: 18px 0;
}

.lp-faq-q {
  color: var(--color-secondary-900);
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  font-weight: 600;
  list-style: none;
  display: flex;
}

.lp-faq-q::-webkit-details-marker {
  display: none;
}

.lp-faq-q__icon {
  background: var(--color-secondary-100);
  width: 24px;
  height: 24px;
  color: var(--color-secondary-600);
  transition: transform .25s var(--lp-easing-default), background .2s;
  border-radius: 999px;
  flex-shrink: 0;
  place-items: center;
  font-size: 14px;
  display: grid;
}

.lp-faq-item[open] .lp-faq-q__icon {
  background: var(--color-primary-100);
  color: var(--color-primary-700);
  transform: rotate(45deg);
}

.lp-faq-a {
  color: var(--color-secondary-600);
  animation: lp-faq-open .3s var(--lp-easing-default);
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.7;
}

@keyframes lp-faq-open {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }

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

@media (prefers-reduced-motion: reduce) {
  .lp-faq-a {
    animation: none;
  }
}

.lp-install {
  background: linear-gradient(135deg, var(--color-primary-700) 0%, var(--color-primary-900) 100%);
  color: #fff;
  border-radius: 24px;
  margin: 32px 20px;
  padding: 36px 24px;
  position: relative;
  overflow: hidden;
}

.lp-install:before {
  content: "";
  inset-inline-end: -50px;
  background-image: radial-gradient(circle, #3bafa940 1px, #0000 2px);
  background-size: 14px 14px;
  width: 200px;
  height: 200px;
  position: absolute;
  top: -50px;
}

.lp-install:after {
  content: "";
  inset-inline-start: -60px;
  background: #3bafa924;
  border-radius: 50%;
  width: 180px;
  height: 180px;
  position: absolute;
  bottom: -60px;
}

.lp-install__content {
  z-index: 1;
  position: relative;
}

.lp-install h2 {
  color: #fff;
  letter-spacing: -.01em;
  margin: 0 0 10px;
  font-size: 24px;
  font-weight: 700;
}

.lp-install p {
  color: #ffffffc7;
  margin: 0 0 22px;
  font-size: 14px;
  line-height: 1.7;
}

.lp-stores {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.lp-stores__row {
  flex-wrap: wrap;
  gap: 10px;
  display: flex;
}

.lp-store {
  background: var(--color-secondary-900);
  color: #fff;
  border-start-start-radius: 12px;
  border-start-end-radius: 4px;
  border-end-end-radius: 12px;
  border-end-start-radius: 4px;
  align-items: center;
  gap: 10px;
  min-width: 172px;
  padding: 12px 16px;
  text-decoration: none;
  transition: background .2s, color .2s;
  display: inline-flex;
}

.lp-store:hover {
  background: var(--color-secondary-700);
  color: #fff;
}

.lp-store--outline {
  color: #fff;
  background: #ffffff1f;
  border: 1px solid #ffffff3d;
}

.lp-store--outline:hover {
  color: #fff;
  background: #fff3;
}

.lp-store__mark {
  border-radius: 7px;
  flex-shrink: 0;
  place-items: center;
  width: 30px;
  height: 30px;
  display: grid;
}

.lp-store__label {
  flex-direction: column;
  align-items: flex-start;
  line-height: 1;
  display: flex;
}

.lp-store__label--sm {
  opacity: .72;
  margin-bottom: 2px;
  font-size: 10px;
  font-weight: 500;
}

.lp-store__label--lg {
  font-size: 14px;
  font-weight: 700;
}

.lp-store--outline .lp-store__label--sm {
  color: #ffffffb3;
  opacity: 1;
}

.tlp-root {
  background: var(--color-secondary-50);
}

.tlp-hero {
  padding: 40px 20px 28px;
  position: relative;
  overflow: hidden;
}

.tlp-hero:before {
  content: "";
  inset-inline-end: -100px;
  background: radial-gradient(circle, var(--color-accent-100), transparent 60%);
  z-index: 0;
  pointer-events: none;
  width: 300px;
  height: 300px;
  position: absolute;
  top: -60px;
}

.tlp-hero:after {
  content: "";
  inset-inline-start: -40px;
  background-image: radial-gradient(circle, var(--color-heritage-300) 1px, transparent 1.5px);
  opacity: .4;
  z-index: 0;
  pointer-events: none;
  background-size: 16px 16px;
  width: 220px;
  height: 220px;
  position: absolute;
  top: 120px;
}

.tlp-hero > * {
  z-index: 1;
  position: relative;
}

.tlp-hero__eyebrow {
  color: var(--color-heritage-700);
}

.tlp-hero__eyebrow:before {
  background: var(--color-heritage-600);
}

.tlp-hero__title {
  letter-spacing: -.028em;
  color: var(--color-secondary-900);
  text-wrap: pretty;
  margin: 0 0 18px;
  font-size: 40px;
  font-weight: 700;
  line-height: 1.15;
}

.tlp-hero__title em {
  color: var(--color-heritage-700);
  font-style: normal;
  display: inline-block;
  position: relative;
}

.tlp-hero__title em:after {
  content: "";
  background: var(--color-heritage-100);
  z-index: -1;
  border-radius: 2px;
  height: 10px;
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
}

.tlp-hero__lead {
  color: var(--color-secondary-600);
  text-wrap: pretty;
  max-width: 420px;
  margin: 0 0 26px;
  font-size: 16px;
  line-height: 1.7;
}

.tlp-seat-card {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  border-radius: 18px;
  margin: 6px 0 22px;
  padding: 18px 18px 20px;
  box-shadow: 0 2px 12px #1f1c170f;
}

.tlp-seat-card__head {
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
  display: flex;
}

.tlp-seat-card__title {
  color: var(--color-secondary-900);
  font-size: 13px;
  font-weight: 700;
}

.tlp-seat-card__subtitle {
  color: var(--color-secondary-500);
  margin-top: 2px;
  font-size: 11px;
}

.tlp-seat-card__meta {
  color: var(--color-heritage-700);
  background: var(--color-heritage-50);
  font-variant-numeric: tabular-nums;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 700;
}

.tlp-seat-card__bar {
  background: repeating-linear-gradient(-45deg, var(--color-secondary-100), var(--color-secondary-100) 6px, var(--color-secondary-50) 6px, var(--color-secondary-50) 12px);
  border-radius: 10px;
  height: 34px;
  margin-bottom: 12px;
  position: relative;
  overflow: hidden;
}

.tlp-seat-card__fill {
  background: linear-gradient(90deg, var(--color-heritage-500), var(--color-primary-600));
  color: #fff;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  border-start-end-radius: 10px;
  border-end-end-radius: 10px;
  justify-content: flex-end;
  align-items: center;
  width: 0;
  padding-inline-end: 12px;
  font-size: 12px;
  font-weight: 700;
  transition: width 1.2s cubic-bezier(.22, 1, .36, 1);
  display: flex;
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
}

@media (prefers-reduced-motion: reduce) {
  .tlp-seat-card__fill {
    transition: none;
  }
}

.tlp-seat-card__stats {
  border-top: 1px dashed var(--color-secondary-200);
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  padding-top: 10px;
  display: grid;
}

.tlp-seat-stat__n {
  color: var(--color-secondary-900);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.1;
}

.tlp-seat-stat__n--heritage {
  color: var(--color-heritage-700);
}

.tlp-seat-stat__n--accent {
  color: var(--color-accent-700);
}

.tlp-seat-stat__l {
  color: var(--color-secondary-500);
  margin-top: 2px;
  font-size: 10px;
  line-height: 1.4;
}

.tlp-hero-trust {
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 16px;
  display: flex;
}

.tlp-trust-chip {
  border: 1px solid var(--color-secondary-200);
  color: var(--color-secondary-700);
  background: #ffffffb3;
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 500;
  display: inline-flex;
}

.tlp-trust-chip__dot {
  background: var(--color-primary-500);
  border-radius: 999px;
  width: 6px;
  height: 6px;
}

.tlp-trust-chip__dot--saffron {
  background: var(--color-accent-500);
}

.tlp-trust-chip__dot--heritage {
  background: var(--color-heritage-500);
}

.tlp-why {
  background: linear-gradient(#0000 0%, #fff 100%);
  padding: 56px 20px 40px;
}

.tlp-why__grid {
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 24px;
  display: grid;
}

.tlp-why-card {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  border-radius: 16px;
  padding: 22px 20px;
  position: relative;
  overflow: hidden;
}

.tlp-why-card--hero {
  background: linear-gradient(135deg, var(--color-heritage-700) 0%, var(--color-primary-800) 100%);
  color: #fff;
  border-color: #0000;
}

.tlp-why-card--hero:before {
  content: "";
  pointer-events: none;
  background-image: radial-gradient(circle at 100% 0, #ffffff1a 0%, #0000 40%), radial-gradient(circle, #d4a24c1a 1px, #0000 2px);
  background-size: 100% 100%, 18px 18px;
  position: absolute;
  inset: 0;
}

.tlp-why-card > * {
  z-index: 1;
  position: relative;
}

.tlp-why-card__num {
  color: var(--color-heritage-700);
  letter-spacing: -.03em;
  font-variant-numeric: tabular-nums;
  margin-bottom: 8px;
  font-size: 44px;
  font-weight: 700;
  line-height: 1;
}

.tlp-why-card--hero .tlp-why-card__num {
  color: var(--color-accent-400);
  font-size: 52px;
}

.tlp-why-card__title {
  color: var(--color-secondary-900);
  margin: 0 0 6px;
  font-size: 16px;
  font-weight: 700;
}

.tlp-why-card--hero .tlp-why-card__title {
  color: #fff;
}

.tlp-why-card__body {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 13px;
  line-height: 1.65;
}

.tlp-why-card--hero .tlp-why-card__body {
  color: #ffffffc7;
}

.tlp-why-card__footnote {
  color: var(--color-secondary-500);
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  font-size: 11px;
  display: inline-flex;
}

.tlp-why-card--hero .tlp-why-card__footnote {
  color: #ffffff8c;
}

.tlp-why-card__footnote:before {
  content: "";
  background: currentColor;
  border-radius: 50%;
  width: 4px;
  height: 4px;
}

@media (min-width: 768px) {
  .tlp-why__grid {
    grid-template-columns: 1fr 1fr 1fr;
    align-items: stretch;
  }

  .tlp-why-card--hero {
    grid-column: span 3;
  }
}

.tlp-match {
  background: var(--color-surface-card);
  padding: 56px 20px 48px;
  position: relative;
  overflow: hidden;
}

.tlp-match:before {
  content: "";
  inset-inline-end: -80px;
  background: radial-gradient(circle, var(--color-primary-50), transparent 70%);
  pointer-events: none;
  width: 240px;
  height: 240px;
  position: absolute;
  top: 40px;
}

.tlp-match > * {
  z-index: 1;
  position: relative;
}

.tlp-hamrah-title__em {
  color: var(--color-primary-700);
  font-style: normal;
}

.tlp-hamrah {
  color: #fff;
  background: linear-gradient(145deg, #16272a 0%, #0e7c7b 55%, #1a5958 100%);
  border-radius: 20px;
  margin: 22px 0 32px;
  padding: 28px 22px 26px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 12px 28px #0e7c7b38;
}

.tlp-hamrah:before {
  content: "";
  pointer-events: none;
  background-image: radial-gradient(circle at 88% 12%, #d4a24c38 0%, #0000 42%), radial-gradient(circle at 10% 90%, #3bafa947 0%, #0000 45%), radial-gradient(circle, #f5efe314 1px, #0000 1.5px);
  background-size: 100% 100%, 100% 100%, 14px 14px;
  position: absolute;
  inset: 0;
}

.tlp-hamrah > * {
  z-index: 1;
  position: relative;
}

.tlp-hamrah__badge {
  letter-spacing: .1em;
  color: #ffffffb3;
  background: #ffffff14;
  border: 1px solid #ffffff29;
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  margin-bottom: 18px;
  padding: 5px 10px;
  font-size: 10px;
  font-weight: 700;
  display: inline-flex;
}

.tlp-hamrah__badge-dot {
  background: var(--color-accent-400);
  width: 5px;
  height: 5px;
  box-shadow: 0 0 6px var(--color-accent-400);
  border-radius: 50%;
}

.tlp-hamrah__head {
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  display: flex;
}

.tlp-hamrah__mark {
  filter: drop-shadow(0 4px 12px #d4a24c59);
  flex-shrink: 0;
  place-items: center;
  width: 64px;
  height: 64px;
  display: grid;
  position: relative;
}

.tlp-hamrah__mark svg {
  width: 100%;
  height: 100%;
  display: block;
}

.tlp-hamrah__mark:after {
  content: "";
  z-index: -1;
  background: radial-gradient(circle, #d4a24c38 0%, #0000 65%);
  border-radius: 50%;
  animation: 3.2s ease-in-out infinite tlp-hamrah-halo;
  position: absolute;
  inset: -6px;
}

@keyframes tlp-hamrah-halo {
  0%, 100% {
    opacity: .6;
    transform: scale(1);
  }

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

@media (prefers-reduced-motion: reduce) {
  .tlp-hamrah__mark:after {
    opacity: .85;
    animation: none;
  }
}

.tlp-hamrah__name {
  letter-spacing: -.02em;
  color: #fff;
  margin: 0 0 4px;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
}

.tlp-hamrah__tm {
  color: var(--color-accent-400);
  vertical-align: super;
  margin-inline-start: 4px;
  font-size: 11px;
  font-weight: 600;
}

.tlp-hamrah__tagline {
  color: var(--color-heritage-300);
  letter-spacing: .02em;
  margin: 0;
  font-size: 12px;
  font-weight: 500;
}

.tlp-hamrah__pitch {
  color: #ffffffe0;
  text-wrap: pretty;
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.7;
}

.tlp-hamrah__pitch strong {
  color: var(--color-accent-400);
  font-weight: 700;
}

.tlp-hamrah__facts {
  border-top: 1px solid #ffffff1f;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding-top: 16px;
  display: grid;
}

.tlp-hamrah__fact {
  text-align: center;
  padding: 0 4px;
}

.tlp-hamrah__fact + .tlp-hamrah__fact {
  border-inline-start: 1px solid #ffffff1a;
}

.tlp-hamrah__fact-n {
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.1;
}

.tlp-hamrah__fact-l {
  color: #fff9;
  margin-top: 4px;
  font-size: 10px;
  line-height: 1.4;
}

.tlp-hamrah__sub-eyebrow {
  color: var(--color-heritage-700);
  margin-top: 8px;
}

.tlp-hamrah__sub-eyebrow:before {
  background: var(--color-heritage-600);
}

.tlp-hamrah__sub-title {
  margin-bottom: 8px;
  font-size: 22px;
}

.tlp-match-diagram {
  background: var(--color-secondary-50);
  border: 1px solid var(--color-secondary-200);
  border-radius: 20px;
  margin-top: 24px;
  padding: 20px 18px 22px;
  position: relative;
}

.tlp-match-diagram__head {
  color: var(--color-primary-700);
  letter-spacing: .04em;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  font-size: 11px;
  font-weight: 700;
  display: flex;
}

.tlp-match-diagram__pulse {
  background: var(--color-primary-600);
  border-radius: 50%;
  width: 8px;
  height: 8px;
  animation: 2s infinite tlp-pulse-match;
  box-shadow: 0 0 #0e7c7b66;
}

@keyframes tlp-pulse-match {
  0% {
    box-shadow: 0 0 #0e7c7b73;
  }

  70% {
    box-shadow: 0 0 0 10px #0e7c7b00;
  }

  100% {
    box-shadow: 0 0 #0e7c7b00;
  }
}

@media (prefers-reduced-motion: reduce) {
  .tlp-match-diagram__pulse {
    animation: none;
  }
}

.tlp-match-row {
  grid-template-columns: 1fr auto 1fr;
  align-items: stretch;
  gap: 10px;
  display: grid;
}

.tlp-match-side {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  border-radius: 12px;
  flex-direction: column;
  padding: 12px;
  display: flex;
}

.tlp-match-side__label {
  letter-spacing: .06em;
  color: var(--color-secondary-500);
  text-transform: uppercase;
  margin-bottom: 8px;
  font-size: 10px;
  font-weight: 700;
}

.tlp-match-tour {
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  display: flex;
}

.tlp-match-tour__img {
  background: linear-gradient(135deg, var(--color-heritage-400), var(--color-primary-700));
  border-radius: 8px;
  flex-shrink: 0;
  width: 38px;
  height: 38px;
}

.tlp-match-tour__name {
  color: var(--color-secondary-900);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.25;
}

.tlp-match-tour__meta {
  color: var(--color-secondary-500);
  margin-top: 2px;
  font-size: 10px;
}

.tlp-match-tags {
  flex-wrap: wrap;
  gap: 4px;
  margin-top: auto;
  display: flex;
}

.tlp-match-tag {
  background: var(--color-heritage-50);
  color: var(--color-heritage-700);
  border: 1px solid var(--color-heritage-100);
  border-radius: 999px;
  padding: 3px 7px;
  font-size: 10px;
  font-weight: 500;
}

.tlp-match-tag--saffron {
  background: var(--color-accent-50);
  color: var(--color-accent-700);
  border-color: var(--color-accent-100);
}

.tlp-match-arrow {
  place-items: center;
  padding: 0 2px;
  display: grid;
  position: relative;
}

.tlp-match-arrow__core {
  background: var(--color-primary-600);
  color: #fff;
  border-radius: 50%;
  place-items: center;
  width: 38px;
  height: 38px;
  display: grid;
  box-shadow: 0 0 0 6px #0e7c7b1f, 0 0 0 12px #0e7c7b0f;
}

.tlp-match-arrow:before, .tlp-match-arrow:after {
  content: "";
  background: repeating-linear-gradient(90deg, var(--color-primary-400) 0 4px, transparent 4px 8px);
  height: 1.5px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.tlp-match-arrow:before {
  width: 28px;
  inset-inline-end: calc(50% + 22px);
}

.tlp-match-arrow:after {
  width: 28px;
  inset-inline-start: calc(50% + 22px);
}

.tlp-match-people {
  flex-direction: column;
  gap: 6px;
  display: flex;
}

.tlp-match-person {
  background: var(--color-primary-50);
  border: 1px solid var(--color-primary-100);
  border-radius: 10px;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  display: flex;
}

.tlp-match-person__avatar {
  background: var(--color-heritage-500);
  color: #fff;
  border-radius: 50%;
  flex-shrink: 0;
  place-items: center;
  width: 26px;
  height: 26px;
  font-size: 11px;
  font-weight: 700;
  display: grid;
}

.tlp-match-person__avatar--saffron {
  background: var(--color-accent-600);
}

.tlp-match-person__avatar--stone {
  background: var(--color-secondary-600);
}

.tlp-match-person__name {
  color: var(--color-secondary-900);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
}

.tlp-match-person__why {
  color: var(--color-secondary-500);
  margin-top: 1px;
  font-size: 9.5px;
  line-height: 1.3;
}

.tlp-match-person__score {
  color: var(--color-primary-700);
  background: var(--color-surface-card);
  font-variant-numeric: tabular-nums;
  border: 1px solid var(--color-primary-200);
  border-radius: 999px;
  flex-shrink: 0;
  margin-inline-start: auto;
  padding: 2px 7px;
  font-size: 10px;
  font-weight: 700;
}

.tlp-match-caption {
  color: var(--color-secondary-500);
  text-align: center;
  margin: 16px 0 0;
  padding: 0 8px;
  font-size: 11px;
  line-height: 1.6;
}

.tlp-match-caption strong {
  color: var(--color-primary-700);
  font-weight: 700;
}

.tlp-match-steps {
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 18px;
  display: grid;
}

.tlp-match-step {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  border-radius: 12px;
  align-items: flex-start;
  gap: 12px;
  padding: 14px;
  display: flex;
}

.tlp-match-step__num {
  background: var(--color-primary-700);
  color: #fff;
  font-variant-numeric: tabular-nums;
  border-radius: 8px;
  flex-shrink: 0;
  place-items: center;
  width: 26px;
  height: 26px;
  font-size: 12px;
  font-weight: 700;
  display: grid;
}

.tlp-match-step__text h4 {
  color: var(--color-secondary-900);
  margin: 2px 0 3px;
  font-size: 14px;
  font-weight: 700;
}

.tlp-match-step__text p {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 12.5px;
  line-height: 1.55;
}

.tlp-match-reassure {
  background: var(--color-heritage-50);
  border: 1px solid var(--color-heritage-100);
  border-radius: 12px;
  align-items: flex-start;
  gap: 10px;
  margin-top: 18px;
  padding: 14px;
  display: flex;
}

.tlp-match-reassure svg {
  color: var(--color-heritage-700);
  flex-shrink: 0;
  margin-top: 1px;
}

.tlp-match-reassure p {
  color: var(--color-secondary-700);
  margin: 0;
  font-size: 12.5px;
  line-height: 1.6;
}

.tlp-match-reassure strong {
  color: var(--color-heritage-700);
  font-weight: 700;
}

.tlp-marketplace {
  background: var(--color-surface-card);
  padding: 56px 20px;
}

.tlp-market-mock {
  background: var(--color-secondary-50);
  border: 1px solid var(--color-secondary-200);
  border-radius: 20px;
  margin-top: 24px;
  padding: 20px 16px;
  position: relative;
  overflow: hidden;
}

.tlp-market-status {
  color: var(--color-secondary-600);
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  padding: 0 4px;
  font-size: 11px;
  display: flex;
}

.tlp-market-status strong {
  color: var(--color-secondary-900);
  font-weight: 700;
}

.tlp-market-pill {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  font-variant-numeric: tabular-nums;
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  display: inline-flex;
}

.tlp-market-pill__dot {
  background: #3baf6a;
  border-radius: 50%;
  width: 6px;
  height: 6px;
  box-shadow: 0 0 0 3px #3baf6a2e;
}

.tlp-market-card {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-100);
  border-radius: 14px;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
  padding: 12px;
  display: flex;
  box-shadow: 0 1px 2px #1f1c170a;
}

.tlp-market-card--featured {
  background: var(--color-primary-50);
  border-color: var(--color-primary-200);
  box-shadow: 0 2px 8px #0e7c7b1f;
}

.tlp-market-card__img {
  background: linear-gradient(135deg, var(--color-heritage-400), var(--color-primary-700));
  border-radius: 10px;
  flex-shrink: 0;
  width: 72px;
  height: 72px;
  position: relative;
  overflow: hidden;
}

.tlp-market-card--featured .tlp-market-card__img {
  background: linear-gradient(135deg, var(--color-accent-400), var(--color-celebration-600));
}

.tlp-market-card--v2 .tlp-market-card__img {
  background: linear-gradient(135deg, #86b9a0, var(--color-secondary-600));
}

.tlp-market-card__img:after {
  content: "";
  background-image: radial-gradient(circle at 30% 30%, #fff3 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

.tlp-market-card__body {
  flex: 1;
  min-width: 0;
}

.tlp-market-card__name {
  color: var(--color-secondary-900);
  letter-spacing: -.01em;
  align-items: center;
  gap: 6px;
  margin: 0 0 2px;
  font-size: 13px;
  font-weight: 700;
  display: flex;
}

.tlp-market-card__badge {
  background: var(--color-accent-500);
  color: var(--color-secondary-900);
  letter-spacing: .04em;
  border-radius: 999px;
  padding: 2px 6px;
  font-size: 9px;
  font-weight: 700;
}

.tlp-market-card__meta {
  color: var(--color-secondary-500);
  margin: 0 0 6px;
  font-size: 11px;
}

.tlp-market-card__foot {
  color: var(--color-secondary-600);
  font-variant-numeric: tabular-nums;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  display: flex;
}

.tlp-market-card__price {
  color: var(--color-secondary-900);
  font-weight: 700;
}

.tlp-market-card__seats {
  background: var(--color-secondary-100);
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 10px;
}

.tlp-market-card--featured .tlp-market-card__seats {
  background: var(--color-primary-600);
  color: #fff;
}

.tlp-market-caption {
  text-align: center;
  color: var(--color-secondary-500);
  margin: 12px 0 0;
  font-size: 11px;
  line-height: 1.6;
}

.tlp-market-caption strong {
  color: var(--color-heritage-700);
  font-weight: 700;
}

.tlp-numbers {
  background: var(--color-secondary-900);
  color: #f5efe3;
  text-align: center;
  padding: 56px 20px;
  position: relative;
  overflow: hidden;
}

.tlp-numbers:before {
  content: "";
  opacity: .4;
  pointer-events: none;
  background-image: radial-gradient(circle, #3bafa92e 1px, #0000 2px);
  background-size: 22px 22px;
  position: absolute;
  inset: 0;
}

.tlp-numbers__content {
  z-index: 1;
  position: relative;
}

.tlp-numbers__content .lp-section-title {
  color: #fff;
}

.tlp-numbers__content .lp-section-lead {
  color: #f5efe3a6;
  margin-inline: auto;
}

.tlp-numbers__eyebrow {
  color: var(--color-heritage-400);
}

.tlp-numbers__eyebrow:before {
  background: var(--color-heritage-500);
}

.tlp-numbers__grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 24px;
  display: grid;
}

@media (min-width: 768px) {
  .tlp-numbers__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.tlp-big-stat {
  text-align: center;
  background: #ffffff0d;
  border: 1px solid #ffffff14;
  border-radius: 14px;
  padding: 20px 14px;
}

.tlp-big-stat__n {
  color: var(--color-heritage-400);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.02em;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.1;
}

.tlp-big-stat__n--saffron {
  color: var(--color-accent-500);
}

.tlp-big-stat__l {
  color: #f5efe3b3;
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.5;
}

.tlp-ops {
  background: var(--color-surface-background);
  padding: 56px 20px;
}

.tlp-ops__intro {
  margin-bottom: 24px;
}

.tlp-ops__note {
  color: var(--color-secondary-600);
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  border-radius: 999px;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 600;
  display: inline-flex;
}

.tlp-ops__note-dot {
  background: var(--color-heritage-600);
  border-radius: 50%;
  width: 6px;
  height: 6px;
}

.tlp-ops__eyebrow {
  color: var(--color-heritage-700);
}

.tlp-ops__eyebrow:before {
  background: var(--color-heritage-600);
}

.tlp-ops-card {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  border-radius: 14px;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 10px;
  padding: 20px;
  display: flex;
}

.tlp-ops-card__icon {
  background: var(--color-heritage-50);
  width: 42px;
  height: 42px;
  color: var(--color-heritage-700);
  border-radius: 11px;
  flex-shrink: 0;
  place-items: center;
  display: grid;
}

.tlp-ops-card__icon--saffron {
  background: var(--color-accent-50);
  color: var(--color-accent-700);
}

.tlp-ops-card__icon--primary {
  background: var(--color-primary-50);
  color: var(--color-primary-700);
}

.tlp-ops-card__icon--stone {
  background: var(--color-secondary-100);
  color: var(--color-secondary-700);
}

.tlp-ops-card__icon--heritage {
  background: var(--color-heritage-50);
  color: var(--color-heritage-700);
}

.tlp-ops-card__text {
  flex: 1;
  min-width: 0;
  padding-top: 2px;
}

.tlp-ops-card__text h4 {
  color: var(--color-secondary-900);
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 700;
}

.tlp-ops-card__text p {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 13px;
  line-height: 1.6;
}

.tlp-ops-card__replaces {
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 10px;
  display: flex;
}

.tlp-ops-card__replace-chip {
  color: var(--color-secondary-600);
  background: var(--color-secondary-50);
  border: 1px solid var(--color-secondary-200);
  text-decoration: line-through;
  -webkit-text-decoration-color: var(--color-celebration-500);
  text-decoration-color: var(--color-celebration-500);
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 600;
  text-decoration-thickness: 1.5px;
}

.tlp-pricing {
  background: var(--color-surface-card);
  padding: 56px 20px 40px;
}

.tlp-plan {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  border-radius: 20px;
  margin: 20px 0 0;
  padding: 28px 24px 24px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 12px #11181c0a;
}

.tlp-plan:before {
  content: "";
  top: 0;
  background: radial-gradient(circle at 100% 0%, var(--color-heritage-50) 0%, transparent 70%);
  pointer-events: none;
  width: 160px;
  height: 160px;
  position: absolute;
  inset-inline-end: 0;
}

.tlp-plan > * {
  z-index: 1;
  position: relative;
}

.tlp-plan__eyebrow {
  letter-spacing: .1em;
  color: var(--color-primary-700);
  text-transform: uppercase;
  margin-bottom: 14px;
  font-size: 11px;
  font-weight: 700;
  display: block;
}

.tlp-plan__price {
  font-variant-numeric: tabular-nums;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 6px;
  display: flex;
}

.tlp-plan__num {
  color: var(--color-secondary-900);
  letter-spacing: -.035em;
  font-size: 68px;
  font-weight: 700;
  line-height: .9;
}

.tlp-plan__unit {
  color: var(--color-secondary-600);
  font-size: 17px;
  font-weight: 600;
}

.tlp-plan__term {
  color: var(--color-secondary-700);
  margin: 0 0 6px;
  font-size: 15px;
  font-weight: 500;
}

.tlp-plan__term strong {
  color: var(--color-secondary-900);
  font-weight: 700;
}

.tlp-plan__after {
  color: var(--color-secondary-500);
  margin: 0 0 22px;
  font-size: 13px;
  line-height: 1.6;
}

.tlp-plan__after strong {
  color: var(--color-secondary-700);
  font-weight: 600;
}

.tlp-plan__divider {
  background: var(--color-secondary-200);
  border: 0;
  height: 1px;
  margin: 0 0 20px;
}

.tlp-plan__features {
  grid-template-columns: 1fr 1fr;
  gap: 10px 16px;
  margin: 0 0 22px;
  padding: 0;
  list-style: none;
  display: grid;
}

.tlp-plan__features li {
  color: var(--color-secondary-700);
  padding-inline-start: 22px;
  font-size: 13px;
  line-height: 1.5;
  position: relative;
}

.tlp-plan__features li:before {
  content: "";
  inset-inline-start: 0;
  background: var(--color-primary-50);
  border: 1px solid var(--color-primary-200);
  border-radius: 50%;
  width: 14px;
  height: 14px;
  position: absolute;
  top: 5px;
}

.tlp-plan__features li:after {
  content: "";
  inset-inline-start: 4px;
  border-inline-start: 1.5px solid var(--color-primary-700);
  border-bottom: 1.5px solid var(--color-primary-700);
  width: 6px;
  height: 3px;
  position: absolute;
  top: 8px;
  transform: rotate(-45deg);
}

@media (max-width: 380px) {
  .tlp-plan__features {
    grid-template-columns: 1fr;
  }
}

.tlp-plan__cta {
  width: 100%;
}

.tlp-plan__fine {
  color: var(--color-secondary-500);
  text-align: center;
  margin: 12px 0 0;
  font-size: 12px;
}

.tlp-testimonials {
  background: #faf7f2;
  padding: 56px 20px;
}

.tlp-testimonial {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-100);
  border-radius: 14px;
  margin-bottom: 12px;
  padding: 20px;
  position: relative;
}

.tlp-testimonial:before {
  content: "“";
  top: 10px;
  color: var(--color-primary-200);
  pointer-events: none;
  font-family: Georgia, serif;
  font-size: 44px;
  line-height: 1;
  position: absolute;
  inset-inline-end: 18px;
}

.tlp-testimonial blockquote {
  margin: 0;
}

.tlp-testimonial p {
  color: var(--color-secondary-700);
  margin: 0 0 16px;
  padding-inline-start: 4px;
  font-size: 14px;
  line-height: 1.7;
}

.tlp-testimonial__meta {
  align-items: center;
  gap: 10px;
  display: flex;
}

.tlp-testimonial__avatar {
  background: var(--color-primary-600);
  color: #fff;
  border: 2px solid var(--color-surface-card);
  border-radius: 999px;
  place-items: center;
  width: 36px;
  height: 36px;
  font-size: 12px;
  font-weight: 700;
  display: grid;
  box-shadow: 0 1px 2px #1f1c1714;
}

.tlp-testimonial__avatar--heritage {
  background: var(--color-heritage-500);
}

.tlp-testimonial__avatar--saffron {
  background: var(--color-accent-600);
}

.tlp-testimonial__name {
  color: var(--color-secondary-900);
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.3;
}

.tlp-testimonial__role {
  color: var(--color-secondary-500);
  margin: 2px 0 0;
  font-size: 11px;
}

.tlp-faq {
  background: var(--color-surface-card);
  padding: 56px 20px;
}

.tlp-faq-item {
  border-bottom: 1px solid var(--color-secondary-200);
  padding: 18px 0;
}

.tlp-faq-q {
  color: var(--color-secondary-900);
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  font-weight: 600;
  list-style: none;
  display: flex;
}

.tlp-faq-q::-webkit-details-marker {
  display: none;
}

.tlp-faq-q__icon {
  background: var(--color-secondary-100);
  width: 24px;
  height: 24px;
  color: var(--color-secondary-600);
  transition: transform .25s var(--lp-easing-default), background .2s;
  border-radius: 999px;
  flex-shrink: 0;
  place-items: center;
  font-size: 14px;
  display: grid;
}

.tlp-faq-item[open] .tlp-faq-q__icon {
  background: var(--color-primary-100);
  color: var(--color-primary-700);
  transform: rotate(45deg);
}

@media (prefers-reduced-motion: reduce) {
  .tlp-faq-q__icon {
    transition: none;
  }
}

.tlp-faq-a {
  color: var(--color-secondary-600);
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.7;
}

.tlp-cta-final {
  background: linear-gradient(135deg, var(--color-primary-700) 0%, var(--color-primary-900) 100%);
  color: #fff;
  text-align: center;
  padding: 56px 24px;
  position: relative;
  overflow: hidden;
}

.tlp-cta-final:before {
  content: "";
  pointer-events: none;
  background-image: radial-gradient(circle, #d4a24c1f 1px, #0000 2px);
  background-size: 16px 16px;
  position: absolute;
  inset: 0;
}

.tlp-cta-final__content {
  z-index: 1;
  position: relative;
}

.tlp-cta-final__eyebrow {
  color: var(--color-accent-400);
}

.tlp-cta-final__eyebrow:before {
  background: var(--color-accent-400);
}

.tlp-cta-final__title {
  color: #fff;
  letter-spacing: -.02em;
  margin: 0 0 10px;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.25;
}

.tlp-cta-final__body {
  color: #ffffffc7;
  margin: 0 0 22px;
  font-size: 14px;
  line-height: 1.7;
}

.tlp-cta-final__buttons {
  flex-direction: column;
  align-items: center;
  gap: 10px;
  display: flex;
}

.tlp-cta-final__primary {
  min-width: 240px;
}

.tlp-cta-final__secondary {
  color: #ffffffd9;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.tlp-cta-final__secondary:hover {
  color: #fff;
}

.tlp-cta-final__arrow {
  display: inline-block;
}

@media (min-width: 768px) {
  .tlp-hero {
    padding: 64px 32px 40px;
  }

  .tlp-hero__title {
    font-size: 48px;
  }

  .tlp-match, .tlp-marketplace, .tlp-numbers, .tlp-ops, .tlp-pricing, .tlp-testimonials, .tlp-faq, .tlp-cta-final, .tlp-why {
    padding-inline: 32px;
  }
}

:root {
  --cp-celebration-700: #6e2329;
}

.cp-root {
  background: #faf7f2;
}

.cp-tl-ribbon {
  background: linear-gradient(90deg, #050402 0%, var(--color-secondary-900) 50%, #050402 100%);
  color: #f5efe3;
  isolation: isolate;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 12px 18px;
  font-size: 13px;
  text-decoration: none;
  display: flex;
  position: relative;
}

.cp-tl-ribbon:after {
  content: "";
  inset-inline: 0;
  background: linear-gradient(90deg, transparent 0%, var(--color-accent-500) 30%, var(--color-accent-300) 50%, var(--color-accent-500) 70%, transparent 100%);
  opacity: .85;
  pointer-events: none;
  height: 1.5px;
  position: absolute;
  bottom: 0;
}

.cp-tl-ribbon__text {
  align-items: center;
  gap: 10px;
  min-width: 0;
  line-height: 1.35;
  display: flex;
}

.cp-tl-ribbon__dot {
  background: var(--color-accent-500);
  border-radius: 50%;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  box-shadow: 0 0 8px #d4a24cb3;
}

.cp-tl-ribbon__text strong {
  color: #fff;
  letter-spacing: -.005em;
  font-weight: 700;
}

.cp-tl-ribbon__text .cp-dim {
  color: #f5efe39e;
}

.cp-tl-ribbon__cta {
  color: #050402;
  background: var(--color-accent-500);
  white-space: nowrap;
  border-radius: 4px;
  flex-shrink: 0;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  font-size: 12.5px;
  font-weight: 700;
  transition: background .18s ease-out, transform .18s ease-out;
  display: inline-flex;
  box-shadow: inset 0 1px #ffffff4d, 0 0 0 1px #0000000d;
}

.cp-tl-ribbon:hover .cp-tl-ribbon__cta {
  background: var(--color-accent-400);
  transform: translateX(-2px);
}

@media (prefers-reduced-motion: reduce) {
  .cp-tl-ribbon__cta {
    transition: none;
  }

  .cp-tl-ribbon:hover .cp-tl-ribbon__cta {
    transform: none;
  }
}

@media (max-width: 480px) {
  .cp-tl-ribbon {
    gap: 10px;
    padding: 10px 14px;
    font-size: 12.5px;
  }

  .cp-tl-ribbon__text .cp-dim {
    display: none;
  }

  .cp-tl-ribbon__cta {
    padding: 7px 10px;
    font-size: 12px;
  }
}

.cp-nav {
  z-index: 50;
  -webkit-backdrop-filter: blur(12px);
  background: #faf7f2d1;
  border-bottom: 1px solid #0000;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  transition: border-color .2s, background .2s;
  display: flex;
  position: sticky;
  top: 0;
}

.cp-nav__logo {
  color: var(--color-secondary-900);
  letter-spacing: -.02em;
  align-items: center;
  gap: 8px;
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  display: flex;
}

.cp-nav__mark {
  background: var(--color-heritage-600);
  border-radius: 8px;
  place-items: center;
  width: 28px;
  height: 28px;
  display: grid;
  position: relative;
}

.cp-nav__links {
  align-items: center;
  gap: 18px;
  display: flex;
}

.cp-nav__link {
  color: var(--color-secondary-700);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  transition: color .15s;
}

.cp-nav__link:hover {
  color: var(--color-primary-700);
}

.cp-nav__cta {
  color: #fff;
  background: var(--color-primary-600);
  border-start-start-radius: 10px;
  border-start-end-radius: 3px;
  border-end-end-radius: 10px;
  border-end-start-radius: 3px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: background .2s;
}

.cp-nav__cta:hover {
  background: var(--color-primary-700);
  color: #fff;
}

.cp-hero {
  padding: 44px 20px 36px;
  position: relative;
  overflow: hidden;
}

.cp-hero:before {
  content: "";
  top: -80px;
  background: radial-gradient(circle at center, var(--color-heritage-100), transparent 65%);
  z-index: 0;
  border-radius: 50%;
  width: 320px;
  height: 320px;
  position: absolute;
  inset-inline-end: -80px;
}

.cp-hero:after {
  content: "";
  bottom: 40px;
  background-image: radial-gradient(circle, var(--color-heritage-300) 1px, transparent 1.5px);
  opacity: .45;
  z-index: 0;
  background-size: 16px 16px;
  width: 180px;
  height: 180px;
  position: absolute;
  inset-inline-start: -40px;
}

.cp-hero > * {
  z-index: 1;
  position: relative;
}

.cp-hero__eyebrow {
  letter-spacing: .08em;
  color: var(--color-primary-700);
  background: var(--color-primary-50);
  border: 1px solid var(--color-primary-100);
  border-radius: 999px;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
  padding: 6px 10px 6px 12px;
  font-size: 11.5px;
  font-weight: 700;
  display: inline-flex;
}

.cp-hero__pulse {
  background: var(--color-primary-600);
  border-radius: 50%;
  width: 6px;
  height: 6px;
  animation: 1.8s infinite cp-ai-pulse;
  box-shadow: 0 0 #0e7c7b80;
}

@keyframes cp-ai-pulse {
  0% {
    box-shadow: 0 0 #0e7c7b80;
  }

  70% {
    box-shadow: 0 0 0 7px #0e7c7b00;
  }

  100% {
    box-shadow: 0 0 #0e7c7b00;
  }
}

.cp-hero__title {
  letter-spacing: -.028em;
  color: var(--color-secondary-900);
  text-wrap: balance;
  margin: 0 0 16px;
  font-size: 40px;
  font-weight: 700;
  line-height: 1.18;
}

.cp-hero__title em {
  color: var(--color-primary-700);
  font-style: normal;
  display: inline-block;
  position: relative;
}

.cp-hero__title em:after {
  content: "";
  background: var(--color-primary-100);
  z-index: -1;
  border-radius: 2px;
  height: 12px;
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
}

.cp-hero__lead {
  color: var(--color-secondary-600);
  text-wrap: pretty;
  max-width: 420px;
  margin: 0 0 22px;
  font-size: 15.5px;
  line-height: 1.7;
}

.cp-mock {
  box-shadow: 0 20px 40px #1f1c1714, 0 0 0 1px var(--color-secondary-200) inset;
  background: #fff;
  border-radius: 22px;
  margin: 24px -4px 20px;
  position: relative;
  overflow: hidden;
}

.cp-mock__head {
  background: linear-gradient(180deg, var(--color-primary-50), #fff);
  border-bottom: 1px solid var(--color-secondary-200);
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  display: flex;
}

.cp-mock__ico {
  background: var(--color-primary-600);
  color: #fff;
  border-radius: 9px;
  flex-shrink: 0;
  place-items: center;
  width: 30px;
  height: 30px;
  display: grid;
  position: relative;
}

.cp-mock__ico:after {
  content: "";
  top: -2px;
  background: var(--color-accent-500);
  border: 2px solid #fff;
  border-radius: 50%;
  width: 8px;
  height: 8px;
  position: absolute;
  inset-inline-end: -2px;
}

.cp-mock__title {
  color: var(--color-secondary-900);
  font-size: 13px;
  font-weight: 700;
}

.cp-mock__sub {
  color: var(--color-secondary-500);
  margin-top: 1px;
  font-size: 11px;
}

.cp-mock__body {
  padding: 16px;
}

.cp-mock__query {
  background: var(--color-secondary-100);
  border-radius: 12px;
  color: var(--color-secondary-800);
  margin-bottom: 12px;
  border-start-end-radius: 4px;
  max-width: 85%;
  margin-inline-start: auto;
  padding: 11px 13px;
  font-size: 13px;
  line-height: 1.55;
}

.cp-mock__query b {
  color: var(--color-secondary-900);
  font-weight: 700;
}

.cp-mock__thinking {
  color: var(--color-primary-700);
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding-inline-start: 2px;
  font-size: 11px;
  font-weight: 600;
  display: flex;
}

.cp-mock__dots {
  gap: 3px;
  display: inline-flex;
}

.cp-mock__dots span {
  background: var(--color-primary-500);
  border-radius: 50%;
  width: 4px;
  height: 4px;
  animation: 1.2s infinite cp-dot-pulse;
}

.cp-mock__dots span:nth-child(2) {
  animation-delay: .2s;
}

.cp-mock__dots span:nth-child(3) {
  animation-delay: .4s;
}

@keyframes cp-dot-pulse {
  0%, 60%, 100% {
    opacity: .3;
    transform: scale(1);
  }

  30% {
    opacity: 1;
    transform: scale(1.3);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cp-hero__pulse, .cp-mock__dots span, .cp-hamrah__mark:after, .cp-dang-hook__arrow {
    animation: none;
  }
}

.cp-sug-grid {
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  display: grid;
}

.cp-sug {
  border: 1px solid var(--color-secondary-200);
  opacity: 0;
  background: #fff;
  border-radius: 12px;
  animation: .5s cubic-bezier(0, 0, .2, 1) forwards cp-sug-in;
  position: relative;
  overflow: hidden;
  transform: translateY(6px);
}

.cp-sug:first-child {
  animation-delay: .6s;
}

.cp-sug:nth-child(2) {
  animation-delay: .9s;
}

@keyframes cp-sug-in {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cp-sug {
    opacity: 1;
    animation: none;
    transform: none;
  }
}

.cp-sug__match {
  top: 6px;
  z-index: 2;
  color: #fff;
  background: #0e7c7bf0;
  border-radius: 999px;
  align-items: center;
  gap: 4px;
  padding: 3px 7px;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  position: absolute;
  inset-inline-end: 6px;
}

.cp-sug__match:before {
  content: "";
  background: #fff;
  border-radius: 50%;
  width: 4px;
  height: 4px;
}

.cp-sug__image {
  height: 78px;
  position: relative;
  overflow: hidden;
}

.cp-sug__image--heritage {
  background: linear-gradient(135deg, var(--color-heritage-300) 0%, var(--color-heritage-700) 100%);
}

.cp-sug__image--saffron {
  background: linear-gradient(135deg, var(--color-accent-400) 0%, var(--color-accent-700) 100%);
}

.cp-sug__image--teal {
  background: linear-gradient(135deg, var(--color-primary-400) 0%, var(--color-primary-800) 100%);
}

.cp-sug__image--pom {
  background: linear-gradient(135deg, #d89593 0%, var(--cp-celebration-700) 100%);
}

.cp-sug__image svg {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.cp-sug__body {
  padding: 8px 10px 10px;
}

.cp-sug__title {
  color: var(--color-secondary-900);
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0 0 3px;
  font-size: 12.5px;
  font-weight: 700;
  overflow: hidden;
}

.cp-sug__meta {
  color: var(--color-secondary-500);
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  display: flex;
}

.cp-sug__meta .cp-star {
  color: var(--color-accent-600);
  font-weight: 700;
}

.cp-sug__meta .cp-sep {
  background: var(--color-secondary-300);
  border-radius: 50%;
  width: 3px;
  height: 3px;
}

.cp-hero__cta-row {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
  display: flex;
}

.cp-hero__cta-row .lp-btn {
  flex: 1;
  justify-content: center;
  min-width: 140px;
}

.cp-trust-row {
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
  display: flex;
}

.cp-trust-chip {
  background: var(--color-secondary-100);
  color: var(--color-secondary-600);
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  font-size: 11px;
  display: inline-flex;
}

.cp-trust-chip__dot {
  background: var(--color-primary-500);
  border-radius: 999px;
  width: 6px;
  height: 6px;
}

.cp-dang-hook {
  background: linear-gradient(135deg, var(--color-heritage-50) 0%, #fff 65%);
  border: 1px solid var(--color-heritage-200);
  color: inherit;
  border-radius: 18px;
  margin: 8px 20px 32px;
  padding: 20px 20px 18px;
  text-decoration: none;
  display: block;
  position: relative;
  overflow: hidden;
}

.cp-dang-hook:after {
  content: "";
  top: -20px;
  background: var(--color-heritage-100);
  opacity: .5;
  border-radius: 50%;
  width: 100px;
  height: 100px;
  position: absolute;
  inset-inline-end: -20px;
}

.cp-dang-hook__inner {
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 16px;
  display: grid;
  position: relative;
}

.cp-dang-hook__label {
  letter-spacing: .1em;
  color: var(--color-heritage-700);
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
  font-size: 10.5px;
  font-weight: 700;
  display: inline-flex;
}

.cp-free-tag {
  background: var(--color-heritage-600);
  color: #fff;
  letter-spacing: 0;
  border-radius: 4px;
  padding: 2px 6px;
  font-size: 9.5px;
}

.cp-dang-hook__title {
  color: var(--color-secondary-900);
  letter-spacing: -.01em;
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
}

.cp-dang-hook__sub {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 12.5px;
  line-height: 1.55;
}

.cp-dang-hook__viz {
  flex-shrink: 0;
  width: 82px;
  height: 82px;
  position: relative;
}

.cp-dang-hook__stack {
  border: 1px solid var(--color-heritage-200);
  background: #fff;
  border-radius: 10px;
  flex-direction: column;
  gap: 3px;
  padding: 7px 8px;
  display: flex;
  position: absolute;
  inset: 0;
}

.cp-dang-hook__stack--1 {
  z-index: 1;
  opacity: .7;
  inset: 4px 2px 0 6px;
  transform: rotate(-6deg);
}

.cp-dang-hook__stack--2 {
  z-index: 2;
  transform: rotate(3deg);
}

.cp-dang-hook__bar {
  background: var(--color-secondary-200);
  border-radius: 2px;
  height: 4px;
}

.cp-dang-hook__bar--1 {
  background: var(--color-heritage-400);
  width: 60%;
}

.cp-dang-hook__bar--2 {
  background: var(--color-heritage-300);
  width: 80%;
}

.cp-dang-hook__bar--3 {
  background: var(--color-heritage-200);
  width: 70%;
}

.cp-dang-hook__amt {
  color: var(--color-heritage-700);
  text-align: end;
  font-variant-numeric: tabular-nums;
  margin-top: auto;
  font-size: 9px;
  font-weight: 700;
}

.cp-dang-hook__arrow {
  bottom: 8px;
  color: var(--color-heritage-600);
  opacity: 0;
  z-index: 3;
  animation: 1.6s ease-in-out 1.2s infinite cp-arrow-bob;
  position: absolute;
  inset-inline-start: 8px;
}

@keyframes cp-arrow-bob {
  0%, 100% {
    opacity: .8;
    transform: translateY(0);
  }

  50% {
    opacity: 1;
    transform: translateY(-3px);
  }
}

.cp-hamrah {
  background: #faf7f2;
  padding: 56px 20px 40px;
  position: relative;
}

.cp-hamrah__eyebrow {
  text-align: center;
  margin-bottom: 10px;
  display: block;
}

.cp-hamrah__eyebrow > span {
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-primary-700);
  background: var(--color-primary-50);
  border: 1px solid var(--color-primary-100);
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  font-size: 10.5px;
  font-weight: 700;
  display: inline-flex;
}

.cp-hamrah__eyebrow > span:before {
  content: "";
  background: var(--color-primary-600);
  border-radius: 50%;
  width: 5px;
  height: 5px;
}

.cp-hamrah__title {
  color: var(--color-secondary-900);
  text-align: center;
  letter-spacing: -.02em;
  text-wrap: balance;
  max-width: 340px;
  margin: 0 auto 14px;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.25;
}

.cp-hamrah__title em {
  color: var(--color-primary-700);
  font-style: normal;
  display: inline-block;
  position: relative;
}

.cp-hamrah__title em:after {
  content: "";
  background: var(--color-primary-100);
  z-index: -1;
  border-radius: 2px;
  height: 10px;
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
}

.cp-hamrah__lead {
  color: var(--color-secondary-600);
  text-align: center;
  text-wrap: pretty;
  max-width: 380px;
  margin: 0 auto 28px;
  font-size: 14px;
  line-height: 1.7;
}

.cp-hamrah__intro {
  background: radial-gradient(ellipse at top right, #d4a24c2e, transparent 60%), linear-gradient(135deg, var(--color-primary-800) 0%, var(--color-primary-900) 100%);
  color: #fff;
  border-radius: 22px;
  padding: 28px 22px 24px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 12px 28px #0e7c7b38;
}

.cp-hamrah__intro:before {
  content: "";
  inset-inline-end: -40px;
  opacity: .6;
  pointer-events: none;
  background-image: radial-gradient(circle, #d4a24c38 1px, #0000 1.5px);
  background-size: 14px 14px;
  width: 180px;
  height: 180px;
  position: absolute;
  bottom: -40px;
}

.cp-hamrah__intro > * {
  z-index: 1;
  position: relative;
}

.cp-hamrah__badge {
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-accent-400);
  background: #d4a24c24;
  border: 1px solid #d4a24c4d;
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  margin-bottom: 18px;
  padding: 5px 10px;
  font-size: 10px;
  font-weight: 700;
  display: inline-flex;
}

.cp-hamrah__badge-dot {
  background: var(--color-accent-400);
  border-radius: 50%;
  width: 5px;
  height: 5px;
  box-shadow: 0 0 0 3px #d4a24c40;
}

.cp-hamrah__head {
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  display: flex;
}

.cp-hamrah__mark {
  filter: drop-shadow(0 4px 12px #d4a24c59);
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  position: relative;
}

.cp-hamrah__mark svg {
  width: 100%;
  height: 100%;
  display: block;
}

.cp-hamrah__mark:after {
  content: "";
  z-index: -1;
  background: radial-gradient(circle, #d4a24c38 0%, #0000 65%);
  border-radius: 50%;
  animation: 3.2s ease-in-out infinite cp-hamrah-halo;
  position: absolute;
  inset: -10px;
}

@keyframes cp-hamrah-halo {
  0%, 100% {
    opacity: .6;
    transform: scale(1);
  }

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

.cp-hamrah__name {
  letter-spacing: -.02em;
  color: #fff;
  margin: 0;
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
}

.cp-hamrah__name-tm {
  color: var(--color-accent-400);
  letter-spacing: .02em;
  vertical-align: super;
  margin-inline-start: 6px;
  font-size: 10.5px;
  font-weight: 600;
}

.cp-hamrah__tagline {
  color: var(--color-heritage-300);
  letter-spacing: .02em;
  margin: 6px 0 0;
  font-size: 12px;
  font-weight: 500;
}

.cp-hamrah__pitch {
  color: #ffffffe0;
  text-wrap: pretty;
  margin: 0 0 22px;
  font-size: 14px;
  line-height: 1.7;
}

.cp-hamrah__pitch strong {
  color: var(--color-accent-400);
  font-weight: 700;
}

.cp-hamrah__facts {
  border-top: 1px solid #ffffff1f;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  padding-top: 18px;
  display: grid;
}

.cp-hamrah__fact {
  text-align: center;
  padding: 0 4px;
}

.cp-hamrah__fact-n {
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.1;
}

.cp-hamrah__fact-l {
  color: #fff9;
  margin-top: 3px;
  font-size: 10px;
  line-height: 1.4;
}

.cp-hamrah__fact + .cp-hamrah__fact {
  border-inline-start: 1px solid #ffffff1a;
}

.cp-ornament {
  text-align: center;
  padding: 0 20px 8px;
}

.cp-ornament__row {
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  display: flex;
}

.cp-ornament__line {
  background: var(--color-heritage-300);
  width: 40px;
  height: 1px;
}

.cp-ornament__mark {
  background: var(--color-heritage-500);
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
}

.cp-ornament__title {
  letter-spacing: -.01em;
  color: var(--color-secondary-900);
  text-wrap: pretty;
  margin: 0;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.3;
}

.cp-ornament__lead {
  color: var(--color-secondary-600);
  text-align: center;
  max-width: 360px;
  margin: 8px auto 0;
  font-size: 14px;
  line-height: 1.7;
}

.cp-explore {
  background: #fff;
  border-radius: 28px 28px 0 0;
  padding: 48px 20px 32px;
  position: relative;
}

.cp-explore:before {
  content: "";
  background: var(--color-secondary-200);
  border-radius: 2px;
  width: 48px;
  height: 4px;
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
}

.cp-explore__filters {
  flex-wrap: wrap;
  gap: 8px;
  margin: 20px 0;
  display: flex;
}

.cp-explore__filter {
  background: var(--color-secondary-100);
  color: var(--color-secondary-700);
  border: 1px solid var(--color-secondary-200);
  cursor: pointer;
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 600;
  transition: all .15s;
}

.cp-explore__filter:hover {
  background: var(--color-secondary-200);
}

.cp-explore__filter.is-active {
  background: var(--color-primary-600);
  color: #fff;
  border-color: var(--color-primary-700);
}

.cp-explore__grid {
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  display: grid;
}

.cp-explore__card {
  border: 1px solid var(--color-secondary-200);
  background: #fff;
  border-radius: 14px;
  transition: transform .3s, box-shadow .3s;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 4px #1f1c170a;
}

.cp-explore__card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px #1f1c171a;
}

.cp-explore__image {
  height: 110px;
  position: relative;
  overflow: hidden;
}

.cp-explore__image--teal {
  background: linear-gradient(135deg, var(--color-primary-400), var(--color-primary-800));
}

.cp-explore__image--saffron {
  background: linear-gradient(135deg, var(--color-accent-400), var(--color-accent-700));
}

.cp-explore__image--heritage {
  background: linear-gradient(135deg, var(--color-heritage-300), var(--color-heritage-700));
}

.cp-explore__image--pom {
  background: linear-gradient(135deg, #d89593, var(--cp-celebration-700));
}

.cp-explore__image svg {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.cp-explore__match {
  top: 8px;
  color: var(--color-primary-700);
  background: #fffffff0;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 700;
  position: absolute;
  inset-inline-end: 8px;
}

.cp-explore__body {
  padding: 10px 12px 12px;
}

.cp-explore__title {
  color: var(--color-secondary-900);
  margin: 0 0 3px;
  font-size: 13.5px;
  font-weight: 700;
}

.cp-explore__meta {
  color: var(--color-secondary-500);
  align-items: center;
  gap: 6px;
  font-size: 11px;
  display: flex;
}

.cp-explore__meta .cp-star {
  color: var(--color-accent-600);
  font-weight: 700;
}

.cp-explore__meta .cp-sep {
  background: var(--color-secondary-300);
  border-radius: 50%;
  width: 3px;
  height: 3px;
}

.cp-how {
  background: #faf7f2;
  padding: 48px 20px 32px;
}

.cp-how__grid {
  gap: 12px;
  max-width: 640px;
  margin: 20px auto 0;
  display: grid;
}

.cp-how__item {
  border: 1px solid var(--color-secondary-200);
  background: #fff;
  border-radius: 14px;
  grid-template-columns: 40px 1fr;
  align-items: start;
  gap: 14px;
  padding: 18px 18px 16px;
  display: grid;
}

.cp-how__ico {
  background: var(--color-primary-50);
  width: 40px;
  height: 40px;
  color: var(--color-primary-700);
  border: 1px solid var(--color-primary-100);
  border-radius: 11px;
  place-items: center;
  display: grid;
}

.cp-how__item h4 {
  color: var(--color-secondary-900);
  letter-spacing: -.005em;
  margin: 2px 0 4px;
  font-size: 15px;
  font-weight: 700;
}

.cp-how__item p {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 13px;
  line-height: 1.65;
}

.cp-dang {
  background: #fff;
  padding: 48px 20px 40px;
  position: relative;
}

.cp-dang__head {
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  display: flex;
}

.cp-dang__pill {
  letter-spacing: .1em;
  background: var(--color-heritage-50);
  color: var(--color-heritage-700);
  border: 1px solid var(--color-heritage-200);
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  font-size: 10.5px;
  font-weight: 700;
  display: inline-flex;
}

.cp-dang__pill .cp-free-tag {
  margin-inline-end: 4px;
  padding: 1px 5px;
  font-size: 9px;
}

.cp-dang__title {
  color: var(--color-secondary-900);
  letter-spacing: -.015em;
  text-wrap: balance;
  margin: 0 0 10px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.3;
}

.cp-dang__lead {
  color: var(--color-secondary-600);
  max-width: 460px;
  margin: 0 0 22px;
  font-size: 14.5px;
  line-height: 1.7;
}

.cp-dang__preview {
  background: linear-gradient(180deg, #fff, var(--color-heritage-50));
  box-shadow: 0 12px 28px #1f1c1714, 0 0 0 1px var(--color-secondary-200) inset;
  border-radius: 18px;
  margin-bottom: 24px;
  overflow: hidden;
}

.cp-dang__preview-head {
  border-bottom: 1px solid var(--color-secondary-200);
  background: #fff;
  justify-content: space-between;
  align-items: center;
  padding: 12px 14px;
  display: flex;
}

.cp-dang__preview-title {
  color: var(--color-secondary-900);
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  font-weight: 700;
  display: flex;
}

.cp-dang__preview-title:before {
  content: "";
  background: var(--color-heritage-500);
  width: 8px;
  height: 8px;
  box-shadow: 0 0 0 3px var(--color-heritage-100);
  border-radius: 50%;
}

.cp-dang__members {
  align-items: center;
  display: flex;
}

.cp-dang__members .lp-avatar {
  border: 2px solid #fff;
  width: 20px;
  height: 20px;
  font-size: 9.5px;
}

.cp-dang__members-count {
  color: var(--color-secondary-600);
  margin-inline-start: 8px;
  font-size: 11px;
  font-weight: 600;
}

.cp-dang__rows {
  background: #fff;
  padding: 4px 14px;
}

.cp-dang__row {
  border-bottom: 1px dashed var(--color-secondary-200);
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  display: flex;
}

.cp-dang__row:last-child {
  border-bottom: none;
}

.cp-dang__row-label {
  color: var(--color-secondary-700);
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  display: flex;
}

.cp-dang__row-ico {
  background: var(--color-secondary-100);
  width: 26px;
  height: 26px;
  color: var(--color-secondary-700);
  border-radius: 8px;
  flex-shrink: 0;
  place-items: center;
  display: grid;
}

.cp-dang__row-payer {
  color: var(--color-secondary-500);
  font-size: 10.5px;
}

.cp-dang__row-amt {
  font-variant-numeric: tabular-nums;
  color: var(--color-secondary-900);
  font-size: 13px;
  font-weight: 700;
}

.cp-dang__summary {
  background: linear-gradient(180deg, var(--color-heritage-50), #fff);
  border-top: 1px solid var(--color-secondary-200);
  padding: 14px;
}

.cp-dang__summary-title {
  letter-spacing: .06em;
  color: var(--color-heritage-700);
  text-transform: uppercase;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 700;
  display: flex;
}

.cp-dang__settle {
  border: 1px solid var(--color-heritage-200);
  background: #fff;
  border-radius: 10px;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  padding: 9px 10px;
  font-size: 12.5px;
  display: flex;
}

.cp-dang__settle:last-child {
  margin-bottom: 0;
}

.cp-dang__settle-avs {
  align-items: center;
  display: flex;
}

.cp-dang__settle-avs .lp-avatar {
  border: 2px solid #fff;
  width: 22px;
  height: 22px;
  font-size: 9.5px;
}

.cp-dang__settle-avs .lp-avatar + .lp-avatar {
  margin-inline-start: -6px;
}

.cp-dang__settle-arrow {
  color: var(--color-secondary-400);
  flex-shrink: 0;
}

.cp-dang__settle-text {
  color: var(--color-secondary-700);
  flex: 1;
}

.cp-dang__settle-text b {
  color: var(--color-secondary-900);
  font-weight: 700;
}

.cp-dang__settle-amt {
  font-variant-numeric: tabular-nums;
  color: var(--color-heritage-700);
  flex-shrink: 0;
  font-weight: 700;
}

.cp-dang__feats {
  gap: 8px;
  display: grid;
}

.cp-dang__feat {
  background: var(--color-heritage-50);
  border: 1px solid var(--color-heritage-100);
  border-radius: 12px;
  grid-template-columns: 28px 1fr;
  align-items: start;
  gap: 12px;
  padding: 12px 14px;
  display: grid;
}

.cp-dang__feat-num {
  background: var(--color-heritage-600);
  color: #fff;
  border-radius: 50%;
  place-items: center;
  width: 24px;
  height: 24px;
  font-size: 11px;
  font-weight: 700;
  display: grid;
}

.cp-dang__feat h5 {
  color: var(--color-secondary-900);
  margin: 0 0 2px;
  font-size: 13.5px;
  font-weight: 700;
}

.cp-dang__feat p {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 12.5px;
  line-height: 1.55;
}

.cp-tl {
  background: radial-gradient(ellipse at top right, #d4a24c2e, transparent 60%), linear-gradient(135deg, var(--color-secondary-900) 0%, #2a2621 100%);
  color: #f5efe3;
  border-radius: 24px;
  margin: 32px 20px;
  padding: 32px 24px 28px;
  position: relative;
  overflow: hidden;
}

.cp-tl:before {
  content: "";
  inset-inline-end: -30px;
  opacity: .6;
  background-image: radial-gradient(circle, #d4a24c40 1px, #0000 1.5px);
  background-size: 14px 14px;
  width: 160px;
  height: 160px;
  position: absolute;
  bottom: -30px;
}

.cp-tl__content {
  z-index: 1;
  position: relative;
}

.cp-tl__badge {
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-accent-500);
  background: #d4a24c1f;
  border: 1px solid #d4a24c4d;
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  margin-bottom: 14px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
}

.cp-tl__badge:before {
  content: "";
  background: var(--color-accent-500);
  border-radius: 50%;
  width: 6px;
  height: 6px;
}

.cp-tl__title {
  color: #fff;
  letter-spacing: -.015em;
  margin: 0 0 10px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.3;
}

.cp-tl__title em {
  color: var(--color-accent-500);
  font-style: normal;
}

.cp-tl__body {
  color: #c8bfb0;
  max-width: 340px;
  margin: 0 0 20px;
  font-size: 14px;
  line-height: 1.65;
}

.cp-tl__stats {
  border-top: 1px solid #ffffff1a;
  border-bottom: 1px solid #ffffff1a;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 4px;
  margin-bottom: 22px;
  padding: 14px 0;
  display: grid;
}

.cp-tl__stat-num {
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
  font-size: 20px;
  font-weight: 700;
}

.cp-tl__stat-label {
  color: #8f877b;
  margin-top: 2px;
  font-size: 11px;
  line-height: 1.3;
}

.cp-tl__cta {
  color: var(--color-secondary-900);
  background: var(--color-accent-500);
  border-start-start-radius: 12px;
  border-start-end-radius: 3px;
  border-end-end-radius: 12px;
  border-end-start-radius: 3px;
  align-items: center;
  gap: 6px;
  padding: 12px 18px 12px 16px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: background .15s, transform .15s;
  display: inline-flex;
}

.cp-tl__cta:hover {
  background: var(--color-accent-400);
  transform: translateX(2px);
}

.cp-testimonials {
  background: #faf7f2;
  flex-direction: column;
  gap: 14px;
  padding: 24px 20px 56px;
  display: flex;
}

@media (min-width: 840px) {
  .cp-testimonials {
    grid-template-columns: 1fr 1fr;
    gap: 14px 20px;
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
  }

  .cp-testimonials > .cp-ornament {
    grid-column: 1 / -1;
  }
}

.cp-testimonial {
  border: 1px solid var(--color-secondary-100);
  background: #fff;
  border-radius: 14px;
  height: 100%;
  padding: 22px 22px 20px;
  position: relative;
  box-shadow: 0 1px #1f1c1705;
}

.cp-testimonial:before {
  content: "“";
  top: 10px;
  color: var(--color-primary-200);
  font-family: Georgia, serif;
  font-size: 44px;
  line-height: 1;
  position: absolute;
  inset-inline-end: 18px;
}

.cp-testimonial p {
  color: var(--color-secondary-700);
  margin: 0 0 16px;
  padding-inline-start: 4px;
  font-size: 14px;
  line-height: 1.7;
}

.cp-testimonial__meta {
  align-items: center;
  gap: 10px;
  display: flex;
}

.cp-testimonial__meta .lp-avatar {
  width: 36px;
  height: 36px;
  font-size: 12px;
}

.cp-testimonial__name {
  color: var(--color-secondary-900);
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.3;
}

.cp-testimonial__role {
  color: var(--color-secondary-500);
  margin: 2px 0 0;
  font-size: 11px;
}

.cp-faq {
  background: #fff;
  padding: 40px 20px;
}

.cp-faq__item {
  border-bottom: 1px solid var(--color-secondary-200);
  padding: 18px 0;
}

.cp-faq__q {
  color: var(--color-secondary-900);
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  font-weight: 600;
  list-style: none;
  display: flex;
}

.cp-faq__q::-webkit-details-marker {
  display: none;
}

.cp-faq__q-icon {
  background: var(--color-secondary-100);
  width: 24px;
  height: 24px;
  color: var(--color-secondary-600);
  border-radius: 999px;
  flex-shrink: 0;
  place-items: center;
  font-size: 14px;
  transition: transform .25s, background .2s;
  display: grid;
}

.cp-faq__item[open] .cp-faq__q-icon {
  background: var(--color-primary-100);
  color: var(--color-primary-700);
  transform: rotate(45deg);
}

.cp-faq__a {
  color: var(--color-secondary-600);
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.7;
  animation: .3s cubic-bezier(.4, 0, .2, 1) cp-faq-open;
}

@keyframes cp-faq-open {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }

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

@media (prefers-reduced-motion: reduce) {
  .cp-faq__a {
    animation: none;
  }
}

.cp-install-prompt {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  animation: cp-install-prompt-in .4s var(--ease-heritage) both;
  border-radius: 16px;
  align-items: flex-start;
  gap: 12px;
  margin-top: 16px;
  padding: 16px 18px;
  display: flex;
  position: relative;
  box-shadow: 0 2px 8px #1f1c170f;
}

@keyframes cp-install-prompt-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

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

@media (prefers-reduced-motion: reduce) {
  .cp-install-prompt {
    animation: none;
  }
}

.cp-install-prompt--ios {
  border-color: var(--color-secondary-900);
  background: linear-gradient(135deg, #1f1c17 0%, var(--color-secondary-900) 100%);
  color: #f5efe3;
  box-shadow: 0 4px 16px #0000002e;
}

.cp-install-prompt--ios .cp-install-prompt__title {
  color: #fff;
}

.cp-install-prompt--ios .cp-install-prompt__body {
  color: #f5efe3b8;
}

.cp-install-prompt--ios .cp-install-prompt__steps li {
  color: #f5efe3c7;
}

.cp-install-prompt--ios .cp-install-prompt__btn--ios {
  color: var(--color-secondary-900);
  background: #fff;
  box-shadow: 0 4px 12px #ffffff26;
}

.cp-install-prompt__icon {
  background: var(--color-primary-50);
  width: 36px;
  height: 36px;
  color: var(--color-primary-700);
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  margin-top: 2px;
  display: flex;
}

.cp-install-prompt--ios .cp-install-prompt__icon {
  color: var(--color-accent-400);
  background: #ffffff1a;
}

.cp-install-prompt__content {
  flex-direction: column;
  flex: 1;
  min-width: 0;
  display: flex;
}

.cp-install-prompt__title {
  color: var(--color-secondary-900);
  letter-spacing: -.005em;
  margin: 0 0 4px;
  font-size: 14px;
  font-weight: 700;
}

.cp-install-prompt__body {
  color: var(--color-secondary-600);
  margin: 0 0 10px;
  font-size: 12.5px;
  line-height: 1.6;
}

.cp-install-prompt__steps {
  counter-reset: step;
  flex-direction: column;
  gap: 6px;
  margin: 0 0 12px;
  padding: 0;
  list-style: none;
  display: flex;
}

.cp-install-prompt__steps li {
  counter-increment: step;
  padding-inline-start: 24px;
  font-size: 12.5px;
  line-height: 1.55;
  position: relative;
}

.cp-install-prompt__steps li:before {
  content: counter(step);
  inset-inline-start: 0;
  background: var(--color-accent-500);
  width: 18px;
  height: 18px;
  color: var(--color-secondary-900);
  font-variant-numeric: tabular-nums;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  position: absolute;
  top: 1px;
}

.cp-install-prompt__actions {
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  display: flex;
}

.cp-install-prompt__btn {
  background: var(--color-primary-600);
  color: #fff;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  border: none;
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 10px 18px;
  font-family: inherit;
  font-size: 13.5px;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s ease-out, transform .15s ease-out;
  display: inline-flex;
}

.cp-install-prompt__btn:hover {
  background: var(--color-primary-700);
  transform: translateY(-1px);
}

.cp-install-prompt__btn:focus-visible {
  outline: 2px solid var(--color-primary-600);
  outline-offset: 2px;
}

.cp-install-prompt__btn--cafebazaar {
  background: #0ea960;
}

.cp-install-prompt__btn--cafebazaar:hover {
  background: #0c8f50;
}

.cp-install-prompt__btn--cafebazaar:focus-visible {
  outline-color: #0ea960;
}

.cp-install-prompt__dismiss {
  color: var(--color-secondary-500);
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px 2px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  transition: color .15s;
}

.cp-install-prompt__dismiss:hover {
  color: var(--color-secondary-700);
}

.cp-install-prompt--ios .cp-install-prompt__dismiss {
  color: #f5efe380;
}

.cp-install-prompt--ios .cp-install-prompt__dismiss:hover {
  color: #f5efe3bf;
}

@media (prefers-reduced-motion: reduce) {
  .cp-install-prompt__btn {
    transition: none;
  }

  .cp-install-prompt__btn:hover {
    transform: none;
  }
}

.cp-install {
  background: linear-gradient(135deg, var(--color-primary-700) 0%, var(--color-primary-900) 100%);
  color: #fff;
  border-radius: 24px;
  margin: 32px 20px;
  padding: 36px 24px;
  position: relative;
  overflow: hidden;
}

.cp-install:before {
  content: "";
  inset-inline-end: -50px;
  background-image: radial-gradient(circle, #3bafa940 1px, #0000 2px);
  background-size: 14px 14px;
  width: 200px;
  height: 200px;
  position: absolute;
  top: -50px;
}

.cp-install:after {
  content: "";
  inset-inline-start: -60px;
  background: #3bafa924;
  border-radius: 50%;
  width: 180px;
  height: 180px;
  position: absolute;
  bottom: -60px;
}

.cp-install__content {
  z-index: 1;
  position: relative;
}

.cp-install__title {
  color: #fff;
  letter-spacing: -.01em;
  margin: 0 0 10px;
  font-size: 24px;
  font-weight: 700;
}

.cp-install__body {
  color: #ffffffc7;
  margin: 0 0 22px;
  font-size: 14px;
  line-height: 1.7;
}

.cp-install__cta {
  background: var(--color-accent-500);
  color: var(--color-secondary-900);
  border-radius: 14px;
  align-items: center;
  gap: 12px;
  min-height: 56px;
  padding: 14px 20px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s ease-out, transform .18s ease-out;
  display: inline-flex;
  box-shadow: 0 8px 24px -10px #d4a24cb3, inset 0 0 0 1px #0000000a;
}

.cp-install__cta:hover {
  background: var(--color-accent-400);
  color: var(--color-secondary-900);
  transform: translateY(-1px);
}

.cp-install__cta-mark {
  width: 30px;
  height: 30px;
  color: var(--color-secondary-900);
  background: #00000014;
  border-radius: 9px;
  place-items: center;
  display: grid;
}

.cp-install__cta-label {
  line-height: 1.1;
}

.cp-install__cta-chev {
  color: var(--color-secondary-900);
  opacity: .7;
  margin-inline-start: 4px;
  display: inline-flex;
}

@media (prefers-reduced-motion: reduce) {
  .cp-install__cta {
    transition: none;
  }

  .cp-install__cta:hover {
    transform: none;
  }
}

.cp-footer {
  border-top: 1px solid var(--color-secondary-200);
  background: var(--color-secondary-50);
  color: var(--color-secondary-500);
  padding: 40px 20px 32px;
  font-size: 12px;
  line-height: 1.7;
}

.cp-footer__brand {
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  display: flex;
}

.cp-footer__brand-mark {
  background: var(--color-heritage-600);
  border-radius: 8px;
  place-items: center;
  width: 28px;
  height: 28px;
  display: grid;
}

.cp-footer__brand-name {
  color: var(--color-secondary-900);
  font-size: 14px;
  font-weight: 700;
}

.cp-footer__links {
  flex-wrap: wrap;
  gap: 16px;
  margin: 14px 0 18px;
  display: flex;
}

.cp-footer__links a {
  color: var(--color-secondary-600);
  text-decoration: none;
}

.cp-footer__links a:hover {
  color: var(--color-primary-700);
}

.cp-root {
  background: var(--color-surface-background);
  max-width: 440px;
  color: var(--color-secondary-800);
  font-family: var(--font-sans);
  line-height: var(--leading-comfortable);
  margin: 0 auto;
  position: relative;
  overflow-x: clip;
}

.cp-root * {
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .cp-root {
    max-width: 680px;
  }
}

@media (min-width: 1024px) {
  .cp-root {
    max-width: 960px;
  }
}

:root {
  --color-primary-50: #eef7f6;
  --color-primary-100: #d2ecea;
  --color-primary-200: #a4d8d5;
  --color-primary-300: #6fbeba;
  --color-primary-400: #3da19d;
  --color-primary-500: #1a8e8c;
  --color-primary-600: #0e7c7b;
  --color-primary-700: #0a6362;
  --color-primary-800: #084b4a;
  --color-primary-900: #063736;
  --color-secondary-50: #faf7f2;
  --color-secondary-100: #f2ede3;
  --color-secondary-200: #e5dfd5;
  --color-secondary-300: #d3cabb;
  --color-secondary-400: #9a9188;
  --color-secondary-500: #6b645c;
  --color-secondary-600: #4a4540;
  --color-secondary-700: #36322d;
  --color-secondary-800: #2d2a26;
  --color-secondary-900: #1f1c17;
  --color-accent-50: #fbf5e8;
  --color-accent-100: #f6e7c1;
  --color-accent-200: #ecce8c;
  --color-accent-300: #e0b566;
  --color-accent-400: #daab59;
  --color-accent-500: #d4a24c;
  --color-accent-600: #b5863a;
  --color-accent-700: #8e6829;
  --color-heritage-50: #eaf6f5;
  --color-heritage-100: #cce9e7;
  --color-heritage-200: #9dd6d2;
  --color-heritage-300: #6fc3be;
  --color-heritage-400: #54b9b3;
  --color-heritage-500: #3bafa9;
  --color-heritage-600: #2e938e;
  --color-heritage-700: #247471;
  --color-celebration-50: #faf1f1;
  --color-celebration-100: #f2dcdd;
  --color-celebration-200: #e8c7c8;
  --color-celebration-300: #e89b9d;
  --color-celebration-500: #a63d40;
  --color-celebration-600: #8a2e31;
  --color-celebration-700: #5c2628;
  --color-semantic-success-50: #eaf5f0;
  --color-semantic-success-500: #2e8b6f;
  --color-semantic-success-700: #1f6e55;
  --color-semantic-error-50: #f7eaea;
  --color-semantic-error-500: #b33a3a;
  --color-semantic-error-700: #8c2929;
  --color-semantic-warning-50: #fbf1df;
  --color-semantic-warning-500: #c8892e;
  --color-semantic-warning-700: #9c6820;
  --color-semantic-info-50: #eaf0f7;
  --color-semantic-info-500: #2e6fb3;
  --color-semantic-info-700: #1f528c;
  --color-surface-background: #faf7f2;
  --color-surface-card: #fff;
  --color-surface-sunken: #f2ede3;
  --color-surface-overlay: #1f1c178c;
  --color-surface-overlayDark: #000000eb;
  --color-surface-overlayLight: #fffffff0;
  --color-surface-overlayLightSubtle: #fffffff2;
  --color-surface-onDarkDivider: #ffffff14;
  --color-surface-onDarkAccentTint: #d4a24c1f;
  --color-surface-onDarkBorder: #ffffff40;
  --color-surface-onGradientChip: #ffffff29;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 28px;
  --space-8: 32px;
  --space-9: 36px;
  --space-10: 40px;
  --space-11: 44px;
  --space-12: 48px;
  --space-14: 56px;
  --space-15: 60px;
  --space-16: 64px;
  --space-20: 80px;
  --space-0_5: 2px;
  --space-1_5: 6px;
  --space-2_5: 10px;
  --space-3_5: 14px;
  --space-5_5: 22px;
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-smPlus: 10px;
  --radius-md: 12px;
  --radius-mdPlus: 14px;
  --radius-lg: 16px;
  --radius-lgPlus: 18px;
  --radius-xl2: 20px;
  --radius-xl: 24px;
  --radius-full: 9999px;
  --radius-asym-ss: 12px;
  --radius-asym-se: 4px;
  --radius-asym-es: 4px;
  --radius-asym-ee: 12px;
  --leading-tight: 1.2;
  --leading-snug: 1.3;
  --leading-normal: 1.4;
  --leading-cozy: 1.5;
  --leading-comfortable: 1.6;
  --leading-legible: 1.7;
  --leading-relaxed: 1.8;
  --shadow-sm: 0 1px 2px #1f1c170d;
  --shadow-md: 0 2px 4px #1f1c171a;
  --shadow-lg: 0 4px 8px #1f1c1726;
  --font-sans: "Vazirmatn Variable", "Vazirmatn", system-ui, sans-serif;
  --font-display: "Fraunces", "Source Serif 4", Georgia, serif;
}

.rounded-asym {
  border-start-start-radius: var(--radius-asym-ss);
  border-start-end-radius: var(--radius-asym-se);
  border-end-end-radius: var(--radius-asym-ee);
  border-end-start-radius: var(--radius-asym-es);
}

:root {
  --primary-50: var(--color-primary-50);
  --primary-100: var(--color-primary-100);
  --primary-200: var(--color-primary-200);
  --primary-300: var(--color-primary-300);
  --primary-400: var(--color-primary-400);
  --primary-500: var(--color-primary-500);
  --primary-600: var(--color-primary-600);
  --primary-700: var(--color-primary-700);
  --primary-800: var(--color-primary-800);
  --primary-900: var(--color-primary-900);
  --stone-50: var(--color-secondary-50);
  --stone-100: var(--color-secondary-100);
  --stone-200: var(--color-secondary-200);
  --stone-300: var(--color-secondary-300);
  --stone-400: var(--color-secondary-400);
  --stone-500: var(--color-secondary-500);
  --stone-600: var(--color-secondary-600);
  --stone-700: var(--color-secondary-700);
  --stone-800: var(--color-secondary-800);
  --stone-900: var(--color-secondary-900);
  --accent-50: var(--color-accent-50);
  --accent-100: var(--color-accent-100);
  --accent-200: var(--color-accent-200);
  --accent-300: var(--color-accent-300);
  --accent-400: var(--color-accent-400);
  --accent-500: var(--color-accent-500);
  --accent-600: var(--color-accent-600);
  --accent-700: var(--color-accent-700);
  --heritage-50: var(--color-heritage-50);
  --heritage-100: var(--color-heritage-100);
  --heritage-200: var(--color-heritage-200);
  --heritage-300: var(--color-heritage-300);
  --heritage-400: var(--color-heritage-400);
  --heritage-500: var(--color-heritage-500);
  --heritage-600: var(--color-heritage-600);
  --heritage-700: var(--color-heritage-700);
  --celebration-500: var(--color-celebration-500);
  --celebration-600: var(--color-celebration-600);
  --success-50: var(--color-semantic-success-50);
  --success-500: var(--color-semantic-success-500);
  --success-700: var(--color-semantic-success-700);
  --error-50: var(--color-semantic-error-50);
  --error-500: var(--color-semantic-error-500);
  --error-700: var(--color-semantic-error-700);
  --warning-50: var(--color-semantic-warning-50);
  --warning-500: var(--color-semantic-warning-500);
  --warning-700: var(--color-semantic-warning-700);
  --info-50: var(--color-semantic-info-50);
  --info-500: var(--color-semantic-info-500);
  --info-700: var(--color-semantic-info-700);
  --surface-background: var(--color-surface-background);
  --surface-card: var(--color-surface-card);
  --surface-sunken: var(--color-surface-sunken);
  --surface-overlay: var(--color-surface-overlay);
  --surface-disabled: var(--color-surface-sunken);
  --border-default: #e5dfd5;
  --border-strong: #d3cabb;
  --border-focus: var(--color-primary-600);
  --border-error: var(--color-semantic-error-500);
  --border-subtle: #f2ede3;
  --fg-strong: var(--color-secondary-900);
  --fg-primary: var(--color-secondary-800);
  --fg-body: var(--color-secondary-600);
  --fg-muted: var(--color-secondary-500);
  --fg-subtle: var(--color-secondary-400);
  --fg-on-primary: #fff;
  --fg-link: var(--color-primary-600);
  --font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  --fs-label-sm: 10px;
  --fs-caption: 11px;
  --fs-footnote: 12px;
  --fs-body: 14px;
  --fs-subheading: 16px;
  --fs-heading: 18px;
  --fs-title: 22px;
  --fs-large-title: 28px;
  --fs-hero: 34px;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-bold: 700;
  --sp-0-5: 2px;
  --sp-1: 4px;
  --sp-1-5: 6px;
  --sp-2: 8px;
  --sp-2-5: 10px;
  --sp-3: 12px;
  --sp-3-5: 14px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
  --sp-7: 28px;
  --sp-8: 32px;
  --sp-10: 40px;
  --sp-11: 44px;
  --sp-12: 48px;
  --sp-14: 56px;
  --sp-16: 64px;
  --sp-20: 80px;
  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-full: 9999px;
  --btn-r-top-start: 12px;
  --btn-r-top-end: 4px;
  --btn-r-bottom-start: 4px;
  --btn-r-bottom-end: 12px;
  --shadow-sm: 0 1px 2px #1f1c170f;
  --shadow-md: 0 2px 4px #1f1c1714;
  --shadow-lg: 0 4px 8px #1f1c171a;
  --shadow-xl: 0 8px 16px #1f1c171f;
  --shadow-2xl: 0 12px 24px #1f1c1729;
  --dur-instant: .1s;
  --dur-fast: .2s;
  --dur-normal: .3s;
  --dur-slow: .5s;
  --dur-deliberate: .8s;
  --easing-default: cubic-bezier(.4, 0, .2, 1);
  --easing-enter: cubic-bezier(0, 0, .2, 1);
  --easing-exit: cubic-bezier(.4, 0, 1, 1);
}

.t-admin-root, .t-admin-root * {
  box-sizing: border-box;
}

.t-btn {
  height: 40px;
  font: var(--fw-medium) var(--fs-body) / 1 var(--font-sans);
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  white-space: nowrap;
  transition: background var(--dur-fast) var(--easing-default), color var(--dur-fast), border-color var(--dur-fast);
  font-family: var(--font-sans);
  border: 1px solid #0000;
  border-start-start-radius: var(--btn-r-top-start);
  border-start-end-radius: var(--btn-r-top-end);
  border-end-end-radius: var(--btn-r-bottom-end);
  border-end-start-radius: var(--btn-r-bottom-start);
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  display: inline-flex;
}

.t-btn:focus-visible {
  outline: 2px solid var(--primary-600);
  outline-offset: 2px;
}

.t-btn[disabled] {
  opacity: .45;
  cursor: not-allowed;
}

.t-btn--sm {
  height: 32px;
  font-size: var(--fs-footnote);
  padding: 0 12px;
}

.t-btn--lg {
  height: 48px;
  font-size: var(--fs-subheading);
  padding: 0 20px;
}

.t-btn--primary {
  background: var(--primary-600);
  color: var(--fg-on-primary);
}

.t-btn--primary:hover:not(:disabled) {
  background: var(--primary-700);
}

.t-btn--secondary {
  color: var(--primary-600);
  border-color: var(--primary-600);
  background: none;
}

.t-btn--secondary:hover:not(:disabled) {
  background: var(--primary-50);
}

.t-btn--ghost {
  color: var(--fg-primary);
  background: none;
}

.t-btn--ghost:hover:not(:disabled) {
  background: var(--stone-100);
}

.t-btn--danger {
  background: var(--celebration-500);
  color: #fff;
}

.t-btn--danger:hover:not(:disabled) {
  background: var(--celebration-600);
}

.t-btn--saffron {
  background: var(--accent-500);
  color: #1f1c17;
}

.t-btn--saffron:hover:not(:disabled) {
  background: var(--accent-600);
  color: #fff;
}

.t-btn--icon {
  width: 36px;
  height: 36px;
  color: var(--fg-body);
  background: none;
  border-radius: 8px;
  padding: 0;
}

.t-btn--icon:hover:not(:disabled) {
  background: var(--stone-100);
}

.t-input {
  width: 100%;
  height: 40px;
  font: var(--fw-regular) var(--fs-body) / 1 var(--font-sans);
  color: var(--fg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--r-sm);
  transition: border-color var(--dur-fast);
  font-family: var(--font-sans);
  background: #fff;
  padding: 0 12px;
}

.t-input::placeholder {
  color: var(--stone-400);
}

.t-input:focus {
  border-color: var(--primary-600);
  outline: none;
  box-shadow: 0 0 0 3px #0e7c7b1f;
}

.t-input--lg {
  height: 56px;
  font-size: var(--fs-title);
  font-weight: 700;
}

textarea.t-input {
  resize: vertical;
  height: auto;
  padding: 12px;
  line-height: 1.6;
}

.t-card {
  background: var(--surface-card);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
}

.t-card--sunken {
  background: var(--stone-100);
  box-shadow: none;
}

.t-pill {
  height: 22px;
  font: var(--fw-medium) var(--fs-caption) / 1 var(--font-sans);
  border-radius: var(--r-full);
  letter-spacing: .01em;
  white-space: nowrap;
  align-items: center;
  gap: 6px;
  padding: 2px 10px;
  display: inline-flex;
}

.t-pill--lg {
  height: 26px;
  font-size: var(--fs-footnote);
  padding: 2px 12px;
}

.t-pill--neutral {
  background: var(--stone-100);
  color: var(--stone-700);
}

.t-pill--teal {
  background: var(--primary-50);
  color: var(--primary-700);
}

.t-pill--heritage {
  background: var(--heritage-50);
  color: var(--heritage-700);
}

.t-pill--saffron {
  background: var(--accent-50);
  color: var(--accent-700);
}

.t-pill--success {
  background: var(--success-50);
  color: var(--success-700);
}

.t-pill--warning {
  background: var(--warning-50);
  color: var(--warning-700);
}

.t-pill--error {
  background: var(--error-50);
  color: var(--error-700);
}

.t-pill--info {
  background: var(--info-50);
  color: var(--info-700);
}

.t-pill--celebration {
  color: var(--celebration-600);
  background: #f5e5e6;
}

.t-role {
  height: 28px;
  font: var(--fw-medium) var(--fs-footnote) / 1 var(--font-sans);
  border-radius: var(--r-full);
  border: 1px solid var(--stone-200);
  background: #fff;
  align-items: center;
  gap: 6px;
  padding-inline: 4px 12px;
  display: inline-flex;
}

.t-role__dot {
  color: #fff;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 20px;
  height: 20px;
  font-size: 10px;
  font-weight: 700;
  display: inline-flex;
}

.t-role--super .t-role__dot {
  background: var(--primary-600);
}

.t-role--super {
  color: var(--primary-700);
  border-color: var(--primary-200);
}

.t-role--supervisor .t-role__dot {
  background: var(--heritage-500);
}

.t-role--supervisor {
  color: var(--heritage-700);
  border-color: var(--heritage-200);
}

.t-role--support .t-role__dot {
  background: var(--stone-500);
}

.t-role--support {
  color: var(--stone-700);
}

.t-num {
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
}

.t-hr {
  border: 0;
  border-top: 1px solid var(--border-default);
  margin: 0;
}

.t-hr-strong {
  border: 0;
  border-top: 1px solid var(--border-strong);
  margin: 0;
}

@keyframes t-pulse {
  0%, 100% {
    opacity: .55;
  }

  50% {
    opacity: .85;
  }
}

.t-skel {
  background: var(--stone-100);
  border-radius: var(--r-sm);
  animation: t-pulse 1.4s var(--easing-default) infinite;
}

.admin-shell {
  background: var(--surface-background);
  min-height: 100vh;
  font-family: var(--font-sans);
  display: flex;
}

.admin-shell__main {
  flex-direction: column;
  flex: 1;
  min-width: 0;
  display: flex;
}

.admin-shell__page {
  flex: 1;
  min-height: 0;
}

.t-audit {
  padding-inline-start: 28px;
  position: relative;
}

.t-audit:before {
  content: "";
  background: linear-gradient(to bottom, var(--stone-200) 0%, var(--stone-200) 100%);
  width: 2px;
  position: absolute;
  inset-block: 6px;
  inset-inline-start: 9px;
}

.t-audit__row {
  padding-block: 10px;
  position: relative;
}

.t-audit__dot {
  inset-inline-start: -23px;
  border: 2px solid var(--stone-300);
  z-index: 1;
  background: #fff;
  border-radius: 50%;
  width: 12px;
  height: 12px;
  position: absolute;
  top: 14px;
}

.t-audit__dot--info {
  border-color: var(--info-500);
  background: var(--info-50);
}

.t-audit__dot--success {
  border-color: var(--success-500);
  background: var(--success-50);
}

.t-audit__dot--warning {
  border-color: var(--warning-500);
  background: var(--warning-50);
}

.t-audit__dot--critical {
  border-color: var(--celebration-500);
  background: var(--celebration-500);
  box-shadow: 0 0 0 3px #f5e5e6;
}

.t-bdi {
  unicode-bidi: isolate;
}

.t-table {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
}

.t-table th, .t-table td {
  text-align: start;
  font-size: var(--fs-body);
  border-bottom: 1px solid var(--border-default);
  vertical-align: middle;
  padding: 12px 16px;
}

.t-table th {
  color: var(--fg-muted);
  font-weight: 500;
  font-size: var(--fs-footnote);
  background: var(--stone-100);
  text-transform: none;
  letter-spacing: .01em;
}

.t-table th:first-child {
  border-start-start-radius: var(--r-sm);
}

.t-table th:last-child {
  border-start-end-radius: var(--r-sm);
}

.t-table tbody tr {
  transition: background var(--dur-fast) var(--easing-default);
}

.t-table tbody tr:hover {
  background: var(--stone-50, #fbfaf6);
}

.t-table tbody tr:last-child td {
  border-bottom: 0;
}

.t-table tbody tr:focus-within {
  background: var(--primary-50);
}

.t-modal-backdrop {
  background: var(--surface-overlay);
  z-index: 50;
  justify-content: center;
  align-items: center;
  display: flex;
  position: fixed;
  inset: 0;
}

.t-modal {
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-2xl);
  background: #fff;
  width: 100%;
  max-width: 540px;
  overflow: hidden;
}

.t-modal__hd {
  padding: 24px 24px 8px;
}

.t-modal__bd {
  padding: 8px 24px 16px;
}

.t-modal__ft {
  background: var(--stone-50, #fbfaf6);
  border-top: 1px solid var(--border-default);
  justify-content: flex-end;
  gap: 12px;
  padding: 16px 24px;
  display: flex;
}

.t-sidebar {
  --t-sidebar-w: 248px;
  width: var(--t-sidebar-w);
  flex: 0 0 var(--t-sidebar-w);
  background: var(--surface-card);
  border-inline-end: 1px solid var(--border-default);
  z-index: 25;
  height: 100dvh;
  transition: width var(--dur-normal) var(--easing-default), flex-basis var(--dur-normal) var(--easing-default);
  flex-direction: column;
  display: flex;
  position: sticky;
  inset-block-start: 0;
}

.t-sidebar__head {
  align-items: center;
  gap: 8px;
  padding: 16px 14px 12px;
  display: flex;
  position: relative;
}

.t-sidebar__brand {
  color: inherit;
  border-radius: var(--r-sm);
  min-width: 0;
  transition: background var(--dur-fast);
  flex: 1;
  align-items: center;
  gap: 10px;
  margin: -4px -6px;
  padding: 4px 6px;
  text-decoration: none;
  display: flex;
}

.t-sidebar__brand:hover {
  background: var(--stone-100);
}

.t-sidebar__brand:focus-visible {
  outline: 2px solid var(--primary-600);
  outline-offset: 2px;
}

.t-sidebar__brand-stack {
  flex-direction: column;
  min-width: 0;
  line-height: 1.15;
  display: flex;
}

.t-sidebar__collapse {
  width: 28px;
  height: 28px;
  color: var(--fg-muted);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: background var(--dur-fast), color var(--dur-fast);
  background: none;
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.t-sidebar__collapse:hover {
  background: var(--stone-100);
  color: var(--fg-primary);
}

.t-sidebar__collapse:focus-visible {
  outline: 2px solid var(--primary-600);
  outline-offset: 2px;
}

.t-sidebar__drawer-close {
  width: 32px;
  height: 32px;
  color: var(--fg-body);
  border-radius: var(--r-sm);
  cursor: pointer;
  background: none;
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  display: none;
}

.t-sidebar__drawer-close:hover {
  background: var(--stone-100);
}

.t-sidebar__brand-old {
  color: inherit;
  align-items: center;
  gap: 10px;
  padding: 20px 20px 16px;
  text-decoration: none;
  display: flex;
}

.t-sidebar__brand-mark {
  background: var(--primary-600);
  color: #fff;
  border-start-start-radius: 12px;
  border-start-end-radius: 4px;
  border-end-end-radius: 12px;
  border-end-start-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  font-size: 14px;
  font-weight: 700;
  display: flex;
}

.t-sidebar__brand-text {
  letter-spacing: -.01em;
  color: var(--stone-900);
  font-size: 18px;
  font-weight: 700;
}

.t-sidebar__brand-sub {
  color: var(--fg-muted);
  font-size: 11px;
  font-weight: 500;
}

.t-sidebar__nav {
  flex: 1;
  padding: 8px 12px 16px;
  overflow-y: auto;
}

.t-sidebar__group {
  margin-top: 16px;
}

.t-sidebar__group-title {
  letter-spacing: .06em;
  color: var(--stone-400);
  text-transform: none;
  padding: 6px 8px 4px;
  font-size: 10px;
  font-weight: 700;
}

.t-sidebar__item {
  border-radius: var(--r-sm);
  color: var(--fg-body);
  font-size: var(--fs-body);
  cursor: pointer;
  transition: background var(--dur-fast) var(--easing-default), color var(--dur-fast), transform var(--dur-fast);
  align-items: center;
  gap: 10px;
  min-height: 36px;
  margin-block: 1px;
  padding: 8px 12px;
  text-decoration: none;
  display: flex;
  position: relative;
}

.t-sidebar__item:hover {
  background: var(--stone-100);
  color: var(--fg-primary);
}

.t-sidebar__item:focus-visible {
  outline: 2px solid var(--primary-600);
  outline-offset: 2px;
}

.t-sidebar__item:active {
  transform: translateY(.5px);
}

.t-sidebar__item-icon {
  color: var(--fg-muted);
  flex: none;
}

.t-sidebar__item-label {
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

.t-sidebar__item .ph {
  color: var(--fg-muted);
  font-size: 18px;
}

.t-sidebar__item--active {
  background: var(--primary-50);
  color: var(--primary-700);
  font-weight: 500;
}

.t-sidebar__item--active:before {
  content: "";
  background: var(--primary-600);
  border-radius: 2px;
  width: 3px;
  position: absolute;
  inset-block: 6px;
  inset-inline-start: -12px;
}

.t-sidebar__item--active .t-sidebar__item-icon, .t-sidebar__item--active .ph {
  color: var(--primary-600);
}

.t-sidebar__count {
  background: var(--stone-100);
  color: var(--fg-muted);
  text-align: center;
  border-radius: 999px;
  min-width: 20px;
  margin-inline-start: auto;
  padding: 1px 8px;
  font-size: 11px;
  font-weight: 500;
}

.t-sidebar__item--active .t-sidebar__count {
  background: var(--primary-100);
  color: var(--primary-700);
}

.t-sidebar__count--saffron {
  background: var(--accent-100);
  color: var(--accent-700);
}

.t-sidebar__count--celebration {
  color: var(--celebration-600);
  background: #f5e5e6;
}

.t-sidebar__footer {
  border-top: 1px solid var(--border-default);
  font-size: var(--fs-footnote);
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  display: flex;
}

.t-topbar {
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-default);
  z-index: 30;
  -webkit-backdrop-filter: saturate(180%) blur(8px);
  backdrop-filter: saturate(180%) blur(8px);
  flex: 0 0 60px;
  align-items: center;
  gap: 12px;
  height: 60px;
  padding: 0 24px;
  display: flex;
  position: sticky;
  top: 0;
}

.t-topbar__menu {
  border-radius: var(--r-sm);
  cursor: pointer;
  width: 36px;
  height: 36px;
  color: var(--fg-body);
  transition: background var(--dur-fast) var(--easing-default);
  background: none;
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  display: none;
}

.t-topbar__menu:hover {
  background: var(--stone-100);
}

.t-topbar__search {
  background: var(--stone-50, #fbfaf6);
  border: 1px solid var(--stone-200);
  border-radius: var(--r-md);
  max-width: 520px;
  height: 38px;
  color: var(--fg-muted);
  cursor: pointer;
  text-align: start;
  transition: background var(--dur-fast) var(--easing-default), border-color var(--dur-fast), box-shadow var(--dur-fast);
  font-family: var(--font-sans);
  flex: 1;
  align-items: center;
  gap: 8px;
  padding: 0 8px 0 12px;
  display: inline-flex;
}

.t-topbar__search:hover {
  border-color: var(--stone-300);
  box-shadow: var(--shadow-sm);
  background: #fff;
}

.t-topbar__search:focus-visible {
  outline: 2px solid var(--primary-600);
  outline-offset: 2px;
}

.t-topbar__search-text {
  min-width: 0;
  font-size: var(--fs-body);
  color: var(--fg-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  overflow: hidden;
}

.t-topbar__kbd {
  font: 500 11px / 1 var(--font-mono);
  color: var(--fg-muted);
  border: 1px solid var(--border-default);
  letter-spacing: .04em;
  white-space: nowrap;
  background: #fff;
  border-radius: 6px;
  padding: 4px 8px;
}

.t-env-pill {
  text-transform: uppercase;
  letter-spacing: .08em;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 700;
}

.t-env-pill--staging {
  background: var(--accent-50);
  color: var(--accent-700);
}

.t-env-pill--dev {
  color: var(--celebration-600);
  background: #f5e5e6;
}

.t-env-pill--production {
  background: var(--success-50);
  color: var(--success-700);
}

.t-topbar__spacer {
  flex: 1;
}

.t-topbar__actions {
  gap: 4px;
  display: flex;
}

.t-topbar__lang {
  position: relative;
}

.t-topbar__divider {
  background: var(--border-default);
  width: 1px;
  height: 24px;
}

.t-topbar__user {
  line-height: 1.1;
}

.t-topbar__user-name {
  font-weight: var(--fw-medium);
  color: var(--fg-primary);
  font-size: 13px;
}

.t-topbar__user-status {
  color: var(--fg-muted);
  font-size: 11px;
}

.t-page {
  max-width: 1600px;
  margin-inline: auto;
  padding: 24px clamp(16px, 4vw, 32px) 32px;
}

.t-page > section + section {
  margin-block-start: 0;
}

.t-page__hd {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
  margin-bottom: 24px;
  display: flex;
}

.t-page__hd-text {
  min-width: 0;
}

.t-page__title {
  font: 700 26px / 1.2 var(--font-sans);
  letter-spacing: -.02em;
  color: var(--stone-900);
  margin: 0;
}

.t-page__kicker {
  font: 500 11px / 1 var(--font-sans);
  letter-spacing: .06em;
  color: var(--fg-muted);
  text-transform: uppercase;
  margin-bottom: 6px;
}

.t-page__sub {
  font-size: var(--fs-body);
  color: var(--fg-muted);
  margin-top: 6px;
}

.t-page__breadcrumb {
  font-size: var(--fs-footnote);
  color: var(--fg-muted);
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  display: flex;
}

.t-page__breadcrumb-item {
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.t-page__breadcrumb-current {
  color: var(--fg-primary);
}

.t-page__actions {
  flex-wrap: wrap;
  flex: none;
  gap: 8px;
  display: flex;
}

.t-sidebar__footer-text {
  flex: 1;
  min-width: 0;
}

.t-sidebar__footer-name {
  font-weight: var(--fw-medium);
  color: var(--fg-primary);
  font-size: 13px;
}

.t-sidebar__footer-sub {
  color: var(--fg-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  overflow: hidden;
}

.t-stat {
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  background: #fff;
  flex-direction: column;
  gap: 6px;
  padding: 16px 18px;
  display: flex;
}

.t-stat__label {
  font-size: var(--fs-footnote);
  color: var(--fg-muted);
  font-weight: 500;
}

.t-stat__value {
  font: 700 28px / 1.2 var(--font-sans);
  color: var(--stone-900);
  letter-spacing: -.02em;
}

.t-stat__trend {
  font-size: var(--fs-caption);
  align-items: center;
  gap: 4px;
  font-weight: 500;
  display: inline-flex;
}

.t-stat--accent .t-stat__value {
  color: var(--accent-700);
}

.t-stat--celebration {
  background: #fcf7f7;
}

.t-flex {
  display: flex;
}

.t-row {
  align-items: center;
  gap: 12px;
  display: flex;
}

: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)) .t-flip {
  transform: scaleX(-1);
}

.t-admin-root i[class^="ph-"], .t-admin-root i[class*=" ph-"] {
  line-height: 1;
}

.t-toast {
  box-shadow: var(--shadow-xl);
  z-index: 60;
  background: #fff;
  border-radius: 12px;
  align-items: center;
  gap: 12px;
  max-width: 420px;
  padding: 12px 16px;
  display: flex;
  position: fixed;
  inset-block-end: 24px;
  inset-inline-end: 32px;
}

@media (max-width: 880px) {
  .t-auth-brand {
    display: none !important;
  }

  .t-auth-surface {
    min-height: 100dvh !important;
    padding: 24px 20px !important;
  }
}

.t-sidebar__brand-text {
  letter-spacing: -.01em;
  color: var(--stone-900);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
}

.t-sidebar__brand-sub {
  color: var(--fg-muted);
  margin-top: 2px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.2;
}

.t-sidebar--collapsed {
  --t-sidebar-w: 72px;
}

.t-sidebar--collapsed .t-sidebar__brand-stack, .t-sidebar--collapsed .t-sidebar__group-title, .t-sidebar--collapsed .t-sidebar__item-label, .t-sidebar--collapsed .t-sidebar__count, .t-sidebar--collapsed .t-sidebar__footer-text {
  display: none;
}

.t-sidebar--collapsed .t-sidebar__head {
  justify-content: center;
  gap: 0;
  padding: 16px 12px;
}

.t-sidebar--collapsed .t-sidebar__brand {
  justify-content: center;
  margin: 0;
  padding: 0;
}

.t-sidebar--collapsed .t-sidebar__item {
  justify-content: center;
  gap: 0;
  padding: 10px 0;
}

.t-sidebar--collapsed .t-sidebar__item--active:before {
  width: 3px;
  inset-block: 8px;
  inset-inline-start: 0;
}

.t-sidebar--collapsed .t-sidebar__group {
  border-block-start: 1px solid var(--border-subtle);
  margin-top: 8px;
  padding-block-start: 8px;
}

.t-sidebar--collapsed .t-sidebar__group:first-child {
  border-block-start: 0;
  padding-block-start: 0;
}

.t-sidebar--collapsed .t-sidebar__nav {
  padding-inline: 8px;
}

.t-sidebar--collapsed .t-sidebar__footer {
  justify-content: center;
  padding: 12px 8px;
}

.t-sidebar--collapsed .t-sidebar__collapse {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  box-shadow: var(--shadow-sm);
  position: absolute;
  inset-block-start: 50%;
  inset-inline-end: -14px;
  transform: translateY(-50%);
}

.t-sidebar__backdrop {
  background: var(--surface-overlay);
  z-index: 40;
  animation: tx-fade-in var(--dur-fast) var(--easing-enter);
  display: none;
  position: fixed;
  inset: 0;
}

@keyframes tx-fade-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes tx-slide-in-start {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(0);
  }
}

: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)) .t-sidebar--drawer-open {
  animation: tx-slide-in-end var(--dur-normal) var(--easing-enter);
}

@keyframes tx-slide-in-end {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(0);
  }
}

.t-topbar__role {
  align-items: center;
  display: inline-flex;
}

.t-topbar__role .t-role {
  background: var(--stone-50);
}

.t-sidebar__nav {
  scrollbar-width: thin;
  scrollbar-color: var(--stone-300) transparent;
  padding: 8px 12px 16px;
  overflow-y: auto;
}

.t-sidebar__nav::-webkit-scrollbar {
  width: 6px;
}

.t-sidebar__nav::-webkit-scrollbar-thumb {
  background: var(--stone-300);
  border-radius: 999px;
}

.t-usermenu {
  position: relative;
}

.t-usermenu__chip {
  border-radius: var(--r-md);
  cursor: pointer;
  height: 40px;
  transition: background var(--dur-fast) var(--easing-default), border-color var(--dur-fast);
  background: none;
  border: 1px solid #0000;
  align-items: center;
  gap: 10px;
  padding: 2px 10px 2px 6px;
  display: inline-flex;
}

.t-usermenu__chip:hover {
  background: var(--stone-100);
}

.t-usermenu__chip[aria-expanded="true"] {
  background: var(--stone-100);
  border-color: var(--border-default);
}

.t-usermenu__chip:focus-visible {
  outline: 2px solid var(--primary-600);
  outline-offset: 2px;
}

.t-usermenu__chip-text {
  flex-direction: column;
  min-width: 0;
  line-height: 1.1;
  display: flex;
}

.t-usermenu__chip-name {
  font-weight: var(--fw-medium);
  color: var(--fg-primary);
  font-size: 13px;
}

.t-usermenu__chip-status {
  color: var(--fg-muted);
  font-size: 11px;
}

.t-usermenu__chip-caret {
  color: var(--fg-muted);
  margin-inline-start: 2px;
}

.t-usermenu__pop {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--r-lg);
  min-width: 240px;
  box-shadow: var(--shadow-xl);
  z-index: 50;
  animation: tx-pop-in .16s var(--easing-enter);
  transform-origin: top end;
  padding: 8px;
  position: absolute;
  inset-block-start: calc(100% + 6px);
  inset-inline-end: 0;
}

@keyframes tx-pop-in {
  from {
    opacity: 0;
    transform: translateY(-4px)scale(.97);
  }

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

.t-usermenu__head {
  align-items: center;
  gap: 12px;
  padding: 10px 10px 12px;
  display: flex;
}

.t-usermenu__name {
  font-weight: var(--fw-medium);
  font-size: var(--fs-subheading);
  color: var(--fg-strong);
}

.t-usermenu__sub {
  color: var(--fg-muted);
  margin-top: 2px;
  font-size: 11px;
}

.t-usermenu__sep {
  background: var(--border-subtle);
  height: 1px;
  margin: 4px 0;
}

.t-usermenu__item {
  border-radius: var(--r-sm);
  width: 100%;
  color: var(--fg-body);
  font: var(--fw-regular) var(--fs-body) / 1 var(--font-sans);
  cursor: pointer;
  text-align: start;
  font-family: var(--font-sans);
  transition: background var(--dur-fast), color var(--dur-fast);
  background: none;
  border: 0;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  text-decoration: none;
  display: flex;
}

.t-usermenu__item:hover:not([disabled]) {
  background: var(--stone-100);
  color: var(--fg-primary);
}

.t-usermenu__item:focus-visible {
  outline: 2px solid var(--primary-600);
  outline-offset: 2px;
}

.t-usermenu__item--danger {
  color: var(--celebration-600);
}

.t-usermenu__item--danger:hover:not([disabled]) {
  color: var(--celebration-600);
  background: #f5e5e6;
}

.t-usermenu__item[disabled] {
  opacity: .55;
  cursor: not-allowed;
}

.t-palette-backdrop {
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  z-index: 60;
  animation: tx-fade-in .12s var(--easing-enter);
  background: #1f1c178c;
  justify-content: center;
  align-items: flex-start;
  padding-block-start: 12vh;
  padding-inline: 16px;
  display: flex;
  position: fixed;
  inset: 0;
}

.t-palette {
  background: var(--surface-card);
  border-radius: var(--r-lg);
  width: 100%;
  max-width: 620px;
  box-shadow: var(--shadow-2xl);
  animation: tx-pop-in .18s var(--easing-enter);
  overflow: hidden;
}

.t-palette__hd {
  border-bottom: 1px solid var(--border-subtle);
  color: var(--fg-muted);
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  display: flex;
}

.t-palette__input {
  height: 28px;
  font: var(--fw-regular) 16px / 1 var(--font-sans);
  color: var(--fg-strong);
  font-family: var(--font-sans);
  background: none;
  border: 0;
  outline: none;
  flex: 1;
}

.t-palette__input::placeholder {
  color: var(--stone-400);
}

.t-palette__close {
  cursor: pointer;
  background: none;
  border: 0;
  padding: 2px;
}

.t-palette__kbd {
  min-width: 28px;
  height: 22px;
  font: 500 11px / 1 var(--font-mono);
  color: var(--fg-muted);
  background: var(--stone-100);
  border: 1px solid var(--border-default);
  letter-spacing: .04em;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  padding: 0 6px;
  display: inline-flex;
}

.t-palette__bd {
  scrollbar-width: thin;
  scrollbar-color: var(--stone-300) transparent;
  max-height: 50vh;
  padding: 6px;
  overflow-y: auto;
}

.t-palette__group {
  margin-top: 6px;
}

.t-palette__group-title {
  letter-spacing: .06em;
  color: var(--stone-500);
  padding: 6px 10px 4px;
  font-size: 10px;
  font-weight: 700;
}

.t-palette__item {
  border-radius: var(--r-sm);
  width: 100%;
  color: var(--fg-body);
  font: var(--fw-regular) var(--fs-body) / 1 var(--font-sans);
  cursor: pointer;
  text-align: start;
  font-family: var(--font-sans);
  background: none;
  border: 0;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  display: flex;
}

.t-palette__item:hover {
  background: var(--stone-100);
}

.t-palette__item--active {
  background: var(--primary-50);
  color: var(--primary-700);
}

.t-palette__item--active .ph {
  color: var(--primary-600);
}

.t-palette__item-label {
  flex: 1;
}

.t-palette__item-hint kbd {
  min-width: 24px;
  height: 20px;
  font: 500 11px / 1 var(--font-mono);
  color: var(--primary-700);
  border: 1px solid var(--primary-200);
  background: #fff;
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  padding: 0 6px;
  display: inline-flex;
}

.t-palette__empty {
  color: var(--fg-muted);
  font-size: var(--fs-footnote);
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 36px 16px;
  display: flex;
}

.t-palette__ft {
  border-top: 1px solid var(--border-subtle);
  background: var(--stone-50);
  font-size: var(--fs-caption);
  color: var(--fg-muted);
  gap: 16px;
  padding: 10px 16px;
  display: flex;
}

.t-palette__ft span {
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.t-palette__ft kbd {
  min-width: 20px;
  height: 18px;
  font: 500 10px / 1 var(--font-mono);
  border: 1px solid var(--border-default);
  color: var(--fg-muted);
  background: #fff;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  padding: 0 5px;
  display: inline-flex;
}

.tx-card {
  background: var(--surface-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  flex-direction: column;
  display: flex;
  overflow: hidden;
}

.tx-card__hd {
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 18px 8px;
  display: flex;
}

.tx-card__hd-text {
  min-width: 0;
}

.tx-card__title-row {
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.tx-card__icon {
  color: var(--fg-muted);
}

.tx-card__title {
  font: 700 14px / 1.2 var(--font-sans);
  color: var(--fg-strong);
  letter-spacing: -.01em;
  margin: 0;
}

.tx-card__sub {
  color: var(--fg-muted);
  margin-top: 4px;
  font-size: 11px;
  line-height: 1.4;
}

.tx-card__actions {
  flex-wrap: wrap;
  flex: none;
  gap: 6px;
  display: flex;
}

.tx-card__bd {
  flex: 1;
  padding: 8px 18px 16px;
}

.tx-card--bleed .tx-card__bd {
  padding: 0;
}

.tx-card__ft {
  border-block-start: 1px solid var(--border-subtle);
  background: var(--stone-50);
  font-size: var(--fs-footnote);
  color: var(--fg-muted);
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  display: flex;
}

.tx-card--compact .tx-card__hd {
  padding: 10px 14px 6px;
}

.tx-card--compact .tx-card__bd {
  padding: 6px 14px 12px;
}

.tx-card--primary {
  border-color: var(--primary-200);
}

.tx-card--saffron {
  border-color: var(--accent-200);
}

.tx-card--celebration {
  border-color: #ecc6ca;
}

.tx-card--success {
  border-color: var(--success-500);
}

.tx-card--warning {
  border-color: var(--warning-500);
}

.tx-card--error {
  border-color: var(--error-500);
}

.tx-card--primary .tx-card__title, .tx-card--success .tx-card__title {
  color: var(--primary-700);
}

.tx-card--celebration .tx-card__title {
  color: var(--celebration-600);
}

.tx-section {
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  display: flex;
}

.tx-section__label {
  font: 700 11px / 1 var(--font-sans);
  letter-spacing: .08em;
  color: var(--stone-500);
  text-transform: none;
  align-items: center;
  gap: 7px;
  margin: 0;
  display: inline-flex;
}

.tx-section__icon {
  color: var(--stone-500);
}

.tx-section__hint {
  color: var(--fg-muted);
  font-size: 11px;
  font-weight: 500;
}

.tx-section--live .tx-section__label:before {
  display: none;
}

.tx-section__pulse {
  background: var(--success-500);
  width: 6px;
  height: 6px;
  box-shadow: 0 0 0 3px var(--success-50);
  border-radius: 50%;
  animation: 1.8s ease-in-out infinite tx-pulse;
  display: inline-block;
}

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

  50% {
    opacity: .55;
  }
}

.tx-empty {
  text-align: center;
  color: var(--fg-muted);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 56px 24px;
  display: flex;
}

.tx-empty--compact {
  gap: 8px;
  padding: 28px 16px;
}

.tx-empty__icon {
  border-radius: var(--r-full);
  background: var(--stone-100);
  width: 52px;
  height: 52px;
  color: var(--fg-muted);
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.tx-empty--compact .tx-empty__icon {
  width: 36px;
  height: 36px;
}

.tx-empty__title {
  font: 700 15px / 1.3 var(--font-sans);
  color: var(--fg-strong);
  margin-top: 2px;
}

.tx-empty__desc {
  font-size: var(--fs-footnote);
  color: var(--fg-muted);
  max-width: 36ch;
  line-height: 1.6;
}

.tx-empty__action {
  margin-top: 8px;
}

.tx-empty--success .tx-empty__icon {
  background: var(--success-50);
  color: var(--success-700);
}

.tx-empty--info .tx-empty__icon {
  background: var(--info-50);
  color: var(--info-700);
}

.tx-empty--warning .tx-empty__icon {
  background: var(--warning-50);
  color: var(--warning-700);
}

.tx-empty--saffron .tx-empty__icon {
  background: var(--accent-50);
  color: var(--accent-700);
}

.tx-kpi {
  background: var(--surface-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--dur-fast) var(--easing-default), transform var(--dur-fast);
  flex-direction: column;
  gap: 8px;
  padding: 16px 18px 14px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.tx-kpi:hover {
  box-shadow: var(--shadow-md);
}

.tx-kpi--sm {
  gap: 6px;
  padding: 12px 14px 10px;
}

.tx-kpi__hd {
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  display: flex;
}

.tx-kpi__label {
  font-size: var(--fs-footnote);
  color: var(--fg-muted);
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  font-weight: 500;
  line-height: 1.3;
  display: -webkit-box;
  overflow: hidden;
}

.tx-kpi__icon {
  border-radius: var(--r-sm);
  background: var(--stone-100);
  width: 24px;
  height: 24px;
  color: var(--fg-muted);
  flex: none;
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.tx-kpi--sm .tx-kpi__icon {
  width: 20px;
  height: 20px;
}

.tx-kpi__value-row {
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px;
  display: flex;
}

.tx-kpi__value {
  font: 700 28px / 1.15 var(--font-sans);
  color: var(--fg-strong);
  letter-spacing: -.02em;
}

.tx-kpi--sm .tx-kpi__value {
  font-size: 22px;
}

.tx-kpi__unit {
  color: var(--fg-muted);
  font-size: 13px;
  font-weight: 500;
}

.tx-kpi__ft {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  display: flex;
}

.tx-kpi__trend {
  font-size: var(--fs-caption);
  border-radius: var(--r-full);
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  font-weight: 600;
  display: inline-flex;
}

.tx-kpi__trend--positive {
  background: var(--success-50);
  color: var(--success-700);
}

.tx-kpi__trend--negative {
  background: var(--error-50);
  color: var(--error-700);
}

.tx-kpi__trend--neutral {
  background: var(--stone-100);
  color: var(--fg-muted);
}

.tx-kpi__hint {
  color: var(--fg-muted);
  font-size: 11px;
}

.tx-kpi__accent {
  margin-top: 4px;
}

.tx-kpi--primary {
  background: linear-gradient(180deg, var(--primary-50) 0%, var(--surface-card) 100%);
  border-color: var(--primary-200);
}

.tx-kpi--primary .tx-kpi__icon {
  color: var(--primary-600);
  background: #fff;
}

.tx-kpi--primary .tx-kpi__value {
  color: var(--primary-700);
}

.tx-kpi--accent {
  background: linear-gradient(180deg, var(--accent-50) 0%, var(--surface-card) 100%);
  border-color: var(--accent-200);
}

.tx-kpi--accent .tx-kpi__value {
  color: var(--accent-700);
}

.tx-kpi--accent .tx-kpi__icon {
  color: var(--accent-700);
  background: #fff;
}

.tx-kpi--celebration {
  background: linear-gradient(180deg, #fcf7f7 0%, var(--surface-card) 100%);
  border-color: #ecc6ca;
}

.tx-kpi--celebration .tx-kpi__value {
  color: var(--celebration-600);
}

.tx-kpi--celebration .tx-kpi__icon {
  color: var(--celebration-600);
  background: #fff;
}

.tx-kpi--success .tx-kpi__icon {
  background: var(--success-50);
  color: var(--success-700);
}

.tx-kpi--warning .tx-kpi__icon {
  background: var(--warning-50);
  color: var(--warning-700);
}

.tx-kpi--info .tx-kpi__icon {
  background: var(--info-50);
  color: var(--info-700);
}

.tx-toolbar {
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-block: 12px 16px;
  display: flex;
}

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

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

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

.tx-toolbar__start, .tx-toolbar__end {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  display: flex;
}

.tx-toolbar--sticky {
  background: var(--surface-background);
  z-index: 5;
  margin-inline: -12px;
  padding-block: 8px;
  padding-inline: 12px;
  position: sticky;
  inset-block-start: 60px;
}

.tx-pill-link {
  outline-offset: 2px;
  text-decoration: none;
  display: inline-flex;
}

.tx-pill-link:focus-visible {
  outline: 2px solid var(--primary-600);
  border-radius: var(--r-full);
}

.t-page__title {
  font: 700 26px / 1.2 var(--font-sans);
}

.t-page__kicker {
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.t-page__kicker:before {
  content: "";
  background: var(--stone-400);
  width: 18px;
  height: 1px;
  display: inline-block;
}

.t-page__breadcrumb a {
  color: var(--fg-muted);
  transition: color var(--dur-fast);
  text-decoration: none;
}

.t-page__breadcrumb a:hover {
  color: var(--fg-primary);
}

.t-admin-root :focus-visible {
  outline-offset: 2px;
}

.t-pill {
  border: 1px solid #0000;
}

.t-pill--neutral {
  border-color: var(--stone-200);
}

.t-audit__row {
  flex-direction: column;
  gap: 4px;
  display: flex;
}

@media (prefers-reduced-motion: reduce) {
  .t-sidebar, .t-sidebar__item, .t-topbar__search, .t-usermenu__chip, .t-usermenu__pop, .t-palette, .t-palette-backdrop, .t-sidebar__backdrop, .tx-kpi, .tx-section__pulse {
    transition: none !important;
    animation: none !important;
  }
}

@media (max-width: 1280px) {
  .t-sidebar {
    --t-sidebar-w: 232px;
  }
}

@media (max-width: 1024px) {
  .t-sidebar {
    --t-sidebar-w: 72px;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__brand-stack, .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__group-title, .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__item-label, .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__count, .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__footer-text {
    display: none;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__head {
    justify-content: center;
    gap: 0;
    padding: 16px 12px;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__brand {
    justify-content: center;
    margin: 0;
    padding: 0;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__item {
    justify-content: center;
    gap: 0;
    padding: 10px 0;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__item--active:before {
    inset-inline-start: 0;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__collapse {
    display: none;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__footer {
    justify-content: center;
    padding: 12px 8px;
  }

  .t-sidebar:not(.t-sidebar--drawer-open) .t-sidebar__nav {
    padding-inline: 8px;
  }

  .t-usermenu__chip-text, .t-usermenu__chip-caret {
    display: none;
  }

  .t-page {
    padding-inline: clamp(12px, 3vw, 20px);
  }
}

.t-table-scroll {
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--stone-300) transparent;
  scroll-snap-type: x proximity;
  width: 100%;
  overflow: auto visible;
}

.t-table-scroll::-webkit-scrollbar {
  height: 6px;
}

.t-table-scroll::-webkit-scrollbar-thumb {
  background: var(--stone-300);
  border-radius: 999px;
}

.t-table-scroll > .t-table {
  min-width: max-content;
}

@media (max-width: 768px) {
  .t-table-scroll {
    background: linear-gradient(to right, var(--surface-card) 30%, #fff0), linear-gradient(to right, #1f1c170f, #fff0 30%) 0 100%, linear-gradient(to left, var(--surface-card) 30%, #fff0) 100% 0, linear-gradient(to left, #1f1c170f, #fff0 30%) 100% 100%;
    background-repeat: no-repeat;
    background-size: 28px 100%, 12px 100%, 28px 100%, 12px 100%;
    background-attachment: local, scroll, local, scroll;
  }

  .t-table th, .t-table td {
    padding: 10px 12px;
    font-size: 13px;
  }

  .t-table th {
    white-space: nowrap;
    font-size: 11px;
  }
}

@media (max-width: 1024px) {
  .t-page {
    padding-inline: clamp(14px, 3vw, 22px);
  }
}

@media (max-width: 768px) {
  .t-topbar {
    height: 56px;
    padding-block: 0;
    padding-inline: 12px;
    flex: 0 0 56px;
    gap: 6px;
    padding-inline-start: max(12px, env(safe-area-inset-left));
    padding-inline-end: max(12px, env(safe-area-inset-right));
  }

  .t-topbar__menu {
    order: 9;
    width: 44px;
    height: 44px;
    display: inline-flex;
  }

  .t-topbar__role {
    flex: none;
    order: 5;
    display: inline-flex;
  }

  .t-topbar__role .t-role {
    height: 28px;
    padding-inline: 4px;
  }

  .t-topbar__role .t-role > span:not(.t-role__dot) {
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 6ch;
    overflow: hidden;
  }

  .t-topbar__divider {
    order: 6;
    display: inline-block;
  }

  .t-topbar__search {
    border-radius: var(--r-sm);
    flex: auto;
    order: 2;
    justify-content: flex-start;
    min-width: 0;
    max-width: none;
    height: 44px;
    padding: 0 10px;
  }

  .t-topbar__search-text {
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 13px;
    display: inline;
    overflow: hidden;
  }

  .t-topbar__kbd {
    display: none;
  }

  .t-topbar__lang {
    order: 7;
    width: 44px;
    height: 44px;
  }

  .t-topbar__actions {
    order: 4;
    gap: 2px;
  }

  .t-topbar__actions .t-btn--icon {
    width: 44px;
    height: 44px;
  }

  .t-topbar__spacer {
    display: none;
  }

  .t-usermenu__chip {
    order: 8;
    gap: 8px;
    height: 44px;
    padding-block: 2px;
    padding-inline: 4px;
  }

  .t-usermenu__chip-text, .t-usermenu__chip-caret {
    display: none;
  }

  .t-usermenu__pop {
    min-width: 0;
    max-width: none;
    position: fixed;
    inset-block-start: 60px;
    inset-inline: 12px;
  }

  .t-sidebar {
    --t-sidebar-w: min(320px, 84vw);
    height: 100dvh;
    width: var(--t-sidebar-w);
    z-index: 50;
    visibility: hidden;
    pointer-events: none;
    transition: transform var(--dur-normal) var(--easing-default), visibility 0s linear var(--dur-normal);
    box-shadow: none;
    flex: none;
    padding-block-end: env(safe-area-inset-bottom);
    padding-inline-start: env(safe-area-inset-left);
    position: fixed;
    inset-block-start: 0;
    inset-inline-start: 0;
    transform: translateX(-100%);
  }

  :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)) .t-sidebar {
    padding-inline-start: 0;
    padding-inline-end: env(safe-area-inset-right);
    inset-inline: auto 0;
    transform: translateX(-100%);
  }

  .t-sidebar.t-sidebar--drawer-open {
    visibility: visible;
    pointer-events: auto;
    box-shadow: var(--shadow-2xl);
    transition-delay: 0s;
    transform: translateX(0);
  }

  .t-sidebar.t-sidebar--drawer-open .t-sidebar__brand-stack, .t-sidebar.t-sidebar--drawer-open .t-sidebar__group-title, .t-sidebar.t-sidebar--drawer-open .t-sidebar__item-label, .t-sidebar.t-sidebar--drawer-open .t-sidebar__count, .t-sidebar.t-sidebar--drawer-open .t-sidebar__footer-text {
    display: revert;
  }

  .t-sidebar.t-sidebar--drawer-open .t-sidebar__head {
    justify-content: space-between;
    padding: 16px 14px 12px;
  }

  .t-sidebar.t-sidebar--drawer-open .t-sidebar__brand {
    justify-content: flex-start;
  }

  .t-sidebar.t-sidebar--drawer-open .t-sidebar__item {
    justify-content: flex-start;
    gap: 12px;
    min-height: 44px;
    padding: 12px;
  }

  .t-sidebar.t-sidebar--drawer-open .t-sidebar__collapse {
    display: none;
  }

  .t-sidebar.t-sidebar--drawer-open .t-sidebar__drawer-close {
    width: 44px;
    height: 44px;
    display: inline-flex;
  }

  .t-sidebar.t-sidebar--drawer-open .t-sidebar__footer {
    justify-content: flex-start;
    min-height: 56px;
    padding: 12px 16px;
  }

  .t-sidebar__nav {
    padding-block-end: max(16px, env(safe-area-inset-bottom));
  }

  .t-sidebar__backdrop {
    background: none;
    display: block;
  }

  .admin-shell {
    flex-direction: column;
  }

  .admin-shell__main {
    width: 100%;
    min-width: 0;
  }

  .t-page {
    padding-inline: max(14px, env(safe-area-inset-left));
    padding-block: 16px max(24px, env(safe-area-inset-bottom));
  }

  .t-page__hd {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    margin-bottom: 14px;
  }

  .t-page__title {
    font-size: 22px;
    line-height: 1.25;
  }

  .t-page__sub {
    font-size: 13px;
    line-height: 1.5;
  }

  .t-page__actions {
    flex-wrap: wrap;
    width: 100%;
  }

  .t-page__actions > * {
    flex: auto;
  }

  .t-page__actions .t-btn {
    min-width: 0;
    height: 44px;
  }

  .t-page__actions input.t-input {
    height: 44px;
    font-size: 16px;
  }

  .t-page__breadcrumb {
    flex-wrap: wrap;
    font-size: 11px;
  }

  .t-modal-backdrop {
    align-items: flex-end;
    padding: 0;
  }

  .t-modal {
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    width: 100%;
    max-width: 100%;
    max-height: 92dvh;
    animation: tx-sheet-up .24s var(--easing-enter);
    margin: 0;
    padding-block-end: env(safe-area-inset-bottom);
    overflow-y: auto;
  }

  .t-modal__hd {
    padding: 18px 18px 6px;
  }

  .t-modal__bd {
    padding: 8px 18px 12px;
  }

  .t-modal__ft {
    background: var(--stone-50, #fbfaf6);
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 18px;
    position: sticky;
    inset-block-end: 0;
  }

  .t-modal__ft .t-btn {
    flex: calc(50% - 4px);
    min-width: 0;
    height: 44px;
  }

  .t-palette-backdrop {
    padding-block-start: 4vh;
    padding-inline: 12px;
  }

  .t-palette {
    max-width: 100%;
  }

  .t-palette__hd {
    padding: 12px 14px;
  }

  .t-palette__input {
    height: 32px;
    font-size: 16px;
  }

  .t-palette__bd {
    max-height: 60dvh;
  }

  .t-palette__item {
    min-height: 44px;
    padding: 12px 10px;
  }

  .t-palette__ft {
    display: none;
  }

  .t-input {
    height: 44px;
    font-size: 16px;
  }

  .t-input--lg {
    height: 52px;
    font-size: 20px;
  }

  textarea.t-input {
    font-size: 16px;
  }

  .t-btn {
    height: 44px;
    padding-inline: 14px;
  }

  .t-btn--sm {
    height: 36px;
    padding-inline: 12px;
  }

  .t-btn--lg {
    height: 52px;
  }

  .t-btn--icon {
    width: 44px;
    height: 44px;
  }

  .t-pagination {
    flex-direction: column;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 14px !important;
  }

  .t-pagination > div:last-child {
    justify-content: space-between !important;
  }

  .t-page .t-row {
    margin-inline: -2px;
  }

  .tx-card__hd {
    flex-wrap: wrap;
    padding: 14px 14px 6px;
  }

  .tx-card__bd {
    padding: 6px 14px 14px;
  }

  .tx-card__ft {
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 14px;
  }

  .tx-card__actions {
    width: 100%;
  }

  .tx-card__actions > * {
    flex: auto;
  }

  .tx-toolbar {
    gap: 8px;
  }

  .tx-toolbar--sticky {
    inset-block-start: 56px;
  }

  .tx-kpi {
    padding: 12px 14px 10px;
  }

  .tx-kpi__value {
    font-size: 22px;
  }

  .tx-kpi--sm .tx-kpi__value {
    font-size: 18px;
  }

  .tx-section {
    margin-bottom: 8px;
  }

  .t-toast {
    max-width: none;
    inset-block-end: max(16px, env(safe-area-inset-bottom));
    inset-inline: 16px;
  }

  .t-audit {
    padding-inline-start: 22px;
  }
}

@media (max-width: 420px) {
  .t-topbar {
    gap: 4px;
    padding-inline: 10px;
  }

  .t-topbar__role .t-role > span:not(.t-role__dot) {
    max-width: 4ch;
  }

  .t-sidebar {
    --t-sidebar-w: 92vw;
  }

  .t-page {
    padding-inline: 12px;
  }

  .t-page__title {
    font-size: 20px;
  }

  .t-pagination > div:last-child {
    flex-direction: column;
    align-items: stretch !important;
    gap: 6px !important;
  }

  .t-pagination > div:last-child .t-btn {
    width: 100%;
  }
}

@media (pointer: coarse) {
  .t-btn--sm {
    min-height: 36px;
  }

  .t-btn--icon {
    min-width: 40px;
    min-height: 40px;
  }

  .t-sidebar__item, .t-usermenu__item, .t-palette__item {
    min-height: 44px;
  }
}

@media (max-width: 640px) {
  .t-page [style*="1fr"] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

@keyframes tx-sheet-up {
  from {
    opacity: 0;
    transform: translateY(100%);
  }

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

.tx-grid {
  gap: 12px;
  display: grid;
}

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

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

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

.tx-grid--auto {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

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

@media (max-width: 640px) {
  .tx-grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }

  .tx-grid--3, .tx-grid--2, .tx-grid--auto {
    grid-template-columns: 1fr;
  }

  .tx-grid {
    gap: 10px;
  }
}

@media (max-width: 380px) {
  .tx-grid--4 {
    grid-template-columns: 1fr;
  }
}

.tx-stack {
  flex-direction: column;
  display: flex;
}

.tx-stack--sm {
  gap: 8px;
}

.tx-stack--md {
  gap: 12px;
}

.tx-stack--lg {
  gap: 16px;
}

.tx-stack--xl {
  gap: 24px;
}

.tx-row {
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  display: flex;
}

.tx-row--sm {
  gap: 6px;
}

.tx-row--md {
  gap: 10px;
}

.tx-row--lg {
  gap: 16px;
}

.tx-sys-tile {
  background: var(--surface-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-sm);
  flex-direction: column;
  gap: 6px;
  padding: 10px 12px;
  display: flex;
}

.tx-sys-tile__hd {
  color: var(--fg-muted);
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  display: flex;
}

.tx-sys-tile__value {
  font: 700 18px / 1.1 var(--font-sans);
  color: var(--fg-strong);
}

.tx-sys-tile__sub {
  color: var(--fg-muted);
  font-size: 11px;
  font-weight: 500;
}

.t-sidebar--collapsed .t-sidebar__item-label {
  clip: rect(0, 0, 0, 0);
  border: 0;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  position: absolute;
  overflow: hidden;
}

.ins-root {
  background: var(--color-surface-background);
  color: var(--color-secondary-800);
  font-family: var(--font-sans);
  padding-bottom: 96px;
}

.ins-root[lang="en"], [dir="ltr"] .ins-root, .ins-root [dir="ltr"] {
  font-family: var(--font-sans);
}

.ins-section__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 32px;
  padding-inline: 20px;
}

.ins-section__title {
  color: var(--color-secondary-900);
  letter-spacing: -.01em;
  margin: 0 0 12px;
  font-size: clamp(26px, 4vw, 36px);
  font-weight: 800;
  line-height: 1.25;
}

.ins-section__lead {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: clamp(15px, 2vw, 17px);
  line-height: 1.7;
}

.ins-hero {
  background: radial-gradient(ellipse 80% 60% at 50% 0%, #0e7c7b0f 0%, transparent 70%), var(--color-surface-background);
  padding: 56px 20px 64px;
  position: relative;
  overflow: hidden;
}

.ins-hero__decor {
  pointer-events: none;
  position: absolute;
  inset: 0;
}

.ins-hero__decor-circle {
  filter: blur(60px);
  opacity: .5;
  border-radius: 50%;
  position: absolute;
}

.ins-hero__decor-circle--a {
  background: var(--color-heritage-300);
  width: 320px;
  height: 320px;
  inset-block-start: -120px;
  inset-inline-end: -100px;
}

.ins-hero__decor-circle--b {
  background: var(--color-accent-200);
  width: 260px;
  height: 260px;
  inset-block-end: -100px;
  inset-inline-start: -80px;
}

.ins-hero__inner {
  grid-template-columns: 1.1fr .9fr;
  align-items: center;
  gap: 56px;
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  position: relative;
}

@media (max-width: 880px) {
  .ins-hero__inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

.ins-hero__content {
  flex-direction: column;
  gap: 20px;
  display: flex;
}

.ins-hero__eyebrow {
  color: var(--color-primary-700);
  background: #0e7c7b14;
  border-radius: 999px;
  align-self: flex-start;
  align-items: center;
  padding: 6px 12px;
  font-size: 12.5px;
  font-weight: 600;
  display: inline-flex;
}

.ins-hero__title {
  font-family: var(--font-display);
  color: var(--color-secondary-900);
  letter-spacing: -.02em;
  margin: 0;
  font-size: clamp(36px, 6vw, 60px);
  font-weight: 700;
  line-height: 1.1;
}

[dir="rtl"] .ins-hero__title {
  font-family: var(--font-sans);
  letter-spacing: -.025em;
  line-height: 1.25;
}

.ins-hero__title em {
  color: var(--color-primary-600);
  background: linear-gradient(#0000 65%, #d4a24c40 65%);
  font-style: normal;
}

.ins-hero__lead {
  color: var(--color-secondary-600);
  max-width: 56ch;
  margin: 0;
  font-size: clamp(15.5px, 1.8vw, 18px);
  line-height: 1.75;
}

.ins-hero__pills {
  flex-wrap: wrap;
  gap: 8px 12px;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.ins-hero__pill {
  background: var(--color-surface-card);
  border: 1px solid var(--color-secondary-200);
  color: var(--color-secondary-700);
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  padding: 6px 11px 6px 12px;
  font-size: 13px;
  display: inline-flex;
}

.ins-hero__pill-dot {
  background: var(--color-primary-500);
  border-radius: 50%;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
}

.ins-hero__ctas {
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
  display: flex;
}

.ins-btn {
  border-radius: var(--radius-md, 12px);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  border: none;
  align-items: center;
  gap: 12px;
  min-height: 56px;
  padding: 14px 18px;
  font-weight: 600;
  text-decoration: none;
  transition: transform .18s ease-out, background .18s ease-out, box-shadow .18s ease-out;
  display: inline-flex;
}

.ins-btn:focus-visible {
  outline: 2px solid var(--color-primary-600);
  outline-offset: 3px;
}

.ins-btn__icon {
  flex-shrink: 0;
  display: inline-flex;
}

.ins-btn__copy {
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.15;
  display: flex;
}

[dir="rtl"] .ins-btn__copy {
  align-items: flex-end;
}

.ins-btn__small {
  opacity: .78;
  letter-spacing: .01em;
  font-size: 11px;
  font-weight: 500;
}

.ins-btn__large {
  font-size: 16px;
  font-weight: 700;
}

.ins-btn__trail {
  opacity: .85;
  flex-shrink: 0;
  margin-inline-start: 6px;
  display: inline-flex;
}

.ins-btn--primary {
  background: var(--color-primary-600);
  color: var(--color-surface-card);
  box-shadow: 0 8px 24px -8px #0a63628c, inset 0 0 0 1px #00000005;
}

.ins-btn--primary:hover {
  background: var(--color-primary-700);
  transform: translateY(-1px);
}

.ins-btn--primary:active {
  transform: translateY(0);
}

.ins-btn--ghost {
  background: var(--color-surface-card);
  color: var(--color-secondary-900);
  box-shadow: 0 0 0 1px var(--color-secondary-200) inset, 0 6px 16px -10px #1f1c172e;
}

.ins-btn--ghost:hover {
  background: var(--color-secondary-50);
  transform: translateY(-1px);
}

.ins-btn--ios {
  color: #fff;
  background: #1f1c17;
  box-shadow: 0 8px 24px -8px #00000080, inset 0 0 0 1px #ffffff0f;
}

.ins-btn--ios:hover {
  background: #050402;
  transform: translateY(-1px);
}

.ins-btn--cafebazaar {
  color: #fff;
  background: #0ea960;
  box-shadow: 0 8px 24px -8px #0ea96080, inset 0 0 0 1px #00000005;
}

.ins-btn--cafebazaar:hover {
  background: #0c8f50;
  transform: translateY(-1px);
}

.ins-btn--cafebazaar:active {
  transform: translateY(0);
}

.ins-btn__cb-logo {
  opacity: .95;
  align-items: center;
  display: inline-flex;
}

.ins-btn--big {
  gap: 14px;
  min-height: 68px;
  padding: 18px 26px;
}

.ins-btn--big .ins-btn__large {
  font-size: 18px;
}

.ins-btn--big .ins-btn__small {
  font-size: 12px;
}

@media (prefers-reduced-motion: reduce) {
  .ins-btn {
    transition: none;
  }

  .ins-btn:hover {
    transform: none;
  }
}

.ins-mockup {
  perspective: 1200px;
  justify-content: center;
  display: flex;
}

.ins-mockup__frame {
  aspect-ratio: 320 / 660;
  background: #050402;
  border-radius: 44px;
  width: 320px;
  padding: 12px;
  position: relative;
  transform: rotateY(-3deg)rotateX(2deg);
  box-shadow: 0 28px 80px -20px #0a323252, 0 8px 20px -10px #1f1c1740, inset 0 0 0 1.5px #ffffff0a;
}

.ins-mockup__notch {
  z-index: 2;
  background: #050402;
  border-radius: 14px;
  width: 110px;
  height: 24px;
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
}

.ins-mockup__screen {
  background: var(--color-surface-background);
  border-radius: 32px;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  height: 100%;
  padding: 38px 16px 16px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.ins-mockup__statusbar {
  color: var(--color-secondary-700);
  justify-content: space-between;
  align-items: center;
  padding: 0 4px;
  font-size: 11px;
  font-weight: 600;
  display: flex;
}

.ins-mockup__bars {
  background: linear-gradient(to right, var(--color-secondary-700) 0 6px, transparent 6px 9px, var(--color-secondary-700) 9px 16px, transparent 16px 19px, var(--color-secondary-700) 19px 26px, transparent 26px 29px, var(--color-secondary-300) 29px 32px);
  width: 32px;
  height: 8px;
}

.ins-mockup__header {
  align-items: center;
  gap: 10px;
  padding: 0 4px;
  display: flex;
}

.ins-mockup__avatar {
  background: var(--color-primary-600);
  width: 36px;
  height: 36px;
  color: var(--color-surface-card);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
}

.ins-mockup__title {
  color: var(--color-secondary-900);
  font-size: 14px;
  font-weight: 700;
}

.ins-mockup__subtitle {
  color: var(--color-secondary-500);
  font-size: 11px;
}

.ins-mockup__list {
  flex-direction: column;
  gap: 8px;
  display: flex;
}

.ins-mockup__row {
  background: var(--color-surface-card);
  border-radius: 14px;
  grid-template-columns: 36px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  display: grid;
  box-shadow: 0 1px 2px #1f1c170d;
}

.ins-mockup__icon {
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  display: inline-flex;
}

.ins-mockup__icon--primary {
  color: var(--color-primary-600);
  background: #0e7c7b1f;
}

.ins-mockup__icon--heritage {
  color: var(--color-heritage-700);
  background: #3bafa924;
}

.ins-mockup__icon--accent {
  color: var(--color-accent-700);
  background: #d4a24c2e;
}

.ins-mockup__row-title {
  color: var(--color-secondary-900);
  font-size: 12.5px;
  font-weight: 600;
}

.ins-mockup__row-who {
  color: var(--color-secondary-500);
  font-size: 11px;
}

.ins-mockup__row-amount {
  color: var(--color-secondary-900);
  font-variant-numeric: tabular-nums;
  font-size: 12.5px;
  font-weight: 700;
}

.ins-mockup__summary {
  background: var(--color-secondary-900);
  color: #f5efe3;
  border-radius: 14px;
  flex-direction: column;
  gap: 8px;
  margin-top: auto;
  padding: 12px 14px;
  display: flex;
}

.ins-mockup__summary-row {
  justify-content: space-between;
  align-items: center;
  font-size: 12.5px;
  display: flex;
}

.ins-mockup__summary-label {
  color: #f5efe3c7;
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.ins-mockup__summary-row strong {
  color: var(--color-accent-300);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
}

.ins-mockup__summary-row--ok {
  color: var(--color-heritage-300);
  font-size: 11.5px;
}

@media (max-width: 480px) {
  .ins-mockup__frame {
    width: 280px;
    transform: none;
  }
}

.ins-benefits {
  max-width: 1200px;
  margin: 0 auto;
  padding: 64px 20px;
}

.ins-benefits__grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
}

.ins-benefit {
  background: var(--color-surface-card);
  box-shadow: 0 1px 0 #fffc inset, 0 4px 14px -8px #1f1c1714, 0 0 0 1px var(--color-secondary-100);
  border-radius: 20px;
  flex-direction: column;
  gap: 10px;
  padding: 26px 24px;
  transition: transform .2s ease-out, box-shadow .2s ease-out;
  display: flex;
}

.ins-benefit:hover {
  box-shadow: 0 14px 32px -16px #1f1c172e, 0 0 0 1px var(--color-secondary-200);
  transform: translateY(-3px);
}

.ins-benefit__icon {
  border-radius: 14px;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  margin-bottom: 4px;
  display: inline-flex;
}

.ins-benefit--primary .ins-benefit__icon {
  color: var(--color-primary-700);
  background: #0e7c7b1f;
}

.ins-benefit--heritage .ins-benefit__icon {
  color: var(--color-heritage-700);
  background: #3bafa929;
}

.ins-benefit--accent .ins-benefit__icon {
  color: var(--color-accent-700);
  background: #d4a24c2e;
}

.ins-benefit__title {
  color: var(--color-secondary-900);
  margin: 0;
  font-size: 18px;
  font-weight: 700;
}

.ins-benefit__body {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 14.5px;
  line-height: 1.7;
}

@media (prefers-reduced-motion: reduce) {
  .ins-benefit:hover {
    transform: none;
  }
}

.ins-features {
  max-width: 1200px;
  margin: 0 auto;
  padding: 56px 20px 72px;
}

.ins-features__grid {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
}

.ins-feature {
  background: var(--color-surface-card);
  box-shadow: 0 0 0 1px var(--color-secondary-100);
  border-radius: 16px;
  flex-direction: column;
  gap: 8px;
  padding: 22px;
  transition: box-shadow .18s ease-out;
  display: flex;
}

.ins-feature:hover {
  box-shadow: 0 0 0 1px var(--color-secondary-200), 0 12px 30px -18px #1f1c172e;
}

.ins-feature__icon {
  background: var(--color-secondary-50);
  width: 40px;
  height: 40px;
  color: var(--color-primary-700);
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  margin-bottom: 2px;
  display: inline-flex;
}

.ins-feature__title {
  color: var(--color-secondary-900);
  margin: 0;
  font-size: 16px;
  font-weight: 700;
}

.ins-feature__body {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
}

.ins-trust {
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 20px 48px;
}

.ins-trust__card {
  background: var(--color-secondary-900);
  color: #f5efe3;
  background-image: radial-gradient(60% 80% at 0 0, #0e7c7b33 0%, #0000 60%), radial-gradient(60% 80% at 100% 100%, #d4a24c29 0%, #0000 60%);
  border-radius: 24px;
  gap: 18px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 28px;
  display: grid;
}

.ins-trust__head {
  align-items: center;
  gap: 12px;
  display: flex;
}

.ins-trust__badge {
  width: 40px;
  height: 40px;
  color: var(--color-accent-300);
  background: #f5efe31a;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.ins-trust__title {
  color: #fff;
  margin: 0;
  font-size: 22px;
  font-weight: 700;
}

.ins-trust__grid {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 14px;
  margin: 0;
  display: grid;
}

.ins-trust__item {
  background: #ffffff0a;
  border-radius: 12px;
  flex-direction: column;
  gap: 4px;
  padding: 14px 16px;
  display: flex;
}

.ins-trust__item dt {
  color: #f5efe399;
  margin: 0;
  font-size: 12px;
  font-weight: 500;
}

.ins-trust__item dd {
  color: #fff;
  margin: 0;
  font-size: 15px;
  font-weight: 700;
}

.ins-trust__note {
  color: #f5efe3b8;
  margin: 0;
  font-size: 13.5px;
  line-height: 1.7;
}

.ins-platforms {
  gap: 32px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 20px 48px;
  display: grid;
}

@media (min-width: 900px) {
  .ins-platforms {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
  }
}

.ins-platform {
  background: var(--color-surface-card);
  box-shadow: 0 0 0 1px var(--color-secondary-100);
  border-radius: 24px;
  flex-direction: column;
  gap: 24px;
  padding: 32px 28px;
  display: flex;
}

.ins-platform--ios {
  background: var(--color-secondary-900);
  color: #f5efe3;
  box-shadow: none;
}

.ins-platform__head {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.ins-platform__eyebrow {
  background: var(--color-secondary-100);
  color: var(--color-secondary-700);
  letter-spacing: .02em;
  text-transform: uppercase;
  border-radius: 999px;
  align-self: flex-start;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
}

.ins-platform--ios .ins-platform__eyebrow {
  color: #f5efe3d9;
  background: #ffffff1a;
}

.ins-platform__title {
  color: inherit;
  letter-spacing: -.01em;
  margin: 0;
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 800;
}

.ins-platform--android .ins-platform__title {
  color: var(--color-secondary-900);
}

.ins-platform--ios .ins-platform__title {
  color: #fff;
}

.ins-platform__lead {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 14.5px;
  line-height: 1.7;
}

.ins-platform--ios .ins-platform__lead {
  color: #f5efe3b8;
}

.ins-platform__cta-wrap {
  flex-wrap: wrap;
  gap: 12px;
  display: flex;
}

.ins-platform__cta-wrap > * {
  flex: 220px;
}

.ins-steps {
  flex-direction: column;
  gap: 12px;
  display: flex;
}

.ins-steps__title {
  color: var(--color-secondary-700);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin: 0;
  font-size: 14px;
  font-weight: 700;
}

.ins-platform--ios .ins-steps__title {
  color: #f5efe3b3;
}

.ins-steps__list {
  counter-reset: step;
  flex-direction: column;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.ins-step {
  background: var(--color-secondary-50);
  border-radius: 14px;
  grid-template-columns: 36px 1fr;
  gap: 12px;
  padding: 14px;
  display: grid;
}

.ins-platform--ios .ins-step {
  background: #ffffff0a;
}

.ins-step--ios {
  grid-template-columns: 36px 28px 1fr;
}

.ins-step__num {
  background: var(--color-primary-600);
  width: 36px;
  height: 36px;
  color: var(--color-surface-card);
  font-variant-numeric: tabular-nums;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
}

.ins-platform--ios .ins-step__num {
  background: var(--color-accent-500);
  color: var(--color-secondary-900);
}

.ins-step__visual {
  color: var(--color-secondary-600);
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.ins-platform--ios .ins-step__visual {
  color: #f5efe3d1;
}

.ins-step__title {
  color: var(--color-secondary-900);
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 700;
}

.ins-platform--ios .ins-step__title {
  color: #fff;
}

.ins-step__body {
  color: var(--color-secondary-600);
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
}

.ins-platform--ios .ins-step__body {
  color: #f5efe3b3;
}

.ins-steps__fineprint {
  color: var(--color-secondary-500);
  margin: 4px 0 0;
  font-size: 12.5px;
  line-height: 1.65;
}

.ins-platform--ios .ins-steps__fineprint {
  color: #f5efe38c;
}

.ins-faq {
  max-width: 800px;
  margin: 0 auto;
  padding: 64px 20px 56px;
}

.ins-faq .ins-section__title {
  text-align: center;
  margin-bottom: 24px;
}

.ins-faq__list {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.ins-faq__item {
  background: var(--color-surface-card);
  box-shadow: 0 0 0 1px var(--color-secondary-100);
  border-radius: 14px;
  overflow: hidden;
}

.ins-faq__item summary {
  cursor: pointer;
  color: var(--color-secondary-900);
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 18px 22px;
  font-size: 15.5px;
  font-weight: 600;
  list-style: none;
  transition: background .16s ease-out;
  display: flex;
}

.ins-faq__item summary::-webkit-details-marker {
  display: none;
}

.ins-faq__item summary:hover {
  background: var(--color-secondary-50);
}

.ins-faq__chev {
  color: var(--color-secondary-500);
  flex-shrink: 0;
  transition: transform .2s ease-out;
  display: inline-flex;
}

.ins-faq__item[open] .ins-faq__chev {
  transform: rotate(180deg);
}

.ins-faq__item p {
  color: var(--color-secondary-600);
  margin: 0;
  padding: 0 22px 22px;
  font-size: 14.5px;
  line-height: 1.75;
}

.ins-dock {
  z-index: 60;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  -webkit-backdrop-filter: blur(14px);
  border-block-start: 1px solid var(--color-secondary-200);
  background: #faf7f2eb;
  gap: 10px;
  transition: transform .2s ease-out;
  display: none;
  position: fixed;
  inset-block-end: 0;
  inset-inline: 0;
  transform: translateY(110%);
}

.ins-dock[data-ready="true"] {
  transform: translateY(0);
}

@media (max-width: 880px) {
  .ins-dock {
    display: flex;
  }
}

.ins-dock__btn {
  border-radius: 12px;
  flex: 1 1 0;
  justify-content: center;
  align-items: center;
  gap: 8px;
  min-height: 48px;
  padding: 12px 14px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
}

.ins-dock__btn--android {
  background: var(--color-primary-600);
  color: var(--color-surface-card);
}

.ins-dock__btn--cafebazaar {
  color: #fff;
  background: #0ea960;
}

.ins-dock__btn--ios {
  color: #fff;
  background: #1f1c17;
}

@media (prefers-reduced-motion: reduce) {
  .ins-dock {
    transition: none;
  }
}

html, body {
  background-color: var(--color-surface-background);
  color: var(--color-secondary-800);
}

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

@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@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-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-space-x-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-divide-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

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

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

@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

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

@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}

@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}

@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}

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

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

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

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

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

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

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

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

@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

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

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

@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

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

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

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

@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

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

@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0;
}

@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}

@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@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
}

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

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

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

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

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

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

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

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

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

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

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

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

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