/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */
@layer properties {
    @supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))) {

        *,
        :before,
        :after,
        ::backdrop {
            --tw-translate-x: 0;
            --tw-translate-y: 0;
            --tw-translate-z: 0;
            --tw-rotate-x: initial;
            --tw-rotate-y: initial;
            --tw-rotate-z: initial;
            --tw-skew-x: initial;
            --tw-skew-y: initial;
            --tw-space-y-reverse: 0;
            --tw-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;
            --tw-scale-x: 1;
            --tw-scale-y: 1;
            --tw-scale-z: 1
        }
    }
}

@layer theme {

    :root,
    :host {
        --font-sans: "Outfit", sans-serif;
        --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
        --color-red-200: oklch(88.5% .062 18.334);
        --color-red-500: oklch(63.7% .237 25.331);
        --color-gray-100: oklch(96.7% .003 264.542);
        --color-gray-300: oklch(87.2% .01 258.338);
        --color-gray-400: oklch(70.7% .022 261.325);
        --color-gray-500: oklch(55.1% .027 264.364);
        --color-gray-600: oklch(44.6% .03 256.802);
        --color-black: #000;
        --color-white: #fff;
        --spacing: .25rem;
        --container-xs: 20rem;
        --container-sm: 24rem;
        --container-xl: 36rem;
        --container-2xl: 42rem;
        --container-3xl: 48rem;
        --container-4xl: 56rem;
        --container-6xl: 72rem;
        --text-xs: .75rem;
        --text-xs--line-height: calc(1/.75);
        --text-sm: .875rem;
        --text-sm--line-height: calc(1.25/.875);
        --text-base: 1rem;
        --text-base--line-height: calc(1.5/1);
        --text-lg: 1.125rem;
        --text-lg--line-height: calc(1.75/1.125);
        --text-xl: 1.25rem;
        --text-xl--line-height: calc(1.75/1.25);
        --text-2xl: 1.5rem;
        --text-2xl--line-height: calc(2/1.5);
        --text-3xl: 1.875rem;
        --text-3xl--line-height: calc(2.25/1.875);
        --text-4xl: 2.25rem;
        --text-4xl--line-height: calc(2.5/2.25);
        --text-5xl: 3rem;
        --text-5xl--line-height: 1;
        --text-6xl: 3.75rem;
        --text-6xl--line-height: 1;
        --font-weight-medium: 500;
        --font-weight-semibold: 600;
        --font-weight-bold: 700;
        --tracking-tight: -.025em;
        --tracking-wider: .05em;
        --tracking-widest: .1em;
        --leading-tight: 1.25;
        --leading-relaxed: 1.625;
        --radius-md: .375rem;
        --radius-lg: .5rem;
        --radius-xl: .75rem;
        --radius-2xl: 1rem;
        --radius-3xl: 1.5rem;
        --ease-in-out: cubic-bezier(.4, 0, .2, 1);
        --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1)infinite;
        --animate-bounce: bounce 1s infinite;
        --blur-md: 12px;
        --blur-lg: 16px;
        --blur-3xl: 64px;
        --default-transition-duration: .15s;
        --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
        --default-font-family: var(--font-sans);
        --default-mono-font-family: var(--font-mono);
        --color-primary: #ffac5b
    }
}

