@import "https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;500;600;700;800&family=Playfair+Display:wght@400;500;600;700&display=swap";
/* [project]/src/app/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-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-leading: initial;
      --tw-font-weight: 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-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-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
    }
  }
}

@layer theme {
  :root, :host {
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --color-red-50: #fef2f2;
    --color-red-200: #ffcaca;
    --color-red-500: #fb2c36;
    --color-red-700: #bf000f;
    --color-amber-50: #fffbeb;
    --color-amber-100: #fef3c6;
    --color-amber-200: #fee685;
    --color-amber-300: #ffd236;
    --color-amber-600: #dd7400;
    --color-amber-700: #b75000;
    --color-amber-800: #953d00;
    --color-green-50: #f0fdf4;
    --color-green-100: #dcfce7;
    --color-green-300: #7bf1a8;
    --color-green-500: #00c758;
    --color-green-800: #016630;
    --color-blue-50: #eff6ff;
    --color-blue-100: #dbeafe;
    --color-blue-200: #bedbff;
    --color-blue-500: #3080ff;
    --color-blue-800: #193cb8;
    --color-gray-50: #f9fafb;
    --color-gray-100: #f3f4f6;
    --color-gray-200: #e5e7eb;
    --color-gray-600: #4a5565;
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-md: 28rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-6xl: 72rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --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);
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --leading-relaxed: 1.625;
    --radius-lg: .5rem;
    --radius-xl: .75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --blur-sm: 8px;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: "Nunito", "Segoe UI", system-ui, sans-serif;
    --default-mono-font-family: var(--font-mono);
  }

  @supports (color: lab(0% 0 0)) {
    :root, :host {
      --color-red-50: lab(96.5005% 4.18508 1.52328);
      --color-red-200: lab(86.017% 19.8815 7.75869);
      --color-red-500: lab(55.4814% 75.0732 48.8528);
      --color-red-700: lab(40.4273% 67.2623 53.7441);
      --color-amber-50: lab(98.6252% -.635922 8.42309);
      --color-amber-100: lab(95.916% -1.21653 23.111);
      --color-amber-200: lab(91.7203% -.505269 49.9084);
      --color-amber-300: lab(86.4156% 6.13147 78.3961);
      --color-amber-600: lab(60.3514% 40.5624 87.1228);
      --color-amber-700: lab(47.2709% 42.9082 69.2966);
      --color-amber-800: lab(37.8822% 37.1699 52.2718);
      --color-green-50: lab(98.1563% -5.60117 2.75915);
      --color-green-100: lab(96.1861% -13.8464 6.52365);
      --color-green-300: lab(86.9953% -47.2691 25.0054);
      --color-green-500: lab(70.5521% -66.5147 45.8073);
      --color-green-800: lab(37.4616% -36.7971 22.9692);
      --color-blue-50: lab(96.492% -1.14644 -5.11479);
      --color-blue-100: lab(92.0301% -2.24757 -11.6453);
      --color-blue-200: lab(86.15% -4.04379 -21.0797);
      --color-blue-500: lab(54.1736% 13.3369 -74.6839);
      --color-blue-800: lab(30.2514% 27.7853 -70.2699);
      --color-gray-50: lab(98.2596% -.247031 -.706708);
      --color-gray-100: lab(96.1596% -.0823438 -1.13575);
      --color-gray-200: lab(91.6229% -.159115 -2.26791);
      --color-gray-600: lab(35.6337% -1.58697 -10.8425);
    }
  }
}

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

@layer components;

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

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .sticky {
    position: sticky;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .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-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }

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

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

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

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

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

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

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

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

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

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

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

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

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

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

  .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-40 {
    height: calc(var(--spacing) * 40);
  }

  .h-full {
    height: 100%;
  }

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

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

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

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

  .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-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-full {
    width: 100%;
  }

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

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

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

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

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

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

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

  .flex-1 {
    flex: 1;
  }

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

  .scale-110 {
    --tw-scale-x: 110%;
    --tw-scale-y: 110%;
    --tw-scale-z: 110%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }

  .cursor-pointer {
    cursor: pointer;
  }

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

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

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

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

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

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

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

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

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

  :where(.space-y-1 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 1) * 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)));
  }

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

  .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-full {
    border-radius: 3.40282e38px;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .bg-\[rgba\(139\,34\,82\,0\.05\)\] {
    background-color: #8b22520d;
  }

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

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

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

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

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

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

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

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

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

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

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

  .bg-black\/30 {
    background-color: #0000004d;
  }

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

  .bg-black\/50 {
    background-color: #00000080;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .capitalize {
    text-transform: capitalize;
  }

  .italic {
    font-style: italic;
  }

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

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

  .opacity-60 {
    opacity: .6;
  }

  .opacity-70 {
    opacity: .7;
  }

  .opacity-80 {
    opacity: .8;
  }

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

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

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

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

  .last\:pb-0:last-child {
    padding-bottom: calc(var(--spacing) * 0);
  }

  @media (hover: hover) {
    .hover\:-translate-y-1:hover {
      --tw-translate-y: calc(var(--spacing) * -1);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }

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

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

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

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

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

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

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

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

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

  @media (min-width: 40rem) {
    .sm\:w-16 {
      width: calc(var(--spacing) * 16);
    }
  }

  @media (min-width: 40rem) {
    .sm\:w-24 {
      width: calc(var(--spacing) * 24);
    }
  }

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

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

  @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: 64rem) {
    .lg\:col-span-1 {
      grid-column: span 1 / span 1;
    }
  }

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

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

:root {
  --primary: #8b2252;
  --primary-light: #a94067;
  --primary-dark: #6b1a3f;
  --accent: #d4a574;
  --accent-light: #e8c9a0;
  --background: #fdf8f5;
  --background-card: #fff;
  --foreground: #2d2024;
  --foreground-muted: #6b5b61;
  --border: #e8ddd8;
  --border-focus: #8b2252;
  --success: #4a7c59;
  --warning: #c9a227;
  --error: #b54a4a;
  --gradient-primary: linear-gradient(135deg, #8b2252 0%, #a94067 50%, #c9607a 100%);
  --gradient-warm: linear-gradient(135deg, #d4a574 0%, #e8c9a0 100%);
  --gradient-cool: linear-gradient(135deg, #7a8b9a 0%, #a0b0c0 100%);
}

body {
  background: var(--background);
  color: var(--foreground);
  min-height: 100vh;
  font-family: Nunito, Segoe UI, system-ui, sans-serif;
}

h1, h2, h3, .heading {
  letter-spacing: -.02em;
  font-family: Playfair Display, Georgia, serif;
  font-weight: 600;
}

.app-background {
  background: radial-gradient(ellipse at top right, #8b225214 0%, transparent 50%), radial-gradient(ellipse at bottom left, #d4a5741f 0%, transparent 50%), var(--background);
  min-height: 100vh;
}

.card {
  background: var(--background-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  transition: all .3s;
  box-shadow: 0 4px 6px -1px #8b22520d, 0 10px 30px -5px #00000014;
}

.card:hover {
  box-shadow: 0 8px 12px -2px #8b225214, 0 20px 40px -10px #0000001f;
}

.btn-primary {
  background: var(--gradient-primary);
  color: #fff;
  cursor: pointer;
  border: none;
  border-radius: 12px;
  padding: 14px 32px;
  font-weight: 600;
  transition: all .3s;
  box-shadow: 0 4px 15px #8b22524d;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px #8b225266;
}

.btn-primary:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none;
}

.btn-secondary {
  color: var(--primary);
  border: 2px solid var(--primary);
  cursor: pointer;
  background: none;
  border-radius: 12px;
  padding: 14px 32px;
  font-weight: 600;
  transition: all .3s;
}

.btn-secondary:hover {
  background: var(--primary);
  color: #fff;
}

.step-indicator {
  justify-content: center;
  gap: 8px;
  margin-bottom: 32px;
  display: flex;
}

.step-dot {
  background: var(--border);
  border-radius: 50%;
  width: 12px;
  height: 12px;
  transition: all .3s;
}

.step-dot.active {
  background: var(--primary);
  border-radius: 6px;
  width: 32px;
}

.step-dot.completed {
  background: var(--success);
}

.progress-bar {
  background: var(--border);
  border-radius: 2px;
  height: 4px;
  overflow: hidden;
}

.progress-fill {
  background: var(--gradient-primary);
  height: 100%;
  transition: width .5s;
}

.color-swatch {
  cursor: pointer;
  border: 3px solid #0000;
  border-radius: 50%;
  width: 48px;
  height: 48px;
  transition: all .2s;
  box-shadow: 0 2px 8px #00000026;
}

.color-swatch:hover {
  transform: scale(1.1);
}

.color-swatch.selected {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px #8b22524d;
}

.color-swatch-large {
  border-radius: 12px;
  width: 64px;
  height: 64px;
}

.ugt-scale {
  background: linear-gradient(90deg, #1c1c1c 0%, #3d2314 15%, #6b4423 30%, #8b7355 45%, #a68b5b 55%, #c4a77d 70%, #dbc49c 85%, #f0e6d0 100%);
  border-radius: 8px;
  gap: 4px;
  height: 48px;
  padding: 8px;
  display: flex;
}

.ugt-level {
  cursor: pointer;
  border: 2px solid #0000;
  border-radius: 4px;
  flex: 1;
  transition: all .2s;
}

.ugt-level:hover {
  border-color: #ffffff80;
}

.ugt-level.selected {
  border-color: #fff;
  box-shadow: 0 0 10px #ffffff80;
}

.grey-scale {
  flex-wrap: wrap;
  gap: 12px;
  display: flex;
}

.grey-option {
  border: 2px solid var(--border);
  cursor: pointer;
  border-radius: 12px;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  min-width: 100px;
  padding: 12px;
  transition: all .2s;
  display: flex;
}

.grey-option:hover {
  border-color: var(--primary-light);
}

.grey-option.selected {
  border-color: var(--primary);
  background: #8b22520d;
}

.grey-visual {
  background: #5c4033;
  border-radius: 50%;
  width: 48px;
  height: 48px;
  position: relative;
  overflow: hidden;
}

.grey-visual:after {
  content: "";
  background: linear-gradient(135deg, silver 0%, #e8e8e8 100%);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.grey-visual[data-grey="none"]:after {
  width: 0%;
}

.grey-visual[data-grey="low"]:after {
  width: 30%;
}

.grey-visual[data-grey="medium"]:after {
  width: 50%;
}

.grey-visual[data-grey="high"]:after {
  width: 70%;
}

.grey-visual[data-grey="very_high"]:after {
  width: 100%;
}

.direction-tabs {
  background: var(--border);
  border-radius: 12px;
  gap: 8px;
  padding: 4px;
  display: flex;
}

.direction-tab {
  cursor: pointer;
  color: var(--foreground-muted);
  background: none;
  border: none;
  border-radius: 8px;
  flex: 1;
  padding: 12px 24px;
  font-weight: 600;
  transition: all .2s;
}

.direction-tab.active {
  color: var(--foreground);
  background: #fff;
  box-shadow: 0 2px 8px #0000001a;
}

.direction-tab.warm.active {
  color: #5c4033;
  background: linear-gradient(135deg, #d4a574, #e8c9a0);
}

.direction-tab.cool.active {
  color: #2a3a4a;
  background: linear-gradient(135deg, #7a8b9a, #a0b0c0);
}

.direction-tab.neutral.active {
  color: #3d2314;
  background: linear-gradient(135deg, #a68b5b, #c4a77d);
}

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

.shade-card {
  border: 2px solid var(--border);
  cursor: pointer;
  text-align: center;
  border-radius: 16px;
  padding: 16px;
  transition: all .2s;
}

.shade-card:hover {
  border-color: var(--primary-light);
  transform: translateY(-2px);
}

.shade-card.selected {
  border-color: var(--primary);
  background: #8b22520d;
}

.upload-zone {
  border: 2px dashed var(--border);
  text-align: center;
  cursor: pointer;
  background: #ffffff80;
  border-radius: 20px;
  padding: 48px;
  transition: all .3s;
}

.upload-zone:hover {
  border-color: var(--primary);
  background: #8b225205;
}

.upload-zone.has-image {
  border-style: solid;
  border-color: var(--success);
  padding: 16px;
}

.result-preview {
  grid-template-columns: 1fr 1fr;
  justify-items: center;
  gap: 32px;
  display: grid;
}

.result-image {
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 20px;
  width: 100%;
  max-width: 400px;
  overflow: hidden;
  box-shadow: 0 8px 30px #0000001f;
}

.preview-fullwidth {
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  width: 100%;
  display: grid;
}

.preview-image-full {
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 24px;
  width: 100%;
  overflow: hidden;
  box-shadow: 0 10px 40px #00000026, 0 0 0 1px #8b22521a;
}

.preview-placeholder-full {
  aspect-ratio: 3 / 4;
  background: linear-gradient(135deg, var(--border) 0%, #8b22520d 100%);
  border: 2px dashed var(--border);
  border-radius: 24px;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.preview-compact {
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  width: 100%;
  display: grid;
}

.preview-image-compact {
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 20px;
  width: 100%;
  overflow: hidden;
  box-shadow: 0 8px 30px #0000001f;
}

.preview-placeholder {
  aspect-ratio: 3 / 4;
  background: var(--border);
  border-radius: 20px;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.alert {
  border-radius: 12px;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  display: flex;
}

.alert-warning {
  color: #8a7019;
  background: #c9a2271a;
  border: 1px solid #c9a2274d;
}

.alert-error {
  color: #8a2e2e;
  background: #b54a4a1a;
  border: 1px solid #b54a4a4d;
}

.alert-success {
  color: #2e5a3d;
  background: #4a7c591a;
  border: 1px solid #4a7c594d;
}

.alert-info {
  color: var(--primary-dark);
  background: #8b225214;
  border: 1px solid #8b225233;
}

.checkbox-card {
  border: 2px solid var(--border);
  cursor: pointer;
  border-radius: 12px;
  align-items: center;
  gap: 12px;
  padding: 16px;
  transition: all .2s;
  display: flex;
}

.checkbox-card:hover {
  border-color: var(--primary-light);
}

.checkbox-card.selected {
  border-color: var(--primary);
  background: #8b22520d;
}

.checkbox-card.warning {
  border-color: var(--warning);
  background: #c9a2270d;
}

.spinner {
  border: 3px solid var(--border);
  border-top-color: var(--primary);
  border-radius: 50%;
  width: 40px;
  height: 40px;
  animation: .8s linear infinite spin;
}

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

.loading-overlay {
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  z-index: 1000;
  background: #fdf8f5f2;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  animation: .3s ease-out fadeInOverlay;
  display: flex;
  position: fixed;
  inset: 0;
}

@keyframes fadeInOverlay {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.loading-hair {
  width: 120px;
  height: 120px;
  margin-bottom: 32px;
  position: relative;
}

.loading-hair:before {
  content: "";
  background: radial-gradient(circle, #8b22521a 0%, #0000 70%);
  border-radius: 50%;
  animation: 2s ease-in-out infinite pulse-glow;
  position: absolute;
  inset: 0;
}

@keyframes pulse-glow {
  0%, 100% {
    opacity: .5;
    transform: scale(1);
  }

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

.hair-strand {
  transform-origin: bottom;
  border-radius: 2px;
  width: 4px;
  height: 60px;
  animation: 1.5s ease-in-out infinite wave-strand;
  position: absolute;
  bottom: 50%;
  left: 50%;
}

.hair-strand:first-child {
  background: linear-gradient(to top, #8b2252, #c9607a);
  animation-delay: 0s;
  transform: translateX(-20px)rotate(-25deg);
}

.hair-strand:nth-child(2) {
  background: linear-gradient(to top, #a94067, #d4a574);
  animation-delay: .1s;
  transform: translateX(-10px)rotate(-12deg);
}

.hair-strand:nth-child(3) {
  background: linear-gradient(to top, #8b2252, #e8c9a0);
  height: 70px;
  animation-delay: .2s;
  transform: translateX(0)rotate(0);
}

.hair-strand:nth-child(4) {
  background: linear-gradient(to top, #a94067, #d4a574);
  animation-delay: .3s;
  transform: translateX(10px)rotate(12deg);
}

.hair-strand:nth-child(5) {
  background: linear-gradient(to top, #8b2252, #c9607a);
  animation-delay: .4s;
  transform: translateX(20px)rotate(25deg);
}

@keyframes wave-strand {
  0%, 100% {
    transform: translateX(var(--tx, 0)) rotate(var(--rot, 0deg)) scaleY(1);
  }

  50% {
    transform: translateX(var(--tx, 0)) rotate(calc(var(--rot, 0deg)  + 8deg)) scaleY(1.1);
  }
}

.hair-strand:first-child {
  --tx: -20px;
  --rot: -25deg;
}

.hair-strand:nth-child(2) {
  --tx: -10px;
  --rot: -12deg;
}

.hair-strand:nth-child(3) {
  --tx: 0px;
  --rot: 0deg;
}

.hair-strand:nth-child(4) {
  --tx: 10px;
  --rot: 12deg;
}

.hair-strand:nth-child(5) {
  --tx: 20px;
  --rot: 25deg;
}

.loading-sparkle {
  background: var(--accent);
  border-radius: 50%;
  width: 8px;
  height: 8px;
  animation: 2s ease-in-out infinite sparkle;
  position: absolute;
}

.loading-sparkle:nth-child(6) {
  animation-delay: 0s;
  top: 10px;
  left: 20px;
}

.loading-sparkle:nth-child(7) {
  animation-delay: .5s;
  top: 30px;
  right: 15px;
}

.loading-sparkle:nth-child(8) {
  animation-delay: 1s;
  bottom: 25px;
  left: 25px;
}

.loading-sparkle:nth-child(9) {
  animation-delay: 1.5s;
  bottom: 40px;
  right: 20px;
}

@keyframes sparkle {
  0%, 100% {
    opacity: 0;
    transform: scale(0);
  }

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

.loading-title {
  color: var(--primary);
  text-align: center;
  margin-bottom: 8px;
  font-family: Playfair Display, Georgia, serif;
  font-size: 1.5rem;
  font-weight: 600;
}

.loading-subtitle {
  color: var(--foreground-muted);
  text-align: center;
  margin-bottom: 24px;
  font-size: 1rem;
}

.loading-dots {
  gap: 8px;
  display: flex;
}

.loading-dot {
  background: var(--border);
  border-radius: 50%;
  width: 10px;
  height: 10px;
  animation: 1.4s ease-in-out infinite dot-bounce;
}

.loading-dot:first-child {
  animation-delay: 0s;
}

.loading-dot:nth-child(2) {
  animation-delay: .2s;
}

.loading-dot:nth-child(3) {
  animation-delay: .4s;
}

@keyframes dot-bounce {
  0%, 80%, 100% {
    background: var(--border);
    transform: scale(1);
  }

  40% {
    background: var(--primary);
    transform: scale(1.3);
  }
}

.loading-progress {
  background: var(--border);
  border-radius: 2px;
  width: 200px;
  height: 4px;
  margin-top: 24px;
  overflow: hidden;
}

.loading-progress-fill {
  background: var(--gradient-primary);
  border-radius: 2px;
  height: 100%;
  animation: 1.5s ease-in-out infinite progress-indeterminate;
}

@keyframes progress-indeterminate {
  0% {
    width: 0%;
    margin-left: 0%;
  }

  50% {
    width: 60%;
    margin-left: 20%;
  }

  100% {
    width: 0%;
    margin-left: 100%;
  }
}

.loading-steps {
  background: #fff;
  border-radius: 16px;
  flex-direction: column;
  gap: 12px;
  margin-top: 32px;
  padding: 24px;
  display: flex;
  box-shadow: 0 4px 20px #8b22521a;
}

.loading-step {
  color: var(--foreground-muted);
  align-items: center;
  gap: 12px;
  font-size: 14px;
  transition: all .3s;
  display: flex;
}

.loading-step.active {
  color: var(--primary);
  font-weight: 600;
}

.loading-step.completed {
  color: var(--success);
}

.loading-step-icon {
  background: var(--border);
  width: 24px;
  height: 24px;
  color: var(--foreground-muted);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  transition: all .3s;
  display: flex;
}

.loading-step.active .loading-step-icon {
  background: var(--primary);
  color: #fff;
  animation: 1s ease-in-out infinite pulse-step;
}

.loading-step.completed .loading-step-icon {
  background: var(--success);
  color: #fff;
}

@keyframes pulse-step {
  0%, 100% {
    box-shadow: 0 0 #8b225266;
  }

  50% {
    box-shadow: 0 0 0 8px #8b225200;
  }
}

.fade-in {
  animation: .4s ease-out fadeIn;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

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

.instruction-card {
  border: 1px solid var(--border);
  background: linear-gradient(135deg, #8b22520d 0%, #d4a57414 100%);
  border-radius: 20px;
  padding: 24px;
}

.instruction-row {
  border-bottom: 1px solid var(--border);
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  display: flex;
}

.instruction-row:last-child {
  border-bottom: none;
}

.instruction-label {
  color: var(--foreground-muted);
  font-size: 14px;
}

.instruction-value {
  color: var(--foreground);
  font-weight: 600;
}

.tips-list {
  padding: 0;
  list-style: none;
}

.tips-list li {
  border-bottom: 1px solid var(--border);
  padding: 12px 0 12px 32px;
  position: relative;
}

.tips-list li:last-child {
  border-bottom: none;
}

.tips-list li:before {
  content: "✓";
  color: var(--success);
  font-weight: bold;
  position: absolute;
  left: 0;
}

.module-card {
  background: var(--background-card);
  border: 2px solid var(--border);
  border-radius: 24px;
  flex-direction: column;
  height: 100%;
  padding: 32px;
  transition: all .3s;
  display: flex;
}

.module-card.available {
  cursor: pointer;
}

.module-card.available:hover {
  border-color: var(--primary);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px #8b225226, 0 0 0 1px #8b22521a;
}

.module-card.disabled {
  opacity: .7;
  cursor: not-allowed;
  position: relative;
}

.module-badge {
  background: var(--accent);
  color: #fff;
  border-radius: 20px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 600;
  position: absolute;
  top: 16px;
  right: 16px;
}

.module-icon {
  border-radius: 20px;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  margin-bottom: 20px;
  display: flex;
  box-shadow: 0 8px 20px #00000026;
}

.module-title {
  color: var(--foreground);
  margin-bottom: 12px;
  font-size: 1.5rem;
  font-weight: 700;
}

.module-description {
  color: var(--foreground-muted);
  margin-bottom: 20px;
  line-height: 1.6;
}

.module-features {
  flex: 1;
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}

.module-features li {
  color: var(--foreground);
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  font-size: 14px;
  display: flex;
}

.feature-check {
  width: 20px;
  height: 20px;
  color: var(--success);
  background: #4a7c5926;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  display: flex;
}

.module-action {
  background: var(--gradient-primary);
  color: #fff;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 14px 24px;
  font-weight: 600;
  transition: all .2s;
  display: flex;
}

.module-card.available:hover .module-action {
  transform: translateX(4px);
}

.module-action.disabled {
  background: var(--border);
  color: var(--foreground-muted);
}

.coloring-tips {
  margin-top: 32px;
}

.tips-header {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  display: flex;
}

.tips-actions {
  gap: 8px;
  display: flex;
}

.tips-action-btn {
  color: var(--primary);
  cursor: pointer;
  background: none;
  border: none;
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 13px;
  transition: all .2s;
}

.tips-action-btn:hover {
  background: #8b225214;
}

.tips-list {
  flex-direction: column;
  gap: 8px;
  display: flex;
}

.tip-card {
  background: var(--background-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  transition: all .2s;
  overflow: hidden;
}

.tip-card:hover {
  border-color: var(--primary-light);
}

.tip-card.warning {
  background: #c9a22708;
  border-color: #c9a22766;
}

.tip-card.warning:hover {
  border-color: var(--warning);
}

.tip-card.open {
  box-shadow: 0 4px 12px #8b225214;
}

.tip-header {
  cursor: pointer;
  text-align: left;
  width: 100%;
  color: var(--foreground);
  background: none;
  border: none;
  align-items: center;
  gap: 12px;
  padding: 16px;
  font-size: 15px;
  font-weight: 600;
  transition: all .2s;
  display: flex;
}

.tip-header:hover {
  background: #8b225208;
}

.tip-icon {
  flex-shrink: 0;
  font-size: 20px;
}

.tip-title {
  flex: 1;
}

.tip-chevron {
  color: var(--foreground-muted);
  align-items: center;
  transition: transform .3s;
  display: flex;
}

.tip-chevron.open {
  transform: rotate(180deg);
}

.tip-content {
  max-height: 0;
  padding: 0 16px;
  transition: max-height .3s, padding .3s;
  overflow: hidden;
}

.tip-content.open {
  max-height: 2000px;
  padding: 0 16px 16px;
}

.tip-text {
  color: var(--foreground);
  font-size: 14px;
  line-height: 1.7;
}

.tip-text p {
  margin-bottom: 12px;
}

.tip-text p:last-child {
  margin-bottom: 0;
}

.tip-text strong {
  color: var(--primary-dark);
  font-weight: 600;
}

.tip-lifehack {
  color: var(--foreground-muted);
  background: #8b22520d;
  border-radius: 8px;
  align-items: flex-start;
  gap: 8px;
  margin-top: 12px;
  padding: 12px;
  font-size: 13px;
  line-height: 1.6;
  display: flex;
}

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

.tip-subtitle {
  color: var(--foreground-muted);
  margin-top: 12px;
  font-size: 13px;
  font-style: italic;
}

@media (max-width: 768px) {
  .result-preview {
    grid-template-columns: 1fr;
  }

  .result-image {
    max-width: 100%;
  }

  .preview-fullwidth {
    gap: 20px;
  }

  .preview-image-full, .preview-placeholder-full {
    border-radius: 16px;
  }

  .preview-compact {
    gap: 16px;
  }

  .preview-image-compact, .preview-placeholder {
    max-width: 150px;
  }

  .shade-grid {
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  }

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

@media (min-width: 1200px) {
  .result-image {
    max-width: 450px;
  }
}

@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}

@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

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

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

@property --tw-font-weight {
  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-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-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;
}

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