/*! tailwindcss v4.1.17 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;

@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-500: oklch(63.7% 0.237 25.331);
        --color-orange-100: oklch(95.4% 0.038 75.164);
        --color-orange-500: oklch(70.5% 0.213 47.604);
        --color-orange-600: oklch(64.6% 0.222 41.116);
        --color-yellow-400: oklch(85.2% 0.199 91.936);
        --color-green-100: oklch(96.2% 0.044 156.743);
        --color-green-500: oklch(72.3% 0.219 149.579);
        --color-green-600: oklch(62.7% 0.194 149.214);
        --color-blue-50: oklch(97% 0.014 254.604);
        --color-blue-100: oklch(93.2% 0.032 255.585);
        --color-blue-400: oklch(70.7% 0.165 254.624);
        --color-blue-500: oklch(62.3% 0.214 259.815);
        --color-blue-600: oklch(54.6% 0.245 262.881);
        --color-blue-700: oklch(48.8% 0.243 264.376);
        --color-blue-800: oklch(42.4% 0.199 265.638);
        --color-purple-100: oklch(94.6% 0.033 307.174);
        --color-purple-400: oklch(71.4% 0.203 305.504);
        --color-purple-500: oklch(62.7% 0.265 303.9);
        --color-purple-600: oklch(55.8% 0.288 302.321);
        --color-gray-50: oklch(98.5% 0.002 247.839);
        --color-gray-100: oklch(96.7% 0.003 264.542);
        --color-gray-200: oklch(92.8% 0.006 264.531);
        --color-gray-300: oklch(87.2% 0.01 258.338);
        --color-gray-400: oklch(70.7% 0.022 261.325);
        --color-gray-500: oklch(55.1% 0.027 264.364);
        --color-gray-600: oklch(44.6% 0.03 256.802);
        --color-gray-700: oklch(37.3% 0.034 259.733);
        --color-gray-800: oklch(27.8% 0.033 256.848);
        --color-gray-900: oklch(21% 0.034 264.665);
        --color-black: #000;
        --color-white: #fff;
        --spacing: 0.25rem;
        --container-sm: 24rem;
        --container-md: 28rem;
        --container-lg: 32rem;
        --container-2xl: 42rem;
        --container-3xl: 48rem;
        --container-4xl: 56rem;
        --container-5xl: 64rem;
        --container-6xl: 72rem;
        --container-7xl: 80rem;
        --text-xs: 0.75rem;
        --text-xs--line-height: calc(1 / 0.75);
        --text-sm: 0.875rem;
        --text-sm--line-height: calc(1.25 / 0.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;
        --text-7xl: 4.5rem;
        --text-7xl--line-height: 1;
        --font-weight-normal: 400;
        --font-weight-medium: 500;
        --font-weight-semibold: 600;
        --font-weight-bold: 700;
        --font-weight-extrabold: 800;
        --font-weight-black: 900;
        --tracking-tighter: -0.05em;
        --tracking-wider: 0.05em;
        --tracking-widest: 0.1em;
        --leading-tight: 1.25;
        --leading-snug: 1.375;
        --leading-relaxed: 1.625;
        --radius-md: 0.375rem;
        --radius-lg: 0.5rem;
        --radius-xl: 0.75rem;
        --radius-2xl: 1rem;
        --radius-3xl: 1.5rem;
        --ease-out: cubic-bezier(0, 0, 0.2, 1);
        --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
        --animate-bounce: bounce 1s infinite;
        --blur-sm: 8px;
        --blur-3xl: 64px;
        --default-transition-duration: 150ms;
        --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
        --default-font-family: var(--font-sans);
        --default-mono-font-family: var(--font-mono);
    }
}

@layer base {

    *,
    ::after,
    ::before,
    ::backdrop,
    ::file-selector-button {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
        border: 0 solid;
    }

    html,
    :host {
        line-height: 1.5;
        -webkit-text-size-adjust: 100%;
        tab-size: 4;
        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;
        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 {
        font-size: 75%;
        line-height: 0;
        position: relative;
        vertical-align: baseline;
    }

    sub {
        bottom: -0.25em;
    }

    sup {
        top: -0.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 {
        display: block;
        vertical-align: middle;
    }

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

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

    :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)) {
                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,
    ::-webkit-datetime-edit-year-field,
    ::-webkit-datetime-edit-month-field,
    ::-webkit-datetime-edit-day-field,
    ::-webkit-datetime-edit-hour-field,
    ::-webkit-datetime-edit-minute-field,
    ::-webkit-datetime-edit-second-field,
    ::-webkit-datetime-edit-millisecond-field,
    ::-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"]),
    ::file-selector-button {
        appearance: button;
    }

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

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

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

    .invisible {
        visibility: hidden;
    }

    .visible {
        visibility: visible;
    }

    .absolute {
        position: absolute;
    }

    .fixed {
        position: fixed;
    }

    .relative {
        position: relative;
    }

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

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

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

    .top-1\/2 {
        top: calc(1/2 * 100%);
    }

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

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

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

    .top-full {
        top: 100%;
    }

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

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

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

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

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

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

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

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

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

    .left-1\/2 {
        left: calc(1/2 * 100%);
    }

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

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

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

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

    .order-1 {
        order: 1;
    }

    .order-2 {
        order: 2;
    }

    .container {
        width: 100%;

        @media (width >=40rem) {
            max-width: 40rem;
        }

        @media (width >=48rem) {
            max-width: 48rem;
        }

        @media (width >=64rem) {
            max-width: 64rem;
        }

        @media (width >=80rem) {
            max-width: 80rem;
        }

        @media (width >=96rem) {
            max-width: 96rem;
        }
    }

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

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

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

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

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

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

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

    .mr-3 {
        margin-right: calc(var(--spacing) * 3);
    }

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

    .mr-16 {
        margin-right: calc(var(--spacing) * 16);
    }

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

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

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

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

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

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

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

    .-ml-\[104px\] {
        margin-left: calc(104px * -1);
    }

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

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

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

    .\!hidden {
        display: none !important;
    }

    .block {
        display: block;
    }

    .flex {
        display: flex;
    }

    .grid {
        display: grid;
    }

    .hidden {
        display: none;
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

    .h-full {
        height: 100%;
    }

    .h-px {
        height: 1px;
    }

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

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

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

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

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

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

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

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

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

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

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

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

    .w-auto {
        width: auto;
    }

    .w-full {
        width: 100%;
    }

    .\!max-w-\[inherit\] {
        max-width: inherit !important;
    }

    .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-5xl {
        max-width: var(--container-5xl);
    }

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

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

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

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

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

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

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

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

    .flex-1 {
        flex: 1;
    }

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

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

    .origin-top-right {
        transform-origin: 100% 0;
    }

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

    .translate-x-full {
        --tw-translate-x: 100%;
        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);
    }

    .-translate-y-2 {
        --tw-translate-y: calc(var(--spacing) * -2);
        translate: var(--tw-translate-x) var(--tw-translate-y);
    }

    .translate-y-2 {
        --tw-translate-y: calc(var(--spacing) * 2);
        translate: var(--tw-translate-x) var(--tw-translate-y);
    }

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

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

    .rotate-180 {
        rotate: 180deg;
    }

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

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

    .cursor-pointer {
        cursor: pointer;
    }

    .resize {
        resize: both;
    }

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

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

    .grid-cols-\[30\%_70\%\] {
        grid-template-columns: 30% 70%;
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

    .space-y-1 {
        :where(& > :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)));
        }
    }

    .space-y-2 {
        :where(& > :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)));
        }
    }

    .space-y-3 {
        :where(& > :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)));
        }
    }

    .space-y-4 {
        :where(& > :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)));
        }
    }

    .space-y-6 {
        :where(& > :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)));
        }
    }

    .space-y-8 {
        :where(& > :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)));
        }
    }

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

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

    .overflow-hidden {
        overflow: hidden;
    }

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

    .rounded {
        border-radius: 0.25rem;
    }

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

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

    .rounded-full {
        border-radius: calc(infinity * 1px);
    }

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

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

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

    .rounded-r-2xl {
        border-top-right-radius: var(--radius-2xl);
        border-bottom-right-radius: var(--radius-2xl);
    }

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

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

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

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

    .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-none {
        --tw-border-style: none;
        border-style: none;
    }

    .border-\[\#333\] {
        border-color: #333;
    }

    .border-\[\#fbbf24\] {
        border-color: #fbbf24;
    }

    .border-\[\#fbbf24\]\/0 {
        border-color: color-mix(in oklab, #fbbf24 0%, transparent);
    }

    .border-\[\#fbbf24\]\/20 {
        border-color: color-mix(in oklab, #fbbf24 20%, transparent);
    }

    .border-\[\#fbbf24\]\/30 {
        border-color: color-mix(in oklab, #fbbf24 30%, transparent);
    }

    .border-\[\#fff\] {
        border-color: #fff;
    }

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

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

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

    .border-gray-700 {
        border-color: var(--color-gray-700);
    }

    .border-gray-800 {
        border-color: var(--color-gray-800);
    }

    .border-purple-500\/30 {
        border-color: color-mix(in srgb, oklch(62.7% 0.265 303.9) 30%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            border-color: color-mix(in oklab, var(--color-purple-500) 30%, transparent);
        }
    }

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

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

    .border-white\/10 {
        border-color: color-mix(in srgb, #fff 10%, transparent);

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

    .\!bg-transparent {
        background-color: transparent !important;
    }

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

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

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

    .bg-\[\#1a1a1a\]\/95 {
        background-color: color-mix(in oklab, #1a1a1a 95%, transparent);
    }

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

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

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

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

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

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

    .bg-\[\#fbbf24\]\/10 {
        background-color: color-mix(in oklab, #fbbf24 10%, transparent);
    }

    .bg-\[\#fbbf24\]\/20 {
        background-color: color-mix(in oklab, #fbbf24 20%, transparent);
    }

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

    .bg-black\/50 {
        background-color: color-mix(in srgb, #000 50%, transparent);

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .bg-purple-500\/20 {
        background-color: color-mix(in srgb, oklch(62.7% 0.265 303.9) 20%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-purple-500) 20%, transparent);
        }
    }

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

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

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

    .bg-white\/90 {
        background-color: color-mix(in srgb, #fff 90%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-white) 90%, transparent);
        }
    }

    .bg-white\/\[0\.03\] {
        background-color: color-mix(in srgb, #fff 3%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-white) 3%, transparent);
        }
    }

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

    .bg-yellow-400\/10 {
        background-color: color-mix(in srgb, oklch(85.2% 0.199 91.936) 10%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-yellow-400) 10%, transparent);
        }
    }

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

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

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

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

    .from-\[\#2a2a2a\] {
        --tw-gradient-from: #2a2a2a;
        --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-\[\#fbbf24\] {
        --tw-gradient-from: #fbbf24;
        --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-\[\#fbbf24\]\/10 {
        --tw-gradient-from: color-mix(in oklab, #fbbf24 10%, transparent);
        --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-\[\#fbbf24\]\/20 {
        --tw-gradient-from: color-mix(in oklab, #fbbf24 20%, transparent);
        --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-black\/50 {
        --tw-gradient-from: color-mix(in srgb, #000 50%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            --tw-gradient-from: color-mix(in oklab, var(--color-black) 50%, transparent);
        }

        --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-blue-500 {
        --tw-gradient-from: var(--color-blue-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));
    }

    .from-blue-600 {
        --tw-gradient-from: var(--color-blue-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));
    }

    .from-gray-900 {
        --tw-gradient-from: var(--color-gray-900);
        --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-gray-900\/0 {
        --tw-gradient-from: color-mix(in srgb, oklch(21% 0.034 264.665) 0%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            --tw-gradient-from: color-mix(in oklab, var(--color-gray-900) 0%, transparent);
        }

        --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-green-500 {
        --tw-gradient-from: var(--color-green-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));
    }

    .from-purple-500 {
        --tw-gradient-from: var(--color-purple-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));
    }

    .from-yellow-400 {
        --tw-gradient-from: var(--color-yellow-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));
    }

    .via-\[\#F8D000\] {
        --tw-gradient-via: #F8D000;
        --tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);
        --tw-gradient-stops: var(--tw-gradient-via-stops);
    }

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

    .to-\[\#1f1f1f\] {
        --tw-gradient-to: #1f1f1f;
        --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-\[\#f59e0b\] {
        --tw-gradient-to: #f59e0b;
        --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-\[\#f59e0b\]\/10 {
        --tw-gradient-to: color-mix(in oklab, #f59e0b 10%, transparent);
        --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-\[\#f59e0b\]\/20 {
        --tw-gradient-to: color-mix(in oklab, #f59e0b 20%, transparent);
        --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-blue-600 {
        --tw-gradient-to: var(--color-blue-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-blue-800 {
        --tw-gradient-to: var(--color-blue-800);
        --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-gray-800 {
        --tw-gradient-to: var(--color-gray-800);
        --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-gray-900\/0 {
        --tw-gradient-to: color-mix(in srgb, oklch(21% 0.034 264.665) 0%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            --tw-gradient-to: color-mix(in oklab, var(--color-gray-900) 0%, transparent);
        }

        --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-green-600 {
        --tw-gradient-to: var(--color-green-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-purple-600 {
        --tw-gradient-to: var(--color-purple-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-transparent {
        --tw-gradient-to: transparent;
        --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-yellow-400 {
        --tw-gradient-to: var(--color-yellow-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));
    }

    .bg-clip-text {
        background-clip: text;
    }

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

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

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

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

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

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

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

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

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

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

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

    .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-5 {
        padding-inline: calc(var(--spacing) * 5);
    }

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

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

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

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

    .py-0\.5 {
        padding-block: calc(var(--spacing) * 0.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-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);
    }

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

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

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

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

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

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

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

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

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

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

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

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

    .pl-20 {
        padding-left: calc(var(--spacing) * 20);
    }

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

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

    .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-5xl {
        font-size: var(--text-5xl);
        line-height: var(--tw-leading, var(--text-5xl--line-height));
    }

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

    .text-7xl {
        font-size: var(--text-7xl);
        line-height: var(--tw-leading, var(--text-7xl--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-\[140px\] {
        font-size: 140px;
    }

    .leading-\[0\.7\] {
        --tw-leading: 0.7;
        line-height: 0.7;
    }

    .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-black {
        --tw-font-weight: var(--font-weight-black);
        font-weight: var(--font-weight-black);
    }

    .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-normal {
        --tw-font-weight: var(--font-weight-normal);
        font-weight: var(--font-weight-normal);
    }

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

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

    .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-wrap {
        text-wrap: wrap;
    }

    .text-\[\#1a1a1a\] {
        color: #1a1a1a;
    }

    .text-\[\#1a1a1a\]\/80 {
        color: color-mix(in oklab, #1a1a1a 80%, transparent);
    }

    .text-\[\#fbbf24\] {
        color: #fbbf24;
    }

    .text-\[\#fff\] {
        color: #fff;
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .text-transparent {
        color: transparent;
    }

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

    .text-white\/80 {
        color: color-mix(in srgb, #fff 80%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            color: color-mix(in oklab, var(--color-white) 80%, transparent);
        }
    }

    .text-white\/90 {
        color: color-mix(in srgb, #fff 90%, transparent);

        @supports (color: color-mix(in lab, red, red)) {
            color: color-mix(in oklab, var(--color-white) 90%, transparent);
        }
    }

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

    .uppercase {
        text-transform: uppercase;
    }

    .italic {
        font-style: italic;
    }

    .placeholder-gray-500 {
        &::placeholder {
            color: var(--color-gray-500);
        }
    }

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

    .opacity-0 {
        opacity: 0%;
    }

    .opacity-5 {
        opacity: 5%;
    }

    .opacity-20 {
        opacity: 20%;
    }

    .opacity-50 {
        opacity: 50%;
    }

    .opacity-70 {
        opacity: 70%;
    }

    .opacity-100 {
        opacity: 100%;
    }

    .shadow-2xl {
        --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
        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, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        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, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        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, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        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, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }

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

    .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 {
        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-\[background-color\,box-shadow\,transform\,padding\] {
        transition-property: background-color, box-shadow, transform, padding;
        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-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));
    }

    .delay-1 {
        transition-delay: 1ms;
    }

    .delay-2 {
        transition-delay: 2ms;
    }

    .delay-3 {
        transition-delay: 3ms;
    }

    .delay-4 {
        transition-delay: 4ms;
    }

    .delay-5 {
        transition-delay: 5ms;
    }

    .delay-6 {
        transition-delay: 6ms;
    }

    .duration-200 {
        --tw-duration: 200ms;
        transition-duration: 200ms;
    }

    .duration-300 {
        --tw-duration: 300ms;
        transition-duration: 300ms;
    }

    .duration-400 {
        --tw-duration: 400ms;
        transition-duration: 400ms;
    }

    .duration-500 {
        --tw-duration: 500ms;
        transition-duration: 500ms;
    }

    .duration-700 {
        --tw-duration: 700ms;
        transition-duration: 700ms;
    }

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

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

    .group-hover\:visible {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                visibility: visible;
            }
        }
    }

    .group-hover\:translate-y-0 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                --tw-translate-y: calc(var(--spacing) * 0);
                translate: var(--tw-translate-x) var(--tw-translate-y);
            }
        }
    }

    .group-hover\:scale-105 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                --tw-scale-x: 105%;
                --tw-scale-y: 105%;
                --tw-scale-z: 105%;
                scale: var(--tw-scale-x) var(--tw-scale-y);
            }
        }
    }

    .group-hover\:scale-110 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                --tw-scale-x: 110%;
                --tw-scale-y: 110%;
                --tw-scale-z: 110%;
                scale: var(--tw-scale-x) var(--tw-scale-y);
            }
        }
    }

    .group-hover\:rotate-12 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                rotate: 12deg;
            }
        }
    }

    .group-hover\:rotate-180 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                rotate: 180deg;
            }
        }
    }

    .group-hover\:border-\[\#fbbf24\]\/50 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                border-color: color-mix(in oklab, #fbbf24 50%, transparent);
            }
        }
    }

    .group-hover\:bg-\[\#fbbf24\] {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                background-color: #fbbf24;
            }
        }
    }

    .group-hover\:bg-white {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                background-color: var(--color-white);
            }
        }
    }

    .group-hover\:from-\[\#fbbf24\]\/10 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                --tw-gradient-from: color-mix(in oklab, #fbbf24 10%, transparent);
                --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));
            }
        }
    }

    .group-hover\:from-gray-900\/20 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                --tw-gradient-from: color-mix(in srgb, oklch(21% 0.034 264.665) 20%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    --tw-gradient-from: color-mix(in oklab, var(--color-gray-900) 20%, transparent);
                }

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

    .group-hover\:to-\[\#f59e0b\]\/10 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                --tw-gradient-to: color-mix(in oklab, #f59e0b 10%, transparent);
                --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));
            }
        }
    }

    .group-hover\:to-gray-800\/10 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                --tw-gradient-to: color-mix(in srgb, oklch(27.8% 0.033 256.848) 10%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    --tw-gradient-to: color-mix(in oklab, var(--color-gray-800) 10%, transparent);
                }

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

    .group-hover\:text-\[\#1a1a1a\] {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                color: #1a1a1a;
            }
        }
    }

    .group-hover\:text-\[\#fbbf24\] {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                color: #fbbf24;
            }
        }
    }

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

    .group-hover\:text-gray-300 {
        &:is(:where(.group):hover *) {
            @media (hover: hover) {
                color: var(--color-gray-300);
            }
        }
    }

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

    .group-hover\/item\:text-blue-400 {
        &:is(:where(.group\/item):hover *) {
            @media (hover: hover) {
                color: var(--color-blue-400);
            }
        }
    }

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

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

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

    .hover\:scale-105 {
        &:hover {
            @media (hover: hover) {
                --tw-scale-x: 105%;
                --tw-scale-y: 105%;
                --tw-scale-z: 105%;
                scale: var(--tw-scale-x) var(--tw-scale-y);
            }
        }
    }

    .hover\:scale-110 {
        &:hover {
            @media (hover: hover) {
                --tw-scale-x: 110%;
                --tw-scale-y: 110%;
                --tw-scale-z: 110%;
                scale: var(--tw-scale-x) var(--tw-scale-y);
            }
        }
    }

    .hover\:border-\[\#fbbf24\] {
        &:hover {
            @media (hover: hover) {
                border-color: #fbbf24;
            }
        }
    }

    .hover\:border-blue-500\/30 {
        &:hover {
            @media (hover: hover) {
                border-color: color-mix(in srgb, oklch(62.3% 0.214 259.815) 30%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    border-color: color-mix(in oklab, var(--color-blue-500) 30%, transparent);
                }
            }
        }
    }

    .hover\:border-gray-600 {
        &:hover {
            @media (hover: hover) {
                border-color: var(--color-gray-600);
            }
        }
    }

    .hover\:border-green-500\/30 {
        &:hover {
            @media (hover: hover) {
                border-color: color-mix(in srgb, oklch(72.3% 0.219 149.579) 30%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    border-color: color-mix(in oklab, var(--color-green-500) 30%, transparent);
                }
            }
        }
    }

    .hover\:border-purple-500\/30 {
        &:hover {
            @media (hover: hover) {
                border-color: color-mix(in srgb, oklch(62.7% 0.265 303.9) 30%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    border-color: color-mix(in oklab, var(--color-purple-500) 30%, transparent);
                }
            }
        }
    }

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

    .hover\:bg-\[\#2a2a2a\] {
        &:hover {
            @media (hover: hover) {
                background-color: #2a2a2a;
            }
        }
    }

    .hover\:bg-\[\#f59e0b\] {
        &:hover {
            @media (hover: hover) {
                background-color: #f59e0b;
            }
        }
    }

    .hover\:bg-\[\#fbbf24\] {
        &:hover {
            @media (hover: hover) {
                background-color: #fbbf24;
            }
        }
    }

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

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

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

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

    .hover\:bg-gray-800 {
        &:hover {
            @media (hover: hover) {
                background-color: var(--color-gray-800);
            }
        }
    }

    .hover\:bg-gray-800\/30 {
        &:hover {
            @media (hover: hover) {
                background-color: color-mix(in srgb, oklch(27.8% 0.033 256.848) 30%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    background-color: color-mix(in oklab, var(--color-gray-800) 30%, transparent);
                }
            }
        }
    }

    .hover\:bg-gray-800\/50 {
        &:hover {
            @media (hover: hover) {
                background-color: color-mix(in srgb, oklch(27.8% 0.033 256.848) 50%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    background-color: color-mix(in oklab, var(--color-gray-800) 50%, transparent);
                }
            }
        }
    }

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

    .hover\:bg-white\/10 {
        &:hover {
            @media (hover: hover) {
                background-color: color-mix(in srgb, #fff 10%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
                }
            }
        }
    }

    .hover\:bg-gradient-to-r {
        &:hover {
            @media (hover: hover) {
                --tw-gradient-position: to right in oklab;
                background-image: linear-gradient(var(--tw-gradient-stops));
            }
        }
    }

    .hover\:from-\[\#fbbf24\] {
        &:hover {
            @media (hover: hover) {
                --tw-gradient-from: #fbbf24;
                --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));
            }
        }
    }

    .hover\:to-\[\#f59e0b\] {
        &:hover {
            @media (hover: hover) {
                --tw-gradient-to: #f59e0b;
                --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));
            }
        }
    }

    .hover\:pl-6 {
        &:hover {
            @media (hover: hover) {
                padding-left: calc(var(--spacing) * 6);
            }
        }
    }

    .hover\:text-\[\#1a1a1a\] {
        &:hover {
            @media (hover: hover) {
                color: #1a1a1a;
            }
        }
    }

    .hover\:text-\[\#f59e0b\] {
        &:hover {
            @media (hover: hover) {
                color: #f59e0b;
            }
        }
    }

    .hover\:text-\[\#fbbf24\] {
        &:hover {
            @media (hover: hover) {
                color: #fbbf24;
            }
        }
    }

    .hover\:text-black {
        &:hover {
            @media (hover: hover) {
                color: var(--color-black);
            }
        }
    }

    .hover\:text-blue-400 {
        &:hover {
            @media (hover: hover) {
                color: var(--color-blue-400);
            }
        }
    }

    .hover\:text-gray-300 {
        &:hover {
            @media (hover: hover) {
                color: var(--color-gray-300);
            }
        }
    }

    .hover\:text-white {
        &:hover {
            @media (hover: hover) {
                color: var(--color-white);
            }
        }
    }

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

    .hover\:shadow-\[0_10px_30px_rgba\(251\,191\,36\,0\.3\)\] {
        &:hover {
            @media (hover: hover) {
                --tw-shadow: 0 10px 30px var(--tw-shadow-color, rgba(251, 191, 36, 0.3));
                box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
            }
        }
    }

    .hover\:shadow-\[0_20px_40px_rgba\(251\,191\,36\,0\.1\)\] {
        &:hover {
            @media (hover: hover) {
                --tw-shadow: 0 20px 40px var(--tw-shadow-color, rgba(251, 191, 36, 0.1));
                box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
            }
        }
    }

    .hover\:shadow-lg {
        &:hover {
            @media (hover: hover) {
                --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
                box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
            }
        }
    }

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

    .hover\:shadow-\[\#fbbf24\]\/30 {
        &:hover {
            @media (hover: hover) {
                --tw-shadow-color: color-mix(in srgb, #fbbf24 30%, transparent);

                @supports (color: color-mix(in lab, red, red)) {
                    --tw-shadow-color: color-mix(in oklab, color-mix(in oklab, #fbbf24 30%, transparent) var(--tw-shadow-alpha), transparent);
                }
            }
        }
    }

    .focus\:border-\[\#fbbf24\] {
        &:focus {
            border-color: #fbbf24;
        }
    }

    .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-\[\#1a1a1a\] {
        &:focus {
            --tw-ring-color: #1a1a1a;
        }
    }

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

    .sm\:mb-4 {
        @media (width >=40rem) {
            margin-bottom: calc(var(--spacing) * 4);
        }
    }

    .sm\:mb-6 {
        @media (width >=40rem) {
            margin-bottom: calc(var(--spacing) * 6);
        }
    }

    .sm\:mb-8 {
        @media (width >=40rem) {
            margin-bottom: calc(var(--spacing) * 8);
        }
    }

    .sm\:mb-10 {
        @media (width >=40rem) {
            margin-bottom: calc(var(--spacing) * 10);
        }
    }

    .sm\:mb-16 {
        @media (width >=40rem) {
            margin-bottom: calc(var(--spacing) * 16);
        }
    }

    .sm\:block {
        @media (width >=40rem) {
            display: block;
        }
    }

    .sm\:h-7 {
        @media (width >=40rem) {
            height: calc(var(--spacing) * 7);
        }
    }

    .sm\:h-16 {
        @media (width >=40rem) {
            height: calc(var(--spacing) * 16);
        }
    }

    .sm\:h-24 {
        @media (width >=40rem) {
            height: calc(var(--spacing) * 24);
        }
    }

    .sm\:h-56 {
        @media (width >=40rem) {
            height: calc(var(--spacing) * 56);
        }
    }

    .sm\:h-80 {
        @media (width >=40rem) {
            height: calc(var(--spacing) * 80);
        }
    }

    .sm\:h-\[400px\] {
        @media (width >=40rem) {
            height: 400px;
        }
    }

    .sm\:min-h-\[300px\] {
        @media (width >=40rem) {
            min-height: 300px;
        }
    }

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

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

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

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

    .sm\:min-w-\[50px\] {
        @media (width >=40rem) {
            min-width: 50px;
        }
    }

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

    .sm\:items-center {
        @media (width >=40rem) {
            align-items: center;
        }
    }

    .sm\:gap-6 {
        @media (width >=40rem) {
            gap: calc(var(--spacing) * 6);
        }
    }

    .sm\:gap-8 {
        @media (width >=40rem) {
            gap: calc(var(--spacing) * 8);
        }
    }

    .sm\:space-y-8 {
        @media (width >=40rem) {
            :where(& > :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)));
            }
        }
    }

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

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

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

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

    .sm\:py-4 {
        @media (width >=40rem) {
            padding-block: calc(var(--spacing) * 4);
        }
    }

    .sm\:py-20 {
        @media (width >=40rem) {
            padding-block: calc(var(--spacing) * 20);
        }
    }

    .sm\:text-2xl {
        @media (width >=40rem) {
            font-size: var(--text-2xl);
            line-height: var(--tw-leading, var(--text-2xl--line-height));
        }
    }

    .sm\:text-3xl {
        @media (width >=40rem) {
            font-size: var(--text-3xl);
            line-height: var(--tw-leading, var(--text-3xl--line-height));
        }
    }

    .sm\:text-4xl {
        @media (width >=40rem) {
            font-size: var(--text-4xl);
            line-height: var(--tw-leading, var(--text-4xl--line-height));
        }
    }

    .sm\:text-5xl {
        @media (width >=40rem) {
            font-size: var(--text-5xl);
            line-height: var(--tw-leading, var(--text-5xl--line-height));
        }
    }

    .sm\:text-base {
        @media (width >=40rem) {
            font-size: var(--text-base);
            line-height: var(--tw-leading, var(--text-base--line-height));
        }
    }

    .sm\:text-lg {
        @media (width >=40rem) {
            font-size: var(--text-lg);
            line-height: var(--tw-leading, var(--text-lg--line-height));
        }
    }

    .sm\:text-sm {
        @media (width >=40rem) {
            font-size: var(--text-sm);
            line-height: var(--tw-leading, var(--text-sm--line-height));
        }
    }

    .sm\:text-xl {
        @media (width >=40rem) {
            font-size: var(--text-xl);
            line-height: var(--tw-leading, var(--text-xl--line-height));
        }
    }

    .sm\:hover\:pl-8 {
        @media (width >=40rem) {
            &:hover {
                @media (hover: hover) {
                    padding-left: calc(var(--spacing) * 8);
                }
            }
        }
    }

    .md\:top-8 {
        @media (width >=48rem) {
            top: calc(var(--spacing) * 8);
        }
    }

    .md\:right-8 {
        @media (width >=48rem) {
            right: calc(var(--spacing) * 8);
        }
    }

    .md\:order-1 {
        @media (width >=48rem) {
            order: 1;
        }
    }

    .md\:order-2 {
        @media (width >=48rem) {
            order: 2;
        }
    }

    .md\:my-8 {
        @media (width >=48rem) {
            margin-block: calc(var(--spacing) * 8);
        }
    }

    .md\:mt-8 {
        @media (width >=48rem) {
            margin-top: calc(var(--spacing) * 8);
        }
    }

    .md\:mt-12 {
        @media (width >=48rem) {
            margin-top: calc(var(--spacing) * 12);
        }
    }

    .md\:mb-2 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 2);
        }
    }

    .md\:mb-3 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 3);
        }
    }

    .md\:mb-6 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 6);
        }
    }

    .md\:mb-8 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 8);
        }
    }

    .md\:mb-16 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 16);
        }
    }

    .md\:mb-32 {
        @media (width >=48rem) {
            margin-bottom: calc(var(--spacing) * 32);
        }
    }

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

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

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

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

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

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

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

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

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

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

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

    .md\:h-full {
        @media (width >=48rem) {
            height: 100%;
        }
    }

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

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

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

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

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

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

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

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

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

    .md\:grid-cols-\[30\%_70\%\] {
        @media (width >=48rem) {
            grid-template-columns: 30% 70%;
        }
    }

    .md\:grid-cols-\[40\%_60\%\] {
        @media (width >=48rem) {
            grid-template-columns: 40% 60%;
        }
    }

    .md\:grid-cols-\[45\%_55\%\] {
        @media (width >=48rem) {
            grid-template-columns: 45% 55%;
        }
    }

    .md\:grid-cols-\[60\%_40\%\] {
        @media (width >=48rem) {
            grid-template-columns: 60% 40%;
        }
    }

    .md\:justify-start {
        @media (width >=48rem) {
            justify-content: flex-start;
        }
    }

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

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

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

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

    .md\:space-y-8 {
        @media (width >=48rem) {
            :where(& > :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)));
            }
        }
    }

    .md\:rounded-3xl {
        @media (width >=48rem) {
            border-radius: var(--radius-3xl);
        }
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .lg\:sticky {
        @media (width >=64rem) {
            position: sticky;
        }
    }

    .lg\:top-8 {
        @media (width >=64rem) {
            top: calc(var(--spacing) * 8);
        }
    }

    .lg\:order-1 {
        @media (width >=64rem) {
            order: 1;
        }
    }

    .lg\:order-2 {
        @media (width >=64rem) {
            order: 2;
        }
    }

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

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

    .lg\:mt-0 {
        @media (width >=64rem) {
            margin-top: calc(var(--spacing) * 0);
        }
    }

    .lg\:mb-12 {
        @media (width >=64rem) {
            margin-bottom: calc(var(--spacing) * 12);
        }
    }

    .lg\:mb-20 {
        @media (width >=64rem) {
            margin-bottom: calc(var(--spacing) * 20);
        }
    }

    .lg\:\!flex {
        @media (width >=64rem) {
            display: flex !important;
        }
    }

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

    .lg\:flex {
        @media (width >=64rem) {
            display: flex;
        }
    }

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

    .lg\:inline-flex {
        @media (width >=64rem) {
            display: inline-flex;
        }
    }

    .lg\:h-18 {
        @media (width >=64rem) {
            height: calc(var(--spacing) * 18);
        }
    }

    .lg\:h-24 {
        @media (width >=64rem) {
            height: calc(var(--spacing) * 24);
        }
    }

    .lg\:h-32 {
        @media (width >=64rem) {
            height: calc(var(--spacing) * 32);
        }
    }

    .lg\:h-\[120vh\] {
        @media (width >=64rem) {
            height: 120vh;
        }
    }

    .lg\:h-\[500px\] {
        @media (width >=64rem) {
            height: 500px;
        }
    }

    .lg\:h-full {
        @media (width >=64rem) {
            height: 100%;
        }
    }

    .lg\:h-screen {
        @media (width >=64rem) {
            height: 100vh;
        }
    }

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

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

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

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

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

    .lg\:grid-cols-\[1fr_350px\] {
        @media (width >=64rem) {
            grid-template-columns: 1fr 350px;
        }
    }

    .lg\:grid-cols-\[55\%_45\%\] {
        @media (width >=64rem) {
            grid-template-columns: 55% 45%;
        }
    }

    .lg\:\!justify-start {
        @media (width >=64rem) {
            justify-content: flex-start !important;
        }
    }

    .lg\:justify-end {
        @media (width >=64rem) {
            justify-content: flex-end;
        }
    }

    .lg\:justify-start {
        @media (width >=64rem) {
            justify-content: flex-start;
        }
    }

    .lg\:gap-10 {
        @media (width >=64rem) {
            gap: calc(var(--spacing) * 10);
        }
    }

    .lg\:gap-12 {
        @media (width >=64rem) {
            gap: calc(var(--spacing) * 12);
        }
    }

    .lg\:gap-16 {
        @media (width >=64rem) {
            gap: calc(var(--spacing) * 16);
        }
    }

    .lg\:gap-20 {
        @media (width >=64rem) {
            gap: calc(var(--spacing) * 20);
        }
    }

    .lg\:p-10 {
        @media (width >=64rem) {
            padding: calc(var(--spacing) * 10);
        }
    }

    .lg\:p-12 {
        @media (width >=64rem) {
            padding: calc(var(--spacing) * 12);
        }
    }

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

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

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

    .lg\:pr-12 {
        @media (width >=64rem) {
            padding-right: calc(var(--spacing) * 12);
        }
    }

    .lg\:pl-12 {
        @media (width >=64rem) {
            padding-left: calc(var(--spacing) * 12);
        }
    }

    .lg\:text-right {
        @media (width >=64rem) {
            text-align: right;
        }
    }

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

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

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

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

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

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

@font-face {
    font-family: 'HelveticaCustom';
    src: url('asset/font/Helvetica.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'HelveticaCustom';
    src: url('asset/font/helvetica-light-587ebe5a59211.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'HelveticaCustom';
    src: url('asset/font/Helvetica-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'HelveticaCustom';
    src: url('asset/font/Helvetica-Oblique.ttf') format('truetype');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

body {
    font-family: 'HelveticaCustom', Arial, sans-serif;
    overflow-x: hidden;
}

.text-stroke-white {
    -webkit-text-stroke: 1px #fff;
    color: transparent;
}

.mobile-wrapper {
    overflow: hidden;
}

.stroke-text,
.solid-text {
    will-change: transform;
    white-space: nowrap;
}

.cta-wrapper {
    height: 100vh;
    background-image: url('https://assets-global.website-files.com/657aefdc8951c28c0b283b37/6580056a6374fb07dc02e099_Image.png');
    background-repeat: no-repeat;
    background-size: cover;
}

#sallaghaHeader {
    background: rgba(26, 26, 26, 0.75);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

#sallaghaHeader.not_active {
    backdrop-filter: blur(25px);
}

.nav-link {
    position: relative;
}

.nav-link::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 0;
    height: 2px;
    background: white;
    transition: width 0.3s ease;
}

.nav-link:hover::after {
    width: 100%;
}

.group:hover>div {
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

#mobileMenu {
    transition: opacity 0.3s ease;
}

#mobileMenuPanel {
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.5);
}

.mobile-dropdown-content {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transform: translateY(-5px);
    transition: all 0.45s ease;
}

.mobile-dropdown-content.open {
    max-height: 500px;
    opacity: 1;
    transform: translateY(0);
}

#mobileMenuBtn.active .line1 {
    transform: rotate(45deg) translate(5px, 5px);
}

#mobileMenuBtn.active .line2 {
    opacity: 0;
}

#mobileMenuBtn.active .line3 {
    transform: rotate(-45deg) translate(6px, -6px);
}

.vertical-text {
    color: #fff;
    letter-spacing: 1.5px !important;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    transform: rotate(180deg);
}

.vertical-text h1 {
    letter-spacing: 1.5px !important;
}

.menu-item {
    font-size: 42px;
    font-weight: 700;
    -webkit-text-stroke: 1.5px #ffffff33;
    color: transparent;
    letter-spacing: 2px;
    cursor: pointer;
    transition: 0.3s ease;
}

.menu-item:hover {
    color: #fff;
}

body,
.menu-item {
    font-family: 'HelveticaCustom', Arial, sans-serif;
}

.left_side_content {
    position: absolute;
    top: 0;
    width: 320px;
    justify-content: center;
    display: flex;
    flex-direction: column;
    left: 50%;
    transform: translate(-50%);
}

.cyber-text {
    -webkit-text-stroke: 1.5px #f8f8f833;
    color: transparent;
    font-weight: 700;
    letter-spacing: -0.02em;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    transform: rotate(180deg);
    font-size: 140px;
    position: absolute;
    z-index: 999;
    right: -45px;
    bottom: -30%;
    will-change: transform;
}

.client_card {
    margin-top: 70px;
}

.bottom {
    height: 100vh;
    background: linear-gradient(180deg, #1a1a1a 0%, #0a0a0a 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero_section {
    height: 100vh;
    position: relative;
}

#defenceText {
    position: relative;
    will-change: transform;
    font-weight: 700;
}

html {
    scroll-behavior: smooth;
}

.right-side-bg {
    background-image: url('https://showcaseonline.xyz/sallagha-inc/3/asset/images/657e8458b6545ac9af50e4d0_businessman-having-presentation-with-colleagues-about-project-he-working-office-(1)-1.png');
    background-size: cover;
    background-position: center;
}

.right-side-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
}

.scroll-indicator {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
    opacity: 0;
    transition: opacity 0.3s;
}

.scroll-indicator.show {
    opacity: 1;
}

.scroll-indicator.hide {
    opacity: 0;
}

#cyberText,
#defenceText {
    transition: all 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

div#defenceContainer {
    position: absolute;
    left: 0;
    z-index: 99;
    top: 50%;
    font-size: 140px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    will-change: transform;
}

.right_arrow {
    transform: rotate(320deg);
    z-index: -1;
}

.out_line {
    outline: 11px solid #1a1a1a;
    border-radius: 50%;
}

.verticle-contact-info {
    position: absolute;
    left: 4%;
    bottom: 60px;
}

.vertical-text-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.vertical-text {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    transform: rotate(180deg);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.vertical-text .call-us {
    font-weight: 400;
    font-size: 14px;
    line-height: 14px;
    letter-spacing: 0.15em;
    color: #ffffff80;
}

.vertical-text .number {
    font-size: 20px;
    font-weight: 500;
    color: #fff;
    line-height: 20px;
    letter-spacing: 0.02em;
}

.phone-circle {
    width: 56px;
    height: 56px;
    background-color: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.3s ease;
}

.phone-circle:hover {
    transform: scale(1.05);
}

.phone-circle svg {
    color: #1a1a1a;
}

.services-section {
    position: relative;
    min-height: 100vh;
    padding: 80px 5%;
    background-color: #212125;
    overflow: hidden;
}

.bg-pattern {
    position: absolute;
    right: 0;
    top: 0;
    width: auto;
    height: auto;
    pointer-events: none;
}

.container {
    max-width: 1400px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.section-header {
    margin-bottom: 80px;
}

.section-label {
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.15em;
    color: #ffffff;
    margin-bottom: 20px;
    text-transform: uppercase;
}

.section-title {
    font-size: 56px;
    font-weight: 700;
    line-height: 1.2;
    color: #ffffff;
    margin-bottom: 30px;
    max-width: 700px;
}

.all-services-btn {
    display: inline-block;
    padding: 14px 32px;
    background-color: transparent;
    color: #ffffff;
    border: 1.5px solid rgba(255, 255, 255, 0.3);
    border-radius: 50px;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
}

.service-card {
    padding: 50px 40px;
    position: relative;
    transition: transform 0.8s ease;
    cursor: pointer;
    border-left: 1px dashed #837f7f;
    margin: 20px;
}

.service-card:hover {
    transform: scale(0.95);
}

.service-number {
    font-size: 14px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 25px;
    letter-spacing: 0.05em;
}

.service-title {
    font-size: 28px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 20px;
    line-height: 1.3;
}

.service-title:hover {
    text-decoration: underline;
}

.service-description {
    font-size: 15px;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 40px;
}

.service-icon {
    width: 60px;
    height: 60px;
    object-fit: contain;
    filter: brightness(0) invert(1);
    opacity: 0.9;
}

@media (max-width: 1200px) {
    .section-title {
        font-size: 48px;
    }

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

@media (max-width: 768px) {
    .services-section {
        padding: 60px 5%;
    }

    .section-title {
        font-size: 36px;
    }

    .services-grid {
        grid-template-columns: 1fr;
    }

    .service-card {
        padding: 40px 30px;
    }

    .bg-pattern {
        width: 70%;
    }
}

.partner-section {
    min-height: 100vh;
    padding: 100px 0;
    position: relative;
    overflow: hidden;
    background-color: #2a2a2a;
}

.partner-grid {
    display: grid;
    grid-template-columns: 50% 50%;
    max-width: 100%;
    margin: 0 auto;
    height: 100vh;
}

.content-left {
    position: relative;
    padding-left: 5%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding-top: 100px;
    padding-bottom: 100px;
}

.content_box {
    position: relative;
    max-width: 550px;
    margin-left: auto;
    padding-right: 60px;
    z-index: 10;
}

.decorative-line {
    width: 60px;
    height: 2px;
    background-color: rgba(255, 255, 255, 0.4);
    margin-bottom: 30px;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.main-title {
    font-size: 56px;
    font-weight: 700;
    color: #ffffff;
    line-height: 1.1;
    margin-bottom: 40px;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.1s;
}

.description-box {
    margin-bottom: 40px;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.2s;
}

.description-title {
    font-size: 24px;
    font-weight: 500;
    color: #ffffff;
    line-height: 1.4;
    margin-bottom: 20px;
}

.description-text {
    font-size: 15px;
    line-height: 1.8;
    color: rgba(255, 255, 255, 0.6);
}

.read-more-btn {
    display: inline-block;
    padding: 16px 38px;
    background-color: transparent;
    color: #ffffff;
    border: 2px solid rgba(255, 255, 255, 0.4);
    border-radius: 50px;
    font-size: 16px;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.3s;
}

.read-more-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.7);
    transform: translateY(-2px);
}

.images-grid-bottom {
    position: relative;
    height: 300px;
    margin-left: 5%;
}

.image-wrapper {
    position: absolute;
    overflow: hidden;
    border-radius: 8px;
    opacity: 0;
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.image-wrapper:hover img {
    transform: scale(1.05);
}

.bottom-image-1 {
    bottom: 0;
    left: 0;
    width: 260px;
    height: 300px;
    z-index: 3;
    transform: translateX(-100px);
    transition-delay: 0.4s;
}

.bottom-image-2 {
    bottom: 40px;
    left: 280px;
    width: 200px;
    height: 160px;
    z-index: 2;
    transform: translateX(-100px);
    transition-delay: 0.6s;
}

.right_side {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.right-image {
    position: relative;
    width: 100%;
    height: 100%;
    max-width: 680px;
    max-height: 700px;
    border-radius: 0;
    opacity: 0;
    transform: translateY(50px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.2s;
}

.right-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.partner-section.active .decorative-line,
.partner-section.active .main-title,
.partner-section.active .description-box,
.partner-section.active .read-more-btn {
    opacity: 1;
    transform: translateY(0);
}

.partner-section.active .bottom-image-1,
.partner-section.active .bottom-image-2 {
    opacity: 1;
    transform: translateX(0);
}

.partner-section.active .right-image {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 1200px) {
    .partner-grid {
        grid-template-columns: 1fr;
        height: auto;
    }

    .content_box {
        margin-left: 0;
        max-width: 100%;
        padding-right: 20px;
    }

    .main-title {
        font-size: 48px;
    }

    .right_side {
        height: 500px;
        margin-top: 60px;
    }

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

@media (max-width: 768px) {
    .partner-section {
        padding: 60px 0;
    }

    .main-title {
        font-size: 36px;
    }

    .description-title {
        font-size: 20px;
    }

    .images-grid-bottom {
        height: 280px;
    }

    .bottom-image-1 {
        width: 200px;
        height: 240px;
    }

    .bottom-image-2 {
        width: 160px;
        height: 130px;
        left: 220px;
    }
}

.counter-section {
    background-color: #2a2a2a;
    padding: 100px 5%;
    overflow: hidden;
}

.counter-container {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 60px;
}

.counter-item {
    text-align: center;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.counter-item:nth-child(1) {
    transition-delay: 0.1s;
}

.counter-item:nth-child(2) {
    transition-delay: 0.2s;
}

.counter-item:nth-child(3) {
    transition-delay: 0.3s;
}

.counter-item:nth-child(4) {
    transition-delay: 0.4s;
}

.counter-section.active .counter-item {
    opacity: 1;
    transform: translateY(0);
}

.counter-number {
    font-size: 180px;
    font-weight: 700;
    color: #ffffff;
    line-height: 1;
    margin-bottom: 20px;
    letter-spacing: -0.02em;
}

.counter-label {
    font-size: 18px;
    font-weight: 500;
    color: #ffffff;
    line-height: 1.4;
    margin: 0;
}

@media (max-width: 1200px) {
    .counter-container {
        grid-template-columns: repeat(2, 1fr);
        gap: 50px;
    }

    .counter-number {
        font-size: 100px;
    }
}

@media (max-width: 768px) {
    .counter-section {
        padding: 60px 5%;
    }

    .counter-container {
        gap: 40px;
    }

    .cta-wrapper {
        height: 50vh;
    }

    .counter-number {
        font-size: 80px;
    }

    .counter-label {
        font-size: 16px;
    }
}

.projects-slider-section {
    min-height: 300vh;
    background-color: #2b2b2b;
    position: relative;
}

.slider-container {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.slides-wrapper {
    position: relative;
    width: 100%;
    height: 100vh;
}

.project-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    opacity: 0;
    transform: translateY(100%) scale(0.95);
    pointer-events: none;
    transition: opacity 1s ease, transform 1s cubic-bezier(0.4, 0, 0.2, 1);
}

.project-slide.active {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
    z-index: 10;
}

.project-slide.passed {
    opacity: 0;
    transform: translateY(-100%) scale(0.95);
    pointer-events: none;
    z-index: 1;
}

.slide-content {
    display: grid;
    grid-template-columns: 48% 52%;
    gap: 80px;
    align-items: center;
    padding: 0 8%;
    position: relative;
    margin-top: 150px !important;
}

.slide-number {
    font-size: 217px;
    font-weight: 700;
    color: rgba(60, 60, 60, 0.4);
    margin: auto;
    background: #262629;
    padding: 25px;
    height: 505px !important;
    text-align: center;
    line-height: 500px;
}

.project-slide.active .slide-number {
    animation: slideNumberIn 1s ease forwards;
}

@keyframes slideNumberIn {
    from {
        opacity: 0;
        transform: translateY(-50%) translateX(-50px);
    }

    to {
        opacity: 1;
        transform: translateY(-50%) translateX(0);
    }
}

.slide-image {
    max-width: 500px;
    position: relative;
    width: 100%;
    z-index: 1;
    overflow: hidden;
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    right: 50px;
}

.project-slide.active .slide-image {
    animation: slideImageIn 1s ease 0.2s both;
}

@keyframes slideImageIn {
    from {
        opacity: 0;
        transform: translateY(50px) scale(0.9);
    }

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

.slide-image img {
    width: 100%;
    height: auto;
    display: block;
}

.play-button {
    position: absolute;
    bottom: 40px;
    right: 40px;
    cursor: pointer;
    transition: transform 0.3s ease;
    z-index: 10;
}

.play-button:hover {
    transform: scale(1.15);
}

.slide-info {
    color: white;
    z-index: 1;
    position: relative;
}

.project-slide.active .slide-info>* {
    animation: slideInfoIn 0.8s ease forwards;
    opacity: 0;
}

.project-slide.active .slide-title {
    animation-delay: 0.3s;
}

.project-slide.active .divider-line {
    animation-delay: 0.4s;
}

.project-slide.active .info-heading {
    animation-delay: 0.5s;
}

.project-slide.active .info-details {
    animation-delay: 0.6s;
}

.project-slide.active .project-read-more-btn {
    animation-delay: 0.7s;
}

@keyframes slideInfoIn {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

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

.slide-title {
    font-size: 80px;
    font-weight: 700;
    line-height: 80px;
    margin-bottom: 50px;
    color: #ffffff;
    letter-spacing: -0.02em;
}

.divider-line {
    width: 60px;
    height: 2px;
    background-color: rgba(255, 255, 255, 0.3);
    margin-bottom: 35px;
}

.info-heading {
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 25px;
    color: #ffffff;
}

.info-details {
    margin-bottom: 45px;
}

.info-details p {
    font-size: 17px;
    line-height: 2;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 5px;
}

.project-read-more-btn {
    display: inline-block;
    padding: 18px 45px;
    background-color: transparent;
    color: #ffffff;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 50px;
    font-size: 17px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.3s ease;
}

.project-read-more-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.6);
    transform: translateY(-2px);
}

.scroll-progress {
    position: fixed;
    right: 40px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 100;
    display: flex;
    flex-direction: column;
    gap: 15px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.scroll-progress.visible {
    opacity: 1;
    pointer-events: auto;
}

.progress-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    transition: all 0.3s ease;
    cursor: pointer;
}

.progress-dot.active {
    background: #ffffff;
    transform: scale(1.5);
}

@media (max-width: 1400px) {
    .slide-number {
        font-size: 250px;
    }

    .slide-title {
        font-size: 52px;
    }
}

@media (max-width: 1200px) {
    .slide-content {
        gap: 50px;
        padding: 80px 5%;
    }

    .slide-number {
        font-size: 180px;
        top: 10%;
        left: 3%;
    }

    .slide-title {
        font-size: 44px;
        line-height: 50px;
        margin-bottom: 15px;
    }

    .divider-line {
        margin-bottom: 20px;
    }

    .slide-image {
        right: 10px;
    }
}

@media (max-width: 768px) {
    .projects-slider-section {
        min-height: 400vh;
    }

    .slide-title {
        font-size: 36px;
    }

    .slide-number {
        font-size: 120px;
    }

    .info-heading {
        font-size: 22px;
    }

    .slide-content {
        padding: 60px 5%;
        gap: 20px;
    }

    .scroll-progress {
        right: 20px;
    }

    .info-heading {
        margin-bottom: 10px;
    }

    .scroll-progress {
        display: none;
    }
}

.slide-image::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    bottom: 0;
    right: 0;
    background-image: url('https://assets-global.website-files.com/657aefdc8951c28c0b283b37/658d2ff344471300d954bc5c_Vector.svg');
    background-repeat: no-repeat;
    background-position: bottom right;
}

.testimonial-section {
    min-height: 100vh;
    background: linear-gradient(135deg, #2d2d30 0%, #35353a 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 80px 20px;
    position: relative;
    overflow: hidden;
}

.testimonial-section::before {
    content: '';
    position: absolute;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(74, 158, 255, 0.1) 0%, transparent 70%);
    top: -200px;
    left: -200px;
    border-radius: 50%;
}

.testimonial-section::after {
    content: '';
    position: absolute;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(107, 95, 255, 0.1) 0%, transparent 70%);
    bottom: -150px;
    right: -150px;
    border-radius: 50%;
}

.testimonial-container {
    max-width: 1200px;
    width: 100%;
    text-align: center;
    position: relative;
    z-index: 1;
}

.quote-icon {
    font-size: 120px;
    line-height: 1;
    color: rgba(255, 255, 255, 0.08);
    margin-bottom: 30px;
    font-family: Georgia, serif;
    animation: fadeInDown 1s ease;
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-30px);
    }

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

.testimonial-text {
    font-size: 32px;
    line-height: 1.6;
    color: #ffffff;
    font-weight: 400;
    margin-bottom: 50px;
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    animation: fadeInUp 1s ease 0.2s backwards;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

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

.closing-quote {
    font-family: Georgia, serif;
    color: rgba(255, 255, 255, 0.3);
    margin-left: 8px;
}

.author-section {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    animation: fadeInUp 1s ease 0.4s backwards;
}

.author-image {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    overflow: hidden;
    border: 3px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.author-image:hover {
    transform: scale(1.05);
    box-shadow: 0 15px 40px rgba(74, 158, 255, 0.3);
}

.author-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

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

.author-name {
    font-size: 24px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 5px;
    letter-spacing: -0.02em;
}

.author-title {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.6);
    font-weight: 400;
    letter-spacing: 0.5px;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@media (max-width: 1024px) {
    .testimonial-text {
        font-size: 28px;
    }

    .quote-icon {
        font-size: 100px;
    }
}

@media (max-width: 768px) {
    .testimonial-section {
        padding: 60px 20px;
    }

    .testimonial-text {
        font-size: 22px;
        line-height: 1.5;
    }

    .quote-icon {
        font-size: 80px;
        margin-bottom: 20px;
    }

    .author-section {
        flex-direction: column;
        gap: 15px;
    }

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

    .author-name {
        font-size: 20px;
    }

    .author-title {
        font-size: 14px;
    }

    .author-image {
        width: 70px;
        height: 70px;
    }
}

@media (max-width: 480px) {
    .testimonial-text {
        font-size: 18px;
    }

    .author-name {
        font-size: 18px;
    }
}

.team-section {
    min-height: 100vh;
    background-color: #1c1d20;
    padding: 100px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.team-container {
    max-width: 1400px;
    width: 100%;
    margin: 0 auto;
}

.team-header {
    text-align: center;
    margin-bottom: 80px;
    animation: fadeInUp 0.8s ease;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

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

.team-label {
    font-size: 14px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.6);
    letter-spacing: 3px;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.team-title {
    font-size: 56px;
    font-weight: 700;
    line-height: 1.2;
    color: #ffffff;
    margin-bottom: 40px;
    letter-spacing: -0.02em;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

.join-team-btn {
    display: inline-block;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.team-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
}

.team-member {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    cursor: pointer;
    animation: fadeInUp 0.8s ease backwards;
}

.team-member:nth-child(1) {
    animation-delay: 0.2s;
}

.team-member:nth-child(2) {
    animation-delay: 0.3s;
}

.team-member:nth-child(3) {
    animation-delay: 0.4s;
}

.member-image {
    width: 100%;
    height: 450px;
    overflow: hidden;
    position: relative;
}

.member-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.team-member:hover .member-image img {
    transform: scale(1.08);
}

.member-image::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 60%;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, transparent 100%);
    transition: opacity 0.4s ease;
}

.team-member:hover .member-image::after {
    opacity: 0.9;
}

.member-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 30px;
    z-index: 2;
    transform: translateY(0);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.member-name {
    font-size: 24px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 8px;
    letter-spacing: -0.02em;
}

.member-role {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 400;
    margin-bottom: 15px;
}

.social-links {
    display: flex;
    gap: 15px;
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.team-member:hover .social-links {
    opacity: 1;
    transform: translateY(0);
}

.social-link {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    text-decoration: none;
    transition: all 0.7s ease;
    backdrop-filter: blur(10px);
}

.social-link:hover {
    background: #fbbf24;
    color: #000;
}

.social-link svg {
    width: 16px;
    height: 16px;
    fill: currentColor;
}

@media (max-width: 1024px) {
    .team-title {
        font-size: 48px;
    }

    .team-grid {
        gap: 30px;
    }

    .member-image {
        height: 400px;
    }
}

@media (max-width: 768px) {
    .team-section {
        padding: 60px 20px;
    }

    .team-header {
        margin-bottom: 50px;
    }

    .team-title {
        font-size: 36px;
    }

    .team-grid {
        grid-template-columns: 1fr;
        gap: 30px;
        max-width: 500px;
    }

    .member-image {
        height: 500px;
    }

    .social-links {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 480px) {
    .team-title {
        font-size: 28px;
    }

    .member-image {
        height: 450px;
    }

    .member-name {
        font-size: 20px;
    }

    .member-role {
        font-size: 14px;
    }

    .slide-title {
        font-size: 22px;
        line-height: 25px;
    }

    .divider-line {
        margin-bottom: 10px;
    }

    .info-details {
        margin-bottom: 10px;
    }

    .info-details p {
        font-size: 12px;
        color: rgba(255, 255, 255, 0.6);
        margin-bottom: 3px;
        line-height: 20px;
    }

    .project-read-more-btn {
        padding: 8px 20px;
        border: 1px solid rgba(255, 255, 255, 0.3);
        font-size: 14px;
    }
}

.cta {
    padding-top: 100px;
    background-color: #1c1d20;
}

.shape_img {
    position: absolute;
    left: 50%;
    transform: translate(-50%, -1%);
}

.circlr-img {
    position: absolute;
    left: 50%;
    top: 15%;
    transform: translate(-50%, -50%);
}

.rotate_img {
    animation: rotate-animation 10s infinite linear;
}

img.arrow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@keyframes rotate-animation {
    0% {
        transform: rotate(0deg);
    }

    50% {
        transform: rotate(180deg);
    }
}

.member-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 30px;
    z-index: 2;
    transform: translateY(0);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.member-name {
    font-size: 24px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 8px;
    letter-spacing: -0.02em;
}

.member-role {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 400;
    margin-bottom: 15px;
}

.social-links {
    display: flex;
    gap: 15px;
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.team-member:hover .social-links {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 1024px) {
    .team-title {
        font-size: 48px;
    }

    .team-grid {
        gap: 30px;
    }

    .member-image {
        height: 400px;
    }

    .slide-number {
        display: none;
    }
}

@media (max-width: 768px) {
    .team-section {
        padding: 60px 20px;
    }

    .team-header {
        margin-bottom: 50px;
    }

    .team-title {
        font-size: 36px;
    }

    .team-grid {
        grid-template-columns: 1fr;
        gap: 30px;
        max-width: 500px;
    }

    .member-image {
        height: 500px;
    }

    .social-links {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 480px) {
    .team-title {
        font-size: 28px;
    }

    .member-image {
        height: 450px;
    }

    .member-name {
        font-size: 20px;
    }

    .member-role {
        font-size: 14px;
    }
}

.cta {
    padding-top: 100px;
    background-color: #1c1d20;
}

.shape_img {
    position: absolute;
    left: 50%;
    transform: translate(-50%, -1%);
}

.circlr-img {
    position: absolute;
    left: 50%;
    top: 15%;
    transform: translate(-50%, -50%);
}

.rotate_img {
    animation: rotate-animation 10s infinite linear;
}

img.arrow {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@keyframes rotate-animation {
    0% {
        transform: rotate(0deg);
    }

    50% {
        transform: rotate(180deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.footer_img {
    position: absolute;
    bottom: 68px;
    right: 0;
}

.footer_img img {
    width: 100%;
}

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

@keyframes rotate {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

.rotate-infinite {
    animation: rotate 10s linear infinite;
}

.ghost-image {
    opacity: 0;
    transform: translateY(100px);
    transition: all 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.ghost-image.visible {
    opacity: 1;
    transform: translateY(0);
}

.ghost-image:nth-child(1) {
    transition-delay: 0.2s;
}

.ghost-image:nth-child(2) {
    transition-delay: 0.4s;
}

.ghost-image:nth-child(3) {
    transition-delay: 0.6s;
}

.hero-content {
    opacity: 0;
    transform: translateY(30px);
    animation: fadeInUp 1s ease forwards;
}

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

.image-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    position: relative;
}

@media (max-width: 640px) {
    .image-grid {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }
}

.image-container {
    position: relative;
    overflow: hidden;
    border-radius: 1rem;
}

.image-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.image-container:hover img {
    transform: scale(1.05);
}

.large-image {
    grid-row: span 2;
}

@media (max-width: 640px) {
    .large-image {
        grid-row: span 1;
    }
}

.circle-container {
    position: absolute;
    top: 65%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
}

@media (max-width: 640px) {
    .circle-container {
        top: 40%;
    }
}

.co-fade-in-up {
    opacity: 0;
    transform: translateY(50px);
    transition: all 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.co-fade-in-up.visible {
    opacity: 1;
    transform: translateY(0);
}

.co-fade-in-left {
    opacity: 0;
    transform: translateX(-50px);
    transition: all 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.co-fade-in-left.visible {
    opacity: 1;
    transform: translateX(0);
}

.co-fade-in-right {
    opacity: 0;
    transform: translateX(50px);
    transition: all 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.co-fade-in-right.visible {
    opacity: 1;
    transform: translateX(0);
}

.co-delay-1 {
    transition-delay: 0.1s;
}

.co-delay-2 {
    transition-delay: 0.2s;
}

.co-delay-3 {
    transition-delay: 0.3s;
}

.co-delay-4 {
    transition-delay: 0.4s;
}

.co-section-label {
    font-size: 0.75rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: #9ca3af;
    font-weight: 400;
}

.co-section-title {
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1.2;
    color: #fff;
}

@media (max-width: 768px) {
    .co-section-title {
        font-size: 2.5rem;
    }
}

@media (max-width: 640px) {
    .co-section-title {
        font-size: 2rem;
    }
}

.co-content-box {
    background: #232323;
    border-radius: 1rem;
    padding: 3rem;
    transition: all 0.4s ease;
    border: 1px solid #2a2a2a;
}

.co-content-box:hover {
    background: #2a2a2a;
    border-color: #161513;
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

@media (max-width: 768px) {
    .co-content-box {
        padding: 2rem;
    }
}

.co-accent-line {
    width: 60px;
    height: 3px;
    background: #81817f;
    margin: 1.5rem 0;
}

.compliance-card {
    background: linear-gradient(135deg, #2a2a2a 0%, #1f1f1f 100%);
    border-radius: 1.5rem;
    padding: 2.5rem;
    border: 1px solid #333;
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

.compliance-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #fbbf24, #f59e0b);
    transform: scaleX(0);
    transition: transform 0.4s ease;
}

.compliance-card:hover::before {
    transform: scaleX(1);
}

.compliance-card:hover {
    background: linear-gradient(135deg, #2f2f2f 0%, #252525 100%);
    border-color: #fbbf24;
    transform: translateY(-8px);
    box-shadow: 0 25px 50px rgba(251, 191, 36, 0.1);
}

@media (max-width: 768px) {
    .compliance-card {
        padding: 1.5rem;
    }
}

.icon-container {
    width: 70px;
    height: 70px;
    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    border-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
    transition: all 0.4s ease;
}

.compliance-card:hover .icon-container {
    transform: scale(1.1) rotate(5deg);
}

.feature-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.5rem;
    padding: 1rem;
    background: #1f1f1f;
    border-radius: 0.75rem;
    border-left: 3px solid #fbbf24;
    transition: all 0.3s ease;
}

.feature-item:hover {
    background: #252525;
    transform: translateX(8px);
}

.feature-icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    background: #fbbf24;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #1a1a1a;
    font-weight: bold;
    font-size: 0.875rem;
}

.accent-line {
    width: 60px;
    height: 3px;
    background: #fbbf24;
    margin: 1.5rem 0;
}

.compliance-badge {
    display: inline-block;
    padding: 0.5rem 1.25rem;
    background: rgba(251, 191, 36, 0.1);
    border: 1px solid #fbbf24;
    border-radius: 2rem;
    color: #fbbf24;
    font-size: 0.875rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.faq-section {
    padding: 6rem 1rem;
}

.faq-container {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 4rem;
    align-items: start;
}

@media (max-width: 968px) {
    .faq-container {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
}

.faq-header {
    position: sticky;
    top: 6rem;
}

.faq-label {
    font-size: 0.75rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: #9ca3af;
    font-weight: 400;
    margin-bottom: 1.5rem;
}

.faq-title {
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1.1;
    color: #fff;
    margin: 0;
}

@media (max-width: 768px) {
    .faq-title {
        font-size: 2.5rem;
    }
}

.faq-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.faq-item {
    background: transparent;
    border: 1px solid #2a2a2a;
    border-radius: 0;
    overflow: hidden;
    transition: all 0.3s ease;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.faq-item.active {
    border-color: #3a3a3a;
}

.faq-question {
    display: flex;
    gap: 2rem;
    align-items: center;
    cursor: pointer;
    background: transparent;
    transition: all 0.3s ease;
}

.faq-question-content {
    flex: 1;
    display: flex;
    gap: 1.5rem;
    align-items: center;
}

.faq-number {
    font-size: 0.875rem;
    color: #fff;
    font-weight: 500;
}

.faq-question-text {
    font-size: 1.25rem;
    font-weight: 600;
    color: #fff;
    margin: 0;
}

@media (max-width: 640px) {
    .faq-question-text {
        font-size: 1rem;
    }
}

.faq-toggle {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: transparent;
    border: 1px solid #3a3a3a;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.faq-item.active .faq-toggle {
    background: #fff;
    border-color: #fff;
    transform: rotate(180deg);
}

.faq-toggle-icon {
    width: 1rem;
    height: 1rem;
    position: relative;
}

.faq-toggle-icon::before,
.faq-toggle-icon::after {
    content: '';
    position: absolute;
    background: #9ca3af;
    transition: all 0.3s ease;
}

.faq-toggle-icon::before {
    width: 100%;
    height: 2px;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}

.faq-toggle-icon::after {
    width: 2px;
    height: 100%;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
}

.faq-item.active .faq-toggle-icon::before,
.faq-item.active .faq-toggle-icon::after {
    background: #1a1a1a;
}

.faq-item.active .faq-toggle-icon::after {
    opacity: 0;
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), padding 0.4s ease;
    padding: 0 2rem;
}

.faq-item.active .faq-answer {
    max-height: 500px;
}

.faq-answer-text {
    color: #9ca3af;
    line-height: 1.7;
    font-size: 1rem;
    padding-left: 2.5rem;
}

@media (max-width: 640px) {
    .faq-answer-text {
        padding-left: 0;
    }

    .faq-question {
        padding: 1.5rem;
    }

    .faq-question-content {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }
}

.rich-text h3 {
    color: #fff;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
    margin-top: 2rem;
}

.rich-text p {
    color: #9ca3af;
    font-size: 1.125rem;
    line-height: 1.75;
    margin-bottom: 1.5rem;
}

.rich-text ul {
    list-style: none;
    padding: 0;
    margin-bottom: 2rem;
}

.rich-text li {
    position: relative;
    padding-left: 1.5rem;
    color: #9ca3af;
    margin-bottom: 0.75rem;
}

.rich-text li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.6rem;
    width: 6px;
    height: 6px;
    background-color: #fbbf24;
    border-radius: 50%;
}

.sidebar-card {
    background: #262629;
    border: 1px solid #333;
    border-radius: 1rem;
    padding: 2rem;
}

.reveal-img {
    position: relative;
    overflow: hidden;
}

.reveal-img::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, #1a1a1a, transparent);
    transform: translateY(0%);
    transition: transform 1.2s ease-out;
}

.reveal-visible .reveal-img::after {
    transform: translateY(100%);
}

.fade-up {
    opacity: 0;
    transform: translateY(40px);
    transition: all 1s ease-out;
}

.reveal-visible.fade-up {
    opacity: 1;
    transform: translateY(0px);
}

.training-card {
    background: linear-gradient(135deg, #2a2a2a 0%, #1f1f1f 100%);
    border: 1px solid #333;
    border-radius: 1.5rem;
    padding: 2.5rem;
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

.training-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #fbbf24, #f59e0b);
    transform: scaleX(0);
    transition: transform 0.4s ease;
}

.training-card:hover::before {
    transform: scaleX(1);
}

.training-card:hover {
    background: linear-gradient(135deg, #2f2f2f 0%, #252525 100%);
    border-color: #fbbf24;
    transform: translateY(-8px);
    box-shadow: 0 25px 50px rgba(251, 191, 36, 0.1);
}

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

.feature-list li {
    padding-left: 2rem;
    position: relative;
    margin-bottom: 1rem;
}

.feature-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #fbbf24;
    font-weight: bold;
    font-size: 1.25rem;
}

.program-card {
    background: #262629;
    border: 1px solid #333;
    border-radius: 1rem;
    padding: 2rem;
    transition: all 0.3s ease;
}

.program-card:hover {
    background: #2a2a2a;
    border-color: #fbbf24;
    transform: translateX(8px);
}

.contact-form {
    background: linear-gradient(135deg, #2a2a2a 0%, #1f1f1f 100%);
    border: 1px solid #333;
    border-radius: 1.5rem;
    padding: 3rem;
}

.form-group {
    margin-bottom: 1.5rem;
}

.form-label {
    display: block;
    color: #fff;
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 0.95rem;
}

.form-input,
.form-textarea,
.form-select {
    width: 100%;
    background: #1a1a1a;
    border: 2px solid #333;
    border-radius: 0.75rem;
    padding: 1rem 1.25rem;
    color: #fff;
    font-size: 1rem;
    transition: all 0.3s ease;
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
    outline: none;
    border-color: #fbbf24;
    background: #232323;
    box-shadow: 0 0 0 3px rgba(251, 191, 36, 0.1);
}

.form-textarea {
    resize: vertical;
    min-height: 150px;
}

.form-input::placeholder,
.form-textarea::placeholder {
    color: #666;
}

.form-checkbox {
    width: 1.25rem;
    height: 1.25rem;
    background: #1a1a1a;
    border: 2px solid #333;
    border-radius: 0.375rem;
    cursor: pointer;
    transition: all 0.3s ease;
}

.form-checkbox:checked {
    background: #fbbf24;
    border-color: #fbbf24;
}

.submit-btn {
    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    color: #000;
    font-weight: 700;
    padding: 1.25rem 3rem;
    border-radius: 0.75rem;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 1.1rem;
    width: 100%;
}

.submit-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(251, 191, 36, 0.3);
}

.submit-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.compliance-disclaimer {
    background: linear-gradient(135deg, #dc2626 0%, #991b1b 100%);
    border-left: 4px solid #fbbf24;
    border-radius: 1rem;
    padding: 1.5rem;
    margin-bottom: 2rem;
}

.office-card {
    background: linear-gradient(135deg, #2a2a2a 0%, #1f1f1f 100%);
    border: 1px solid #333;
    border-radius: 1.5rem;
    padding: 2.5rem;
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

.office-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #fbbf24, #f59e0b);
    transform: scaleX(0);
    transition: transform 0.4s ease;
}

.office-card:hover::before {
    transform: scaleX(1);
}

.office-card:hover {
    background: linear-gradient(135deg, #2f2f2f 0%, #252525 100%);
    border-color: #fbbf24;
    transform: translateY(-8px);
    box-shadow: 0 25px 50px rgba(251, 191, 36, 0.1);
}

.map-container {
    border-radius: 1rem;
    overflow: hidden;
    height: 400px;
    background: #1a1a1a;
}

.fade-in-up {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.fade-in-up.visible {
    opacity: 1;
    transform: translateY(0);
}

.stagger-1 {
    transition-delay: 0.1s;
}

.stagger-2 {
    transition-delay: 0.2s;
}

.stagger-3 {
    transition-delay: 0.3s;
}

.error-message {
    color: #ef4444;
    font-size: 0.875rem;
    margin-top: 0.5rem;
    display: none;
}

.error-message.show {
    display: block;
}

.form-input.error,
.form-textarea.error,
.form-select.error {
    border-color: #ef4444;
}

@keyframes pulse-bg {

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

    50% {
        transform: scale(1.1);
        opacity: 0.15;
    }
}

@keyframes float {

    0%,
    100% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-20px);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

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

@keyframes ripple {
    0% {
        transform: translate(-50%, -50%) scale(0.8);
        opacity: 1;
    }

    100% {
        transform: translate(-50%, -50%) scale(1.2);
        opacity: 0;
    }
}

.pulse-bg {
    animation: pulse-bg 4s ease-in-out infinite;
}

.float {
    animation: float 3s ease-in-out infinite;
}

.fadeInUp {
    animation: fadeInUp 0.8s ease-out backwards;
}

.fadeInUp-delay-1 {
    animation: fadeInUp 0.8s ease-out 0.2s backwards;
}

.fadeInUp-delay-2 {
    animation: fadeInUp 0.8s ease-out 0.4s backwards;
}

.fadeInUp-delay-3 {
    animation: fadeInUp 0.8s ease-out 0.6s backwards;
}

.ripple {
    animation: ripple 3s ease-out infinite;
}

.ripple-delay-1 {
    animation-delay: 0.5s;
}

.ripple-delay-2 {
    animation-delay: 1s;
}

.ripple-delay-3 {
    animation-delay: 1.5s;
}

.feature-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, #fbbf24, transparent);
    transform: scaleX(0);
    transition: transform 0.4s ease;
}

.feature-card:hover::before {
    transform: scaleX(1);
}

.gradient-border {
    position: relative;
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.05) 0%, rgba(26, 26, 26, 0.8) 100%);
    border: 1px solid rgba(251, 191, 36, 0.2);
}

.gradient-text {
    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hover-lift {
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.5s ease;
}

.hover-lift:hover {
    transform: translateY(-8px);
}

.section-number {
    font-size: 120px;
    font-weight: 900;
    color: rgba(251, 191, 36, 0.08);
    position: absolute;
    top: -40px;
    left: 0;
    line-height: 1;
    pointer-events: none;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(40px);
    }

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

.animate-fadeInUp {
    animation: fadeInUp 0.8s ease-out forwards;
    opacity: 0;
}

.animate-delay-200 {
    animation-delay: 0.2s;
}

.animate-delay-400 {
    animation-delay: 0.4s;
}

.btn-outline-yellow {
    position: relative;
    overflow: hidden;
}

.btn-outline-yellow::before {
    content: '';
    position: absolute;
    inset: 0;
    background: #fbbf24;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.4s ease;
    z-index: -1;
}

.btn-outline-yellow:hover::before {
    transform: scaleX(1);
    transform-origin: left;
}

.btn-outline-yellow:hover {
    color: #000;
    border-color: #fbbf24;
}

.btn-outline-white {
    position: relative;
    overflow: hidden;
}

.btn-outline-white::before {
    content: '';
    position: absolute;
    inset: 0;
    background: #fff;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.4s ease;
    z-index: -1;
}

.btn-outline-white:hover::before {
    transform: scaleX(1);
    transform-origin: left;
}

.btn-outline-white:hover {
    color: #000;
    border-color: #fff;
}

.section-reveal-new {
    transform: translateY(60px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.section-reveal-new.visible {
    opacity: 1;
    transform: translateY(0);
}

.gradient-card-new {
    border: 1px solid rgba(251, 191, 36, 0.2);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.gradient-card-new:hover {
    border-color: rgba(251, 191, 36, 0.5);
}

.pdf-icon {
    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
}

.tag-new {
    background: rgba(251, 191, 36, 0.1);
    border: 1px solid rgba(251, 191, 36, 0.3);
    color: #fbbf24;
}

.detail-section-case {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.6s ease;
}

.detail-section-case.visible {
    opacity: 1;
    transform: translateY(0);
}

.stat-card-case {
    transition: all 0.3s ease;
}

.stat-card-case:hover {
    transform: translateY(-5px);
    border-color: #fbbf24;
}

.compliance-card {
    background: linear-gradient(135deg, #2a2a2a 0%, #1f1f1f 100%);
    border: 1px solid #333;
    border-radius: 1rem;
    padding: 2.5rem;
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

.compliance-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #fbbf24, #f59e0b);
    transform: scaleX(0);
    transition: transform 0.4s ease;
}

.compliance-card:hover::before {
    transform: scaleX(1);
}

.compliance-card:hover {
    background: linear-gradient(135deg, #2f2f2f 0%, #252525 100%);
    border-color: #fbbf24;
    transform: translateY(-8px);
    box-shadow: 0 25px 50px rgba(251, 191, 36, 0.1);
}

.process-step {
    background: #232323;
    border: 1px solid #2a2a2a;
    border-radius: 1rem;
    padding: 2rem;
    position: relative;
    transition: all 0.3s ease;
}

.process-step::before {
    content: '';
    position: absolute;
    left: -1px;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 0;
    background: #fbbf24;
    transition: height 0.3s ease;
}

.process-step:hover::before {
    height: 100%;
}

.process-step:hover {
    background: #2a2a2a;
    border-color: #fbbf24;
    transform: translateX(8px);
}

.framework-badge {
    background: #2a2a2a;
    border: 2px solid #333;
    border-radius: 0.75rem;
    padding: 1.5rem;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.framework-badge:hover {
    border-color: #fbbf24;
    background: #2f2f2f;
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(251, 191, 36, 0.15);
}

.trust-seal {
    background: linear-gradient(135deg, #1f2937 0%, #111827 100%);
    border: 2px solid #fbbf24;
    border-radius: 1.5rem;
    padding: 3rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.trust-seal::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(251, 191, 36, 0.1) 0%, transparent 70%);
    animation: pulse 3s ease-in-out infinite;
}

@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-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-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-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-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: 0px;
}

@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-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 pulse {
    50% {
        opacity: 0.5;
    }
}

@keyframes bounce {

    0%,
    100% {
        transform: translateY(-25%);
        animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
    }

    50% {
        transform: none;
        animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
    }
}

@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-scale-x: 1;
            --tw-scale-y: 1;
            --tw-scale-z: 1;
            --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-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-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-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;
        }
    }
}