@layer base {

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

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

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

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

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

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

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

    b,
    strong {
        font-weight: bolder
    }

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

    small {
        font-size: 80%
    }

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

    sub {
        bottom: -.25em
    }

    sup {
        top: -.5em
    }

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

    :-moz-focusring {
        outline: auto
    }

    progress {
        vertical-align: baseline
    }

    summary {
        display: list-item
    }

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

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

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

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

    ::file-selector-button {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        opacity: 1;
        background-color: #0000;
        border-radius: 0
    }

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

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

    ::file-selector-button {
        margin-inline-end: 4px
    }

    ::placeholder {
        opacity: 1
    }

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

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

    textarea {
        resize: vertical
    }

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

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

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

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

    ::-webkit-datetime-edit {
        padding-block: 0
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@layer components;

@layer utilities {
    .pointer-events-auto {
        pointer-events: auto
    }

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

    .visible {
        visibility: visible
    }

    .absolute {
        position: absolute
    }

    .fixed {
        position: fixed
    }

    .relative {
        position: relative
    }

    .static {
        position: static
    }

    .sticky {
        position: sticky
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .z-10 {
        z-index: 10
    }

    .z-20 {
        z-index: 20
    }

    .z-30 {
        z-index: 30
    }

    .z-40 {
        z-index: 40
    }

    .z-50 {
        z-index: 50
    }

    .z-\[100\] {
        z-index: 100
    }

    .z-\[99999\] {
        z-index: 99999
    }

    .order-1 {
        order: 1
    }

    .order-2 {
        order: 2
    }

    .container {
        width: 100%
    }

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

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

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

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

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

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

    .mx-auto {
        margin-inline: auto
    }

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

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

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

    .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-16 {
        margin-top: calc(var(--spacing)*16)
    }

    .mr-1\.5 {
        margin-right: calc(var(--spacing)*1.5)
    }

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

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

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

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

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

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

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

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

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

    .block {
        display: block
    }

    .flex {
        display: flex
    }

    .grid {
        display: grid
    }

    .hidden {
        display: none
    }

    .inline-block {
        display: inline-block
    }

    .inline-flex {
        display: inline-flex
    }

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

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

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

    .h-3\.5 {
        height: calc(var(--spacing)*3.5)
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

    .h-\[80\%\] {
        height: 80%
    }

    .h-\[100dvh\] {
        height: 100dvh
    }

    .h-\[600px\] {
        height: 600px
    }

    .h-auto {
        height: auto
    }

    .h-full {
        height: 100%
    }

    .max-h-full {
        max-height: 100%
    }

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

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

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

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

    .w-3\.5 {
        width: calc(var(--spacing)*3.5)
    }

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

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

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

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

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

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

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

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

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

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

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

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

    .w-\[80\%\] {
        width: 80%
    }

    .w-\[90\%\] {
        width: 90%
    }

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

    .w-auto {
        width: auto
    }

    .w-full {
        width: 100%
    }

    .w-screen {
        width: 100vw
    }

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

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

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

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

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

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

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

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

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

    .flex-1 {
        flex: 1
    }

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

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

    .translate-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-0 {
        --tw-translate-y: calc(var(--spacing)*0);
        translate: var(--tw-translate-x)var(--tw-translate-y)
    }

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

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

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

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

    .rotate-2 {
        rotate: 2deg
    }

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

    .animate-pulse {
        animation: var(--animate-pulse)
    }

    .cursor-pointer {
        cursor: pointer
    }

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

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

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

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

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

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

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

    .overflow-hidden {
        overflow: hidden
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .border-\[\#ffffff38\] {
        border-color: #ffffff38
    }

    .border-\[rgba\(var\(--glass-border-rgb\)\,0\.05\)\] {
        border-color: rgba(var(--glass-border-rgb), .05)
    }

    .border-\[var\(--color-accent\)\],
    .border-\[var\(--color-accent\)\]\/30 {
        border-color: var(--color-accent)
    }

    @supports (color:color-mix(in lab, red, red)) {
        .border-\[var\(--color-accent\)\]\/30 {
            border-color: color-mix(in oklab, var(--color-accent)30%, transparent)
        }
    }

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

    .border-\[var\(--color-status-indicator\)\]\/30 {
        border-color: var(--color-status-indicator)
    }

    @supports (color:color-mix(in lab, red, red)) {
        .border-\[var\(--color-status-indicator\)\]\/30 {
            border-color: color-mix(in oklab, var(--color-status-indicator)30%, transparent)
        }
    }

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

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

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

    .border-red-500\/50 {
        border-color: #fb2c3680
    }

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

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

    .border-white\/10 {
        border-color: #ffffff1a
    }

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

    .border-white\/20 {
        border-color: #fff3
    }

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

    .border-white\/30 {
        border-color: #ffffff4d
    }

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

    .border-l-\[var\(--color-accent\)\]\/30 {
        border-left-color: var(--color-accent)
    }

    @supports (color:color-mix(in lab, red, red)) {
        .border-l-\[var\(--color-accent\)\]\/30 {
            border-left-color: color-mix(in oklab, var(--color-accent)30%, transparent)
        }
    }

    .bg-\[\#25D366\] {
        background-color: #25d366
    }

    .bg-\[\#25D366\]\/10 {
        background-color: oklab(76.0953% -.174012 .10152/.1)
    }

    .bg-\[rgba\(var\(--bg-main-rgb\)\,0\.9\)\] {
        background-color: rgba(var(--bg-main-rgb), .9)
    }

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

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

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

    .bg-\[var\(--color-accent\)\],
    .bg-\[var\(--color-accent\)\]\/5 {
        background-color: var(--color-accent)
    }

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

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

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

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

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

    .bg-\[var\(--color-contact-icons\)\]\/10 {
        background-color: var(--color-contact-icons)
    }

    @supports (color:color-mix(in lab, red, red)) {
        .bg-\[var\(--color-contact-icons\)\]\/10 {
            background-color: color-mix(in oklab, var(--color-contact-icons)10%, transparent)
        }
    }

    .bg-\[var\(--color-status-indicator\)\],
    .bg-\[var\(--color-status-indicator\)\]\/5 {
        background-color: var(--color-status-indicator)
    }

    @supports (color:color-mix(in lab, red, red)) {
        .bg-\[var\(--color-status-indicator\)\]\/5 {
            background-color: color-mix(in oklab, var(--color-status-indicator)5%, transparent)
        }
    }

    .bg-\[var\(--color-status-indicator\)\]\/10 {
        background-color: var(--color-status-indicator)
    }

    @supports (color:color-mix(in lab, red, red)) {
        .bg-\[var\(--color-status-indicator\)\]\/10 {
            background-color: color-mix(in oklab, var(--color-status-indicator)10%, transparent)
        }
    }

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

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

    .bg-red-500\/20 {
        background-color: #fb2c3633
    }

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

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

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

    .bg-white\/10 {
        background-color: #ffffff1a
    }

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

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

    .bg-gradient-to-l {
        --tw-gradient-position: to left 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-\[radial-gradient\(circle_at_50\%_50\%\,rgba\(76\,29\,149\,0\.03\)\,rgba\(15\,23\,42\,0\)\)\] {
        background-image: radial-gradient(circle, #4c1d9508, #0f172a00)
    }

    .bg-\[url\(\'data\:image\/svg\+xml\;base64\,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI\+PHBhdGggZD0iTTEgMWgydjJIMUMxeiIgZmlsbD0iI2ZmZiIgZmlsbC1vcGFjaXR5PSIwLjEiLz48L3N2Zz4\=\'\)\] {
        background-image: url()
    }

    .from-\[\#0b0f19\] {
        --tw-gradient-from: #0b0f19;
        --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-\[var\(--bg-card\)\] {
        --tw-gradient-from: var(--bg-card);
        --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-\[var\(--text-main\)\] {
        --tw-gradient-from: var(--text-main);
        --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-\[var\(--bg-main\)\] {
        --tw-gradient-to: var(--bg-main);
        --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-\[var\(--text-muted\)\] {
        --tw-gradient-to: var(--text-muted);
        --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))
    }

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

    .object-contain {
        object-fit: contain
    }

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

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

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

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

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

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

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

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

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

    .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-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-16 {
        padding-block: calc(var(--spacing)*16)
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    .text-center {
        text-align: center
    }

    .text-left {
        text-align: left
    }

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

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

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

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

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

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

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

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

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

    .text-\[1\.15rem\] {
        font-size: 1.15rem
    }

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

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

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

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

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

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

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

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

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

    .whitespace-nowrap {
        white-space: nowrap
    }

    .text-\[\#0b0f19\] {
        color: #0b0f19
    }

    .text-\[\#25D366\] {
        color: #25d366
    }

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

    .text-\[var\(--color-contact-icons\)\] {
        color: var(--color-contact-icons)
    }

    .text-\[var\(--color-contact-subtitle\)\] {
        color: var(--color-contact-subtitle)
    }

    .text-\[var\(--color-portfolio-link\)\] {
        color: var(--color-portfolio-link)
    }

    .text-\[var\(--color-status-indicator\)\] {
        color: var(--color-status-indicator)
    }

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

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

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

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

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

    .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-inherit {
        color: inherit
    }

    .text-red-200 {
        color: var(--color-red-200)
    }

    .text-transparent {
        color: #0000
    }

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

    .text-white\/70 {
        color: #ffffffb3
    }

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

    .uppercase {
        text-transform: uppercase
    }

    .no-underline {
        text-decoration-line: none
    }

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

    .placeholder-\[var\(--input-placeholder\)\]::placeholder {
        color: var(--input-placeholder)
    }

    .opacity-0 {
        opacity: 0
    }

    .opacity-20 {
        opacity: .2
    }

    .opacity-75 {
        opacity: .75
    }

    .opacity-100 {
        opacity: 1
    }

    .opacity-\[0\.03\] {
        opacity: .03
    }

    .shadow-2xl {
        --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, #00000040);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

    .shadow-\[0_0_15px_rgba\(103\,189\,29\,0\.1\)\] {
        --tw-shadow: 0 0 15px var(--tw-shadow-color, #67bd1d1a);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

    .shadow-\[0_4px_20px_rgba\(37\,211\,102\,0\.4\)\] {
        --tw-shadow: 0 4px 20px var(--tw-shadow-color, #25d36666);
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
    }

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

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

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

    .ring-0 {
        --tw-ring-shadow: var(--tw-ring-inset, )0 0 0 calc(0px + 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)
    }

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

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

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

    .backdrop-blur-md {
        --tw-backdrop-blur: blur(var(--blur-md));
        -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-all {
        transition-property: all;
        transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
        transition-duration: var(--tw-duration, var(--default-transition-duration))
    }

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

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

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

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

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

    .duration-700 {
        --tw-duration: .7s;
        transition-duration: .7s
    }

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

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

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

        .group-hover\:scale-105:is(:where(.group):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 *) {
            --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 *) {
            rotate: 12deg
        }

        .group-hover\:bg-\[\#0077b5\]:is(:where(.group):hover *) {
            background-color: #0077b5
        }

        .group-hover\:bg-\[var\(--color-accent\)\]:is(:where(.group):hover *) {
            background-color: var(--color-accent)
        }

        .group-hover\:text-\[var\(--color-contact-icons\)\]:is(:where(.group):hover *) {
            color: var(--color-contact-icons)
        }

        .group-hover\:text-\[var\(--text-main\)\]:is(:where(.group):hover *) {
            color: var(--text-main)
        }

        .group-hover\:text-white:is(:where(.group):hover *) {
            color: var(--color-white)
        }
    }

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

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

    .selection\:text-\[var\(--bg-main\)\] ::selection {
        color: var(--bg-main)
    }

    .selection\:text-\[var\(--bg-main\)\]::selection {
        color: var(--bg-main)
    }

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

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

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

        .hover\:scale-105: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 {
            --tw-scale-x: 110%;
            --tw-scale-y: 110%;
            --tw-scale-z: 110%;
            scale: var(--tw-scale-x)var(--tw-scale-y)
        }

        .hover\:scale-\[1\.02\]:hover {
            scale: 1.02
        }

        .hover\:rotate-0:hover {
            rotate: none
        }

        .hover\:border-\[var\(--color-accent\)\]\/30:hover {
            border-color: var(--color-accent)
        }

        @supports (color:color-mix(in lab, red, red)) {
            .hover\:border-\[var\(--color-accent\)\]\/30:hover {
                border-color: color-mix(in oklab, var(--color-accent)30%, transparent)
            }
        }

        .hover\:bg-\[\#20bd5a\]:hover {
            background-color: #20bd5a
        }

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

        .hover\:bg-\[var\(--glass-highlight\)\]:hover {
            background-color: var(--glass-highlight)
        }

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

        .hover\:bg-white\/10:hover {
            background-color: #ffffff1a
        }

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

        .hover\:bg-white\/20:hover {
            background-color: #fff3
        }

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

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

        .hover\:text-\[var\(--text-main\)\]:hover {
            color: var(--text-main)
        }

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

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

        .hover\:shadow-\[var\(--color-status-indicator\)\]\/20:hover {
            --tw-shadow-alpha: 20%;
            --tw-shadow: var(--color-status-indicator);
            box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)
        }
    }

    .focus\:border-\[var\(--color-status-indicator\)\]:focus {
        border-color: var(--color-status-indicator)
    }

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

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

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

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

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

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

        .md\:bottom-8 {
            bottom: calc(var(--spacing)*8)
        }

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

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

        .md\:left-auto {
            left: auto
        }

        .md\:order-1 {
            order: 1
        }

        .md\:order-2 {
            order: 2
        }

        .md\:order-3 {
            order: 3
        }

        .md\:col-span-1 {
            grid-column: span 1/span 1
        }

        .md\:col-span-2 {
            grid-column: span 2/span 2
        }

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

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

        .md\:mb-0 {
            margin-bottom: calc(var(--spacing)*0)
        }

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

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

        .md\:block {
            display: block
        }

        .md\:flex {
            display: flex
        }

        .md\:grid {
            display: grid
        }

        .md\:hidden {
            display: none
        }

        .md\:inline-flex {
            display: inline-flex
        }

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

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

        .md\:w-40 {
            width: calc(var(--spacing)*40)
        }

        .md\:w-auto {
            width: auto
        }

        .md\:max-w-none {
            max-width: none
        }

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

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

        .md\:scroll-mt-\[7\.5rem\] {
            scroll-margin-top: 7.5rem
        }

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

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

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

        .md\:flex-row {
            flex-direction: row
        }

        .md\:items-center {
            align-items: center
        }

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

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

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

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

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

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

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

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

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

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

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

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

        .md\:pt-8 {
            padding-top: calc(var(--spacing)*8)
        }

        .md\:pt-12 {
            padding-top: calc(var(--spacing)*12)
        }

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

        .md\:pb-8 {
            padding-bottom: calc(var(--spacing)*8)
        }

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

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

        .md\:text-left {
            text-align: left
        }

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

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

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

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

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

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

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

        .md\:opacity-100 {
            opacity: 1
        }
    }

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

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

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

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

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

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

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

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

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

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

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

@property --tw-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: 0
}

@property --tw-ring-offset-color {
    syntax: "*";
    inherits: false;
    initial-value: #fff
}

@property --tw-ring-offset-shadow {
    syntax: "*";
    inherits: false;
    initial-value: 0 0 #0000
}

@property --tw-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
}

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

@keyframes pulse {
    50% {
        opacity: .5
    }
}

@keyframes bounce {

    0%,
    to {
        animation-timing-function: cubic-bezier(.8, 0, 1, 1);
        transform: translateY(-25%)
    }

    50% {
        animation-timing-function: cubic-bezier(0, 0, .2, 1);
        transform: none
    }
}

/* Theme Definitions */

/* 1. Default Dark (Original) */
:root {
    --bg-main: #0b0f19;
    --bg-main-rgb: 11 15 25;
    --bg-card: #151b2b;
    --bg-card-inner: #1a2035;
    --text-main: #ffffff;
    --text-body: #d1d5db;
    --text-muted: #9ca3af;
    --color-accent: #67bd1d;
    --color-accent-rgb: 103 189 29;
    --color-primary: #FFAC5B;
    --color-primary-rgb: 255 172 91;
    --border-color: rgba(255, 255, 255, 0.1);
    --glass-bg: rgba(255, 255, 255, 0.05);
    /* Slightly more visible */
    --glass-border: rgba(255, 255, 255, 0.12);
    --glass-border-rgb: 255 255 255;
    --input-bg: #f2f1ef;
    /* Light background requested by user */
    --input-border: rgba(255, 255, 255, 0.1);
    --input-focus-bg: #ffffff;
    --input-text: #1f2937;
    /* Dark text for light background */
    --input-placeholder: #6b7280;

    /* Specific overrides */
    --color-action-btn-bg: linear-gradient(90deg, #68bc1d 0%, #8ce635 50%, #68bc1d 100%);
    --color-action-btn-text: #ffffff;
    --color-status-indicator: #67bd1d;
    --color-usp-check: #649039;
    --color-usp-border: #67bd1d;
    --color-portfolio-link: #FFAC5B;
    --filter-client-logo: grayscale(100%) opacity(0.4);
    --color-contact-header-btn-text: #ffffff;
    --color-contact-icons: #67bd1d;
    --color-contact-subtitle: #67bd1d;
    --color-contact-profile-border: #67bd1d;
    --color-contact-profile-border: #67bd1d;
    --logo-mask: linear-gradient(to right, transparent, black 20%, black 80%, transparent);
    --logo-grayscale-opacity: 1;
    --logo-filter: none;
}

/* 2. Itsme Inspired (Light/Orange/Fresh) */
[data-theme="fresh-orange"] {
    --bg-main: #ffffff;
    --bg-main-rgb: 255 255 255;
    --bg-card: #ffffff;
    --bg-card-inner: #f9fafb;
    --text-main: #1f2937;
    --text-body: #4b5563;
    --text-muted: #6b7280;
    --color-accent: #FF4F00;
    --color-accent-rgb: 255 79 0;
    --color-primary: #1f2937;
    --color-primary-rgb: 31 41 55;
    --border-color: rgba(0, 0, 0, 0.1);
    --glass-bg: rgba(0, 0, 0, 0.04);
    --glass-border: rgba(0, 0, 0, 0.1);
    --glass-border-rgb: 0 0 0;
    --input-bg: #f2f1ef;
    --input-border: rgba(0, 0, 0, 0.08);
    --input-focus-bg: #ffffff;
    --input-text: #1f2937;
    --input-placeholder: #6b7280;

    /* Specific overrides */
    --color-action-btn-bg: linear-gradient(90deg, #67bd1d 0%, #8ce635 50%, #67bd1d 100%);
    /* Keep Green */
    --color-action-btn-text: #ffffff;
    --color-status-indicator: #67bd1d;
    /* Keep Green */
    --color-usp-check: #ff4f00;
    /* Keep Green */
    --color-usp-border: #FF4F00;
    /* Orange */
    --color-portfolio-link: rgb(237, 147, 4);
    --filter-client-logo: none;
    --color-contact-header-btn-text: #ffffff;
    /* Default white, override on contact page */
    --color-contact-icons: #FF4F00;
    --color-contact-subtitle: #FF4F00;
    --color-contact-profile-border: #FF4F00;
    --color-contact-profile-border: #FF4F00;
    --logo-mask: none;
}

/* Contact Page Specific Override */
body.contact-page .contact-page-btn {
    color: white;
}

:root[data-theme="fresh-orange"] body.contact-page .contact-page-btn {
    color: #4b5563 !important;
    border-color: rgba(75, 85, 99, 0.3) !important;
}

/* Theme Toggle Button Override for Light Theme */
[data-theme="fresh-orange"] #theme-toggle {
    background-color: rgb(224 224 224 / 22%);
    border-color: rgb(214 214 214);
}

/* Utility Classes to use these variables */
.bg-theme-main {
    background-color: var(--bg-main);
}

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

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

.text-theme-main {
    color: var(--text-main);
}

.text-theme-body {
    color: var(--text-body);
}

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

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

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

/* Overrides for specific hardcoded elements if needed */
body {
    background-color: var(--bg-main);
    color: var(--text-main);
    transition: background-color 0.5s ease, color 0.5s ease;
}

/* Update selection color based on theme */
::selection {
    background-color: var(--color-accent);
    color: var(--bg-main);
}

:root {
    --primary-color: var(--color-primary);
    /* Warm Orange */
    --action-color: var(--color-accent);
    /* The user's Green for CTAs */
    --action-hover: var(--color-accent);
    /* Needs a hover var? */
    --dark-bg: var(--bg-main);
    /* Slightly deeper black/blue */
    --card-bg: var(--bg-card);
}

body {
    font-family: 'Outfit', sans-serif;
    background-color: var(--bg-main);
    color: var(--text-body);
    /* Softer white for better readability */
    overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: 'Outfit', sans-serif;
}

/* Smooth Scrolling */
html {
    scroll-behavior: smooth;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: #0f172a;
}

::-webkit-scrollbar-thumb {
    background: #334155;
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #475569;
}

/* Glassmorphism Utilities */
.glass {
    background: rgba(30, 41, 59, 0.7);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.glass-card {
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.glass-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px -10px rgba(103, 189, 29, 0.2);
    border-color: rgba(103, 189, 29, 0.3);
}

/* Client Logo Filter */
.client-logo {
    filter: var(--filter-client-logo);
    transition: filter 0.3s ease, opacity 0.3s ease;
}

.client-logo:hover {
    filter: none;
    opacity: 1;
}

/* Logo Theme Switching */
[data-theme="fresh-orange"] .dark-theme-logo {
    display: none;
}

[data-theme="fresh-orange"] .light-theme-logo {
    display: block !important;
}

/* Striking Button - The "Pop" Element */
.btn-striking {
    background: var(--color-action-btn-bg);
    background-size: 200% auto;
    /* animation: gradientFlow 2s linear infinite; - Moved to .btn-animate-gradient */
    color: white;
    position: relative;
    overflow: hidden;
    z-index: 1;
    transition: all 0.3s ease;
    box-shadow: 0 0 20px rgba(var(--color-accent-rgb), 0.2);
    font-family: 'Outfit', sans-serif;
    /* border: 1px solid var(--glass-border); - Removed to let green hover border shine through */
}

.btn-striking:hover {
    transform: translateY(-2px);
    box-shadow: 0 0 30px rgba(104, 188, 29, 0.4);
    border-color: rgba(255, 255, 255, 0.2);
}

.btn-animate-gradient {
    animation: gradientFlow 2s linear infinite;
}

/* Orange Gradient Button Class */
.bg-gradient-orange {
    background: linear-gradient(90deg, var(--color-primary) 0%, #ea913c 100%);
}

.bg-gradient-orange:hover {
    background: linear-gradient(90deg, #ea913c 0%, #FFAC5B 100%);
}

@keyframes gradientFlow {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 200% 50%;
    }
}

/* Gradient Text - White to Orange */
.text-gradient {
    background: linear-gradient(135deg, var(--text-main) 0%, var(--color-primary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ... (Animations kept same) ... */

/* Marquee Animation */
.marquee-container {
    overflow: hidden;
    white-space: nowrap;
    position: relative;
}

/* WhatsApp Button Pulse */
@keyframes whatsappPulse {

    0%,
    90% {
        transform: scale(1);
        box-shadow: 2px 2px 3px #999;
    }

    95% {
        transform: scale(1.1);
        box-shadow: 0 0 20px rgba(37, 211, 102, 0.6);
    }

    100% {
        transform: scale(1);
        box-shadow: 2px 2px 3px #999;
    }
}

#whatsapp-btn {
    animation: whatsappPulse 5s infinite;
}

/* Marquee Animation Speed */
/* Marquee Animation Speed */
/* Marquee Animation Speed */
.marquee-content {
    display: inline-flex;
    /* Base speed for desktop */
    animation: marquee 80s linear infinite;
    will-change: transform;
}

/* Mobile specific animations */
.animate-marquee-left {
    animation: marquee 180s linear infinite !important;
}

.animate-marquee-right {
    animation: marquee-reverse 180s linear infinite !important;
}

@keyframes marquee {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

@keyframes marquee-reverse {
    0% {
        transform: translateX(-50%);
    }

    100% {
        transform: translateX(0);
    }
}

/* Hero Background */
.hero-section {
    /* background: linear-gradient(to bottom, #0a1019, rgb(15, 21, 37), #0a1019); */
    background: transparent;
}

/* 2025 Modern High-Conversion Styles */

:root {
    --glass-bg: var(--glass-bg);
    /* Inherit from themes.css */
    --glass-border: var(--glass-border);
    --glass-highlight: rgba(255, 255, 255, 0.1);
    --neon-green: var(--color-accent);
    --neon-orange: var(--color-primary);
    --deep-bg: var(--bg-main);
}

/* Typography Enhancements */
h1,
h2,
h3 {
    letter-spacing: -0.02em;
    /* Tighter tracking for modern feel */
}

/* 1. Glassmorphism Cards (The "Wow" Factor) */
.modern-card {
    background: var(--bg-card-inner);
    /* Constant base */
    background: color-mix(in srgb, var(--bg-card-inner), transparent 10%);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    /* border: 1px solid var(--glass-border); */
    box-shadow: 0 8px 32px -4px rgba(0, 0, 0, 0.3);
    transition: all 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
    position: relative;
    overflow: hidden;
    font-family: 'Outfit', sans-serif;
}

/* Performance Optimization for Animations */
.gpu-accelerated {
    will-change: transform, opacity;
    transform: translateZ(0);
    -webkit-font-smoothing: antialiased;
    backface-visibility: hidden;
}

/* Hover Effect: Glow & Lift */
.modern-card:hover {
    transform: translateY(-8px) scale(1.02);
    border-color: rgba(var(--color-accent-rgb), 0.3);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

/* Inner Glow Gradient on Hover */
.modern-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(800px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(255, 255, 255, 0.06), transparent 40%);
    opacity: 0;
    transition: opacity 0.5s;
    pointer-events: none;
}

.modern-card:hover::before {
    opacity: 1;
}

/* 2. Bento Grid Layout Utilities */
.bento-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .bento-grid {
        grid-template-columns: repeat(3, 1fr);
        grid-auto-rows: minmax(250px, auto);
    }

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

    .row-span-2 {
        grid-row: span 2;
    }
}

/* 3. Hero Typography "Super Sizing" */
.hero-title-modern {
    font-size: 2.5rem;
    /* Reduced from 3.5rem for better mobile fit */
    line-height: 1.1;
    font-weight: 800;
}

@media (min-width: 768px) {
    .hero-title-modern {
        font-size: 5rem;
        /* Desktop massive */
    }
}

/* Prevent button text wrap */
.btn-striking {
    white-space: nowrap;
}

/* Gradient Text with "Shimmer" */
.text-gradient-modern {
    background: linear-gradient(to right, var(--text-main) 20%, var(--color-primary) 50%, var(--text-main) 80%);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: shine 5s linear infinite;
}

@keyframes shine {
    to {
        background-position: 200% center;
    }
}

/* 4. Magnetic Button Effect */
.btn-magnetic {
    transition: transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.btn-magnetic:hover {
    transform: scale(1.05);
}

/* 5. Badge Style */
.modern-badge {
    background: rgba(var(--color-accent-rgb), 0.1);
    border: 1px solid rgba(var(--color-accent-rgb), 0.2);
    color: var(--color-accent);
    padding: 0.6rem 1.25rem;
    border-radius: 9999px;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    backdrop-filter: blur(4px);
    font-family: 'Outfit', sans-serif;
}

/* 6. Section Separator Gradient */
.section-fade-top {
    background: linear-gradient(to bottom, var(--deep-bg), transparent);
    height: 100px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
    pointer-events: none;
}

/* 7. Visual Diversity Backgrounds */
.bg-grid-pattern {
    background-image: linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
    -webkit-mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
}

.bg-gradient-mesh {
    background-color: var(--bg-main);
    background-image:
        radial-gradient(at 0% 0%, rgba(var(--color-accent-rgb), 0.08) 0px, transparent 50%),
        radial-gradient(at 100% 100%, rgba(var(--color-accent-rgb), 0.05) 0px, transparent 50%);
}

.avatar-glow {
    box-shadow: 0 0 20px rgba(var(--color-accent-rgb), 0.3);
    transition: all 0.3s ease;
}

.avatar-glow:hover {
    box-shadow: 0 0 30px rgba(var(--color-accent-rgb), 0.5);
    transform: scale(1.05);
}

/* GSAP Utility Classes */

/* Premium Text Reveal */
.text-reveal-wrapper {
    overflow: hidden;
    /* Masks the text as it slides up */
    display: block;
}

.text-reveal {
    display: block;
    will-change: transform, opacity;
}

/* Parallax Wrapper */
.parallax-wrapper {
    overflow: hidden;
    position: relative;
}

.parallax-img {
    will-change: transform;
    /* Ensure image is large enough to move without showing edges */
    height: 120% !important;
    top: -10%;
    position: relative;
}

/* CTA Reveal */
.cta-reveal {
    will-change: transform, opacity, border-radius;
}

/* View Transitions API */
::view-transition-old(root),
::view-transition-new(root) {
    animation: none;
    mix-blend-mode: normal;
    height: 100%;
    overflow: clip;
}

/* Ensure the new view sits on top during the transition */
::view-transition-new(root) {
    z-index: 2147483646;
    /* Max safe integer for z-index */
}

/* Fallback / Helper for the JS animation */
::view-transition-image-pair(root) {
    isolation: isolate;
}

/* Disable default fade */
::view-transition-group(root) {
    animation-duration: 0s;
}

/* 2. Curtain Sweep */
.transition-overlay-curtain {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    pointer-events: none;
    background-color: #1a1a1a;
    /* Neutral dark or target color */
    transform: translateY(-100%);
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.transition-overlay-curtain.active {
    transform: translateY(0);
}

.transition-overlay-curtain.exit {
    transform: translateY(100%);
}

/* 3. Fade & Scale */
.fade-scale-anim {
    animation: fadeScale 0.6s ease-in-out forwards;
}

@keyframes fadeScale {
    0% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0;
        transform: scale(0.95);
    }

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

/* Gradient Border Animation */
.btn-gradient-border {
    position: relative;
    background: transparent;
    border-radius: 9999px;
    z-index: 1;
}

.btn-gradient-border::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 9999px;
    padding: 2px;
    /* Border width */
    background: linear-gradient(90deg, #FFAC5B, #67bd1d, #FFAC5B);
    background-size: 200% auto;
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    animation: gradientFlow 3s linear infinite;
}

.btn-gradient-border:hover::before {
    background: linear-gradient(90deg, #67bd1d, #FFAC5B, #67bd1d);
    background-size: 200% auto;
}

/* USP Sequential Loading Styles */
.usp-item {
    opacity: 0;
}

.usp-checkmark {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    color: var(--color-usp-check);
    flex-shrink: 0;
    vertical-align: middle;
}

.usp-checkmark path {
    stroke-dasharray: 60;
    stroke-dashoffset: 60;
    stroke: var(--color-usp-check);
}

.usp-text {
    opacity: 0;
    display: inline-block;
    white-space: nowrap;
}