/*
Theme Name: BidPack
Theme URI: https://bidpack.co
Author: Vision Age Company LLC
Author URI: https://bidpack.co
Description: BidPack — VFX Outsourcing & Project Management Platform. Connects VFX studios with trusted vendors to streamline outsourcing: manage bids, contracts, asset delivery and project workflows securely and transparently.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bidpack
Tags: dark, modern, one-page, business, portfolio
*/

/* ============================================================
   CSS VARIABLES — Design System
   ============================================================ */
:root {
    --radius: 0.625rem;
    --background: #17181D;
    --foreground: #ffffff;
    --card: #1f2127;
    --card-foreground: #ffffff;
    --primary: #5473C1;
    --primary-foreground: #ffffff;
    --secondary: #22242a;
    --secondary-foreground: #ffffff;
    --border: #2d2f36;
    --input: #2d2f36;
    --ring: #5473C1;
    --accent: #5473C1;
    --accent-foreground: #ffffff;
    --muted: #9ca3af;
    --font-sans: 'Geist', 'Inter', system-ui, -apple-system, sans-serif;
    --font-mono: 'Geist Mono', 'Fira Code', monospace;
    /* Tailwind design tokens */
    --color-sky-800: oklch(44.3% .11 240.79);
    --color-blue-600: oklch(54.6% .245 262.881);
    --color-gray-400: oklch(70.7% .022 261.325);
    --color-gray-500: oklch(55.1% .027 264.364);
    --color-zinc-100: oklch(96.7% .001 286.375);
    --color-zinc-900: oklch(21% .006 285.885);
    --color-neutral-100: oklch(97% 0 0);
    --color-neutral-300: oklch(87% 0 0);
    --color-neutral-400: oklch(70.8% 0 0);
    --color-neutral-500: oklch(55.6% 0 0);
    --color-neutral-700: oklch(37.1% 0 0);
    --color-neutral-800: oklch(26.9% 0 0);
    --color-neutral-900: oklch(20.5% 0 0);
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-sm: 24rem;
    --container-lg: 32rem;
    --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-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;
    --tracking-wide: .025em;
    --radius-xs: .125rem;
    --radius-3xl: 1.5rem;
    --ease-in-out: cubic-bezier(.4,0,.2,1);
    --animate-spin: spin 1s linear infinite;
    --animate-pulse: pulse 2s cubic-bezier(.4,0,.6,1) infinite;
    --blur-2xl: 40px;
    --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);
}

.dark {
    --background: #0f1014;
    --foreground: #fff;
    --card: #17181d;
    --card-foreground: #fff;
    --primary: #5473c1;
    --primary-foreground: #fff;
    --secondary: #1b1c20;
    --secondary-foreground: #fff;
    --border: #25262b;
    --input: #25262b;
    --ring: #5473c1;
    --accent: #5473c1;
    --accent-foreground: #fff;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border-color: var(--border);
    border: 0 solid;
    --tw-border-style: solid;
    outline-color: var(--ring);
}

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

html {
    scroll-behavior: smooth;
    font-size: 16px;
    -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");
    -webkit-tap-highlight-color: transparent;
}

body {
    font-family: var(--font-sans);
    background-color: var(--background);
    color: var(--foreground);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; }
img, video { max-width: 100%; height: auto; display: block; vertical-align: middle; }
audio, canvas, embed, iframe, img, object, svg, video { vertical-align: middle; display: block; }
a { color: inherit; text-decoration: inherit; transition: opacity 0.15s ease; }
a:hover { opacity: 0.8; }
ul, ol, menu { list-style: none; }
button { cursor: pointer; font-family: inherit; }
b, strong { font-weight: bolder; }
small { font-size: 80%; }
hr { height: 0; color: inherit; border-top-width: 1px; }
table { text-indent: 0; border-color: inherit; border-collapse: collapse; }
textarea { resize: vertical; }
progress { vertical-align: baseline; }
summary { display: list-item; }

sub, sup { vertical-align: baseline; font-size: 75%; line-height: 0; position: relative; }
sub { bottom: -.25em; }
sup { top: -.5em; }

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

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

:-moz-focusring { outline: auto; }
:-moz-ui-invalid { box-shadow: none; }
::-webkit-search-decoration { -webkit-appearance: none; }
::-webkit-inner-spin-button, ::-webkit-outer-spin-button { height: auto; }
::-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-day-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-minute-field,
::-webkit-datetime-edit-millisecond-field,
::-webkit-datetime-edit-second-field,
::-webkit-datetime-edit-meridiem-field { padding-block: 0; }
::-webkit-calendar-picker-indicator { line-height: 1; }

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

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

button, input:where([type=button], [type=reset], [type=submit]), ::file-selector-button { appearance: button; }
::file-selector-button { margin-inline-end: 4px; }

/* ============================================================
   TYPOGRAPHY UTILITIES
   ============================================================ */
.title {
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--foreground);
}
.title-xl  { font-size: clamp(1.25rem, 2vw, 1.5rem); }
.title-2xl { font-size: clamp(1.5rem, 3vw, 2rem); }
.title-3xl { font-size: clamp(1.75rem, 4vw, 2.25rem); }
.title-7xl { font-size: clamp(3rem, 8vw, 4.5rem); }

.desc-text {
    color: var(--muted);
    font-weight: 300;
    line-height: 1.7;
}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1rem;
}

@media (min-width: 640px)  { .container { padding: 0 70px; } }

.section-padding { padding: 80px 0; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-col-center { display: flex; flex-direction: column; align-items: center; justify-content: center; }
.text-center { text-align: center; }

/* ============================================================
   BACKGROUND — Gradient mesh
   ============================================================ */
.site-background {
    position: fixed;
    inset: 0;
    z-index: -10;
    background-color: var(--background);
    pointer-events: none;
    overflow: hidden;
}
.site-background::before {
    content: '';
    position: absolute;
    top: -20%;
    left: -10%;
    width: 60%;
    height: 60%;
    background: radial-gradient(ellipse, rgba(84,115,193,0.18) 0%, transparent 70%);
    animation: bgFloat 8s ease-in-out infinite alternate;
}
.site-background::after {
    content: '';
    position: absolute;
    bottom: -20%;
    right: -10%;
    width: 50%;
    height: 50%;
    background: radial-gradient(ellipse, rgba(84,115,193,0.10) 0%, transparent 70%);
    animation: bgFloat 10s ease-in-out infinite alternate-reverse;
}

/* ============================================================
   KEYFRAMES
   ============================================================ */
@keyframes bgFloat {
    from { transform: translateY(0) scale(1); }
    to   { transform: translateY(30px) scale(1.05); }
}
@keyframes pulse {
    0%, 100% { opacity: 0.7; transform: scale(1); }
    50%       { opacity: 1;   transform: scale(1.05); }
}
@keyframes spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}
@keyframes spinReverse {
    from { transform: rotate(0deg); }
    to   { transform: rotate(-360deg); }
}
@keyframes toastIn {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes motion-filter-in {
    0%  { filter: blur(var(--motion-origin-blur)) grayscale(var(--motion-origin-grayscale)); }
    to  { filter: blur() grayscale(0); }
}
@keyframes motion-filter-out {
    0%  { filter: blur() grayscale(0); }
    to  { filter: blur(var(--motion-end-blur)) grayscale(var(--motion-end-grayscale)); }
}
@keyframes motion-filter-loop-mirror {
    0%, to { filter: blur() grayscale(0); }
    50%    { filter: blur(var(--motion-loop-blur)) grayscale(var(--motion-loop-grayscale)); }
}
@keyframes motion-filter-loop-reset {
    0%  { filter: blur() grayscale(0); }
    to  { filter: blur(var(--motion-loop-blur)) grayscale(var(--motion-loop-grayscale)); }
}
@keyframes motion-opacity-in         { 0%  { opacity: var(--motion-origin-opacity); } }
@keyframes motion-opacity-out        { to  { opacity: var(--motion-end-opacity); } }
@keyframes motion-opacity-loop-mirror{ 50% { opacity: var(--motion-loop-opacity); } }
@keyframes motion-opacity-loop-reset { to  { opacity: var(--motion-loop-opacity); } }
@keyframes motion-background-color-in         { 0%  { background-color: var(--motion-origin-background-color); } }
@keyframes motion-background-color-out        { to  { background-color: var(--motion-end-background-color); } }
@keyframes motion-background-color-loop-mirror{ 50% { background-color: var(--motion-loop-background-color); } }
@keyframes motion-background-color-loop-reset { to  { background-color: var(--motion-loop-background-color); } }
@keyframes motion-text-color-in         { 0%  { color: var(--motion-origin-text-color); } }
@keyframes motion-text-color-out        { to  { color: var(--motion-end-text-color); } }
@keyframes motion-text-color-loop-mirror{ 50% { color: var(--motion-loop-text-color); } }
@keyframes motion-text-color-loop-reset { to  { color: var(--motion-loop-text-color); } }
@keyframes enter {
    0% {
        opacity: var(--tw-enter-opacity, 1);
        transform: translate3d(var(--tw-enter-translate-x, 0), var(--tw-enter-translate-y, 0), 0)
                   scale3d(var(--tw-enter-scale, 1), var(--tw-enter-scale, 1), var(--tw-enter-scale, 1))
                   rotate(var(--tw-enter-rotate, 0));
        filter: blur(var(--tw-enter-blur, 0));
    }
}
@keyframes exit {
    to {
        opacity: var(--tw-exit-opacity, 1);
        transform: translate3d(var(--tw-exit-translate-x, 0), var(--tw-exit-translate-y, 0), 0)
                   scale3d(var(--tw-exit-scale, 1), var(--tw-exit-scale, 1), var(--tw-exit-scale, 1))
                   rotate(var(--tw-exit-rotate, 0));
        filter: blur(var(--tw-exit-blur, 0));
    }
}

@media screen and (prefers-reduced-motion: no-preference) {
    @keyframes motion-scale-in         { 0%  { scale: var(--motion-origin-scale-x) var(--motion-origin-scale-y); } to { scale: 1; } }
    @keyframes motion-scale-out        { 0%  { scale: 1; } to { scale: var(--motion-end-scale-x) var(--motion-end-scale-y); } }
    @keyframes motion-scale-loop-mirror{ 0%, to { scale: 1; } 50% { scale: var(--motion-loop-scale-x) var(--motion-loop-scale-y); } }
    @keyframes motion-scale-loop-reset { 0%  { scale: 1; } to { scale: var(--motion-loop-scale-x) var(--motion-loop-scale-y); } }
    @keyframes motion-translate-in         { 0%  { translate: var(--motion-origin-translate-x) var(--motion-origin-translate-y); } to { translate: 0; } }
    @keyframes motion-translate-out        { 0%  { translate: 0; } to { translate: var(--motion-end-translate-x) var(--motion-end-translate-y); } }
    @keyframes motion-translate-loop-mirror{ 0%, to { translate: 0; } 50% { translate: var(--motion-loop-translate-x) var(--motion-loop-translate-y); } }
    @keyframes motion-translate-loop-reset { 0%  { translate: 0; } to { translate: var(--motion-loop-translate-x) var(--motion-loop-translate-y); } }
    @keyframes motion-rotate-in         { 0%  { rotate: var(--motion-origin-rotate); } to { rotate: 0; } }
    @keyframes motion-rotate-out        { 0%  { rotate: 0; } to { rotate: var(--motion-end-rotate); } }
    @keyframes motion-rotate-loop-mirror{ 0%, to { rotate: none; } 50% { rotate: var(--motion-loop-rotate); } }
    @keyframes motion-rotate-loop-reset { to  { rotate: var(--motion-loop-rotate); } }
}

/* ============================================================
   MOTION CSS CUSTOM PROPERTIES
   ============================================================ */
@layer properties {
    @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
        *, ::backdrop, :after, :before {
            --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-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-mask-linear: linear-gradient(#fff,#fff);
            --tw-mask-radial: linear-gradient(#fff,#fff);
            --tw-mask-conic: linear-gradient(#fff,#fff);
            --tw-mask-radial-from-position: 0%; --tw-mask-radial-to-position: 100%;
            --tw-mask-radial-from-color: black; --tw-mask-radial-to-color: transparent;
            --tw-mask-radial-shape: ellipse; --tw-mask-radial-size: farthest-corner;
            --tw-mask-radial-position: center;
            --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-outline-style: solid;
            --tw-blur: initial; --tw-brightness: initial; --tw-contrast: initial;
            --tw-grayscale: initial; --tw-hue-rotate: initial; --tw-invert: initial;
            --tw-opacity: initial; --tw-saturate: initial; --tw-sepia: initial;
            --tw-drop-shadow: initial; --tw-drop-shadow-color: initial; --tw-drop-shadow-alpha: 100%;
            --tw-drop-shadow-size: initial;
            --tw-backdrop-blur: initial; --tw-backdrop-brightness: initial;
            --tw-backdrop-contrast: initial; --tw-backdrop-grayscale: initial;
            --tw-backdrop-hue-rotate: initial; --tw-backdrop-invert: initial;
            --tw-backdrop-opacity: initial; --tw-backdrop-saturate: initial;
            --tw-backdrop-sepia: initial;
            --tw-duration: initial; --tw-ease: initial;
            --tw-animation-delay: 0s; --tw-animation-direction: normal;
            --tw-animation-duration: initial; --tw-animation-fill-mode: none;
            --tw-animation-iteration-count: 1;
            --tw-enter-blur: 0; --tw-enter-opacity: 1; --tw-enter-rotate: 0;
            --tw-enter-scale: 1; --tw-enter-translate-x: 0; --tw-enter-translate-y: 0;
            --tw-exit-blur: 0; --tw-exit-opacity: 1; --tw-exit-rotate: 0;
            --tw-exit-scale: 1; --tw-exit-translate-x: 0; --tw-exit-translate-y: 0;
        }
    }
}

/* Motion CSS @property declarations */
@property --motion-bounce { syntax: "*"; inherits: false; initial-value: linear(0,.004,.016,.035,.063,.098,.141 13.6%,.25,.391,.563,.765,1,.891 40.9%,.848,.813,.785,.766,.754,.75,.754,.766,.785,.813,.848,.891 68.2%,1 72.7%,.973,.953,.941,.938,.941,.953,.973,1,.988,.984,.988,1) }
@property --motion-spring-smooth { syntax: "*"; inherits: false; initial-value: linear(0,.001 .44%,.0045 .94%,.0195 2.03%,.0446 3.19%,.0811 4.5%,.1598 6.82%,.3685 12.34%,.4693 15.17%,.5663,.6498 21.27%,.7215 24.39%,.7532 25.98%,.7829 27.65%,.8105,.8349 31.14%,.8573 32.95%,.8776 34.84%,.8964 36.87%,.9136 39.05%,.929 41.37%,.9421 43.77%,.9537 46.38%,.9636 49.14%,.9789 55.31%,.9888 62.35%,.9949 71.06%,.9982 82.52%,.9997 99.94%) }
@property --motion-spring-snappy { syntax: "*"; inherits: false; initial-value: linear(0,.0014,.0053 1.02%,.0126,.0227 2.18%,.0517 3.41%,.094 4.79%,.1865 7.26%,.4182 12.77%,.5246 15.46%,.6249,.7112,.7831 23.95%,.8146 25.4%,.844,.8699 28.45%,.8935,.9139 31.64%,.932,.9473,.9601 36.65%,.9714 38.47%,.9808 40.35%,.9948 44.49%,1.0031 49.43%,1.0057 53.35%,1.0063 58.14%,1.0014 80.78%,1.0001 99.94%) }
@property --motion-spring-bouncy { syntax: "*"; inherits: false; initial-value: linear(0,.0018,.0069,.0151 1.74%,.0277 2.4%,.062 3.7%,.1115 5.15%,.2211 7.77%,.4778 13.21%,.5912 15.75%,.6987 18.44%,.7862 20.98%,.861 23.59%,.8926,.9205,.945 27.51%,.9671 28.89%,.9868,1.003 31.79%,1.0224 34.11%,1.0358 36.58%,1.0436 39.27%,1.046 42.31%,1.0446 44.71%,1.0406 47.47%,1.0118 61.84%,1.0027 69.53%,.9981 80.49%,.9991 99.94%) }
@property --motion-spring-bouncier { syntax: "*"; inherits: false; initial-value: linear(0,.0023,.0088,.0194 1.59%,.035 2.17%,.078 3.33%,.1415 4.64%,.2054 5.75%,.2821 6.95%,.5912 11.45%,.7205 13.43%,.8393 15.45%,.936 17.39%,.9778,1.015,1.0477,1.0759,1.0998 22.22%,1.1203,1.1364,1.1484 25.26%,1.1586 26.61%,1.1629 28.06%,1.1613 29.56%,1.1537 31.2%,1.1434 32.6%,1.1288 34.19%,1.0508 41.29%,1.0174 44.87%,1.0025 46.89%,.9911 48.87%,.9826 50.9%,.9769 53.03%,.9735 56.02%,.9748 59.45%,.9964 72.64%,1.0031 79.69%,1.0042 86.83%,1.0008 99.97%) }
@property --motion-spring-bounciest { syntax: "*"; inherits: false; initial-value: linear(0,.0032,.0131,.0294,.0524,.0824,.1192 1.54%,.2134 2.11%,.3102 2.59%,.4297 3.13%,.8732 4.95%,1.0373,1.1827 6.36%,1.2972 7.01%,1.3444,1.3859,1.4215,1.4504,1.4735,1.4908,1.5024,1.5084 9.5%,1.5091,1.5061,1.4993,1.4886,1.4745,1.4565 11.11%,1.4082 11.7%,1.3585 12.2%,1.295 12.77%,1.0623 14.64%,.9773,.9031 16.08%,.8449 16.73%,.8014,.7701 17.95%,.7587,.7501,.7443,.7412 19.16%,.7421 19.68%,.7508 20.21%,.7672 20.77%,.7917 21.37%,.8169 21.87%,.8492 22.43%,.9681 24.32%,1.0114,1.0492 25.75%,1.0789 26.41%,1.1008,1.1167,1.1271,1.1317 28.81%,1.1314,1.1271 29.87%,1.1189 30.43%,1.1063 31.03%,1.0769 32.11%,.9941 34.72%,.9748 35.43%,.9597 36.09%,.9487,.9407,.9355,.933 38.46%,.9344 39.38%,.9421 40.38%,.9566 41.5%,.9989 44.12%,1.0161 45.37%,1.029 46.75%,1.0341 48.1%,1.0335 49.04%,1.0295 50.05%,1.0221 51.18%,.992 55.02%,.9854 56.38%,.9827 57.72%,.985 59.73%,1.004 64.67%,1.0088 67.34%,1.0076 69.42%,.9981 74.28%,.9956 76.85%,.9961 79.06%,1.0023 86.46%,.999 95.22%,.9994 100%) }
@property --motion-origin-scale-x { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-origin-scale-y { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-origin-translate-x { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-origin-translate-y { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-origin-rotate { syntax: "*"; inherits: false; initial-value: 0deg }
@property --motion-origin-blur { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-origin-grayscale { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-origin-opacity { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-origin-background-color { syntax: "*"; inherits: false }
@property --motion-origin-text-color { syntax: "*"; inherits: false }
@property --motion-end-scale-x { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-end-scale-y { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-end-translate-x { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-end-translate-y { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-end-rotate { syntax: "*"; inherits: false; initial-value: 0deg }
@property --motion-end-blur { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-end-grayscale { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-end-opacity { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-end-background-color { syntax: "*"; inherits: false }
@property --motion-end-text-color { syntax: "*"; inherits: false }
@property --motion-loop-scale-x { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-loop-scale-y { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-loop-translate-x { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-loop-translate-y { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-loop-rotate { syntax: "*"; inherits: false; initial-value: 0deg }
@property --motion-loop-blur { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-loop-grayscale { syntax: "*"; inherits: false; initial-value: 0 }
@property --motion-loop-opacity { syntax: "*"; inherits: false; initial-value: 100% }
@property --motion-loop-background-color { syntax: "*"; inherits: false }
@property --motion-loop-text-color { syntax: "*"; inherits: false }
@property --motion-duration { syntax: "*"; inherits: false; initial-value: .7s }
@property --motion-timing { syntax: "*"; inherits: false; initial-value: cubic-bezier(.165,.84,.44,1) }
@property --motion-perceptual-duration-multiplier { syntax: "*"; inherits: false; initial-value: 1 }
@property --motion-delay { syntax: "*"; inherits: false; initial-value: 0s }
@property --motion-loop-count { syntax: "*"; inherits: false; initial-value: infinite }
@property --motion-scale-in-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-translate-in-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-rotate-in-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-filter-in-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-opacity-in-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-background-color-in-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-text-color-in-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-scale-out-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-translate-out-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-rotate-out-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-filter-out-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-opacity-out-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-background-color-out-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-text-color-out-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-scale-loop-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-translate-loop-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-rotate-loop-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-filter-loop-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-opacity-loop-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-background-color-loop-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-text-color-loop-animation { syntax: "*"; inherits: false; initial-value: none }
@property --motion-origin-scale-x { syntax: "*"; inherits: false; initial-value: 100% }
@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-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-mask-linear { syntax: "*"; inherits: false; initial-value: linear-gradient(#fff,#fff) }
@property --tw-mask-radial { syntax: "*"; inherits: false; initial-value: linear-gradient(#fff,#fff) }
@property --tw-mask-conic { syntax: "*"; inherits: false; initial-value: linear-gradient(#fff,#fff) }
@property --tw-mask-radial-from-position { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-mask-radial-to-position { syntax: "*"; inherits: false; initial-value: 100% }
@property --tw-mask-radial-from-color { syntax: "*"; inherits: false; initial-value: black }
@property --tw-mask-radial-to-color { syntax: "*"; inherits: false; initial-value: transparent }
@property --tw-mask-radial-shape { syntax: "*"; inherits: false; initial-value: ellipse }
@property --tw-mask-radial-size { syntax: "*"; inherits: false; initial-value: farthest-corner }
@property --tw-mask-radial-position { syntax: "*"; inherits: false; initial-value: center }
@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-outline-style { syntax: "*"; inherits: false; initial-value: solid }
@property --tw-blur { syntax: "*"; inherits: false }
@property --tw-brightness { syntax: "*"; inherits: false }
@property --tw-contrast { syntax: "*"; inherits: false }
@property --tw-grayscale { syntax: "*"; inherits: false }
@property --tw-hue-rotate { syntax: "*"; inherits: false }
@property --tw-invert { syntax: "*"; inherits: false }
@property --tw-opacity { syntax: "*"; inherits: false }
@property --tw-saturate { syntax: "*"; inherits: false }
@property --tw-sepia { syntax: "*"; inherits: false }
@property --tw-drop-shadow { syntax: "*"; inherits: false }
@property --tw-drop-shadow-color { syntax: "*"; inherits: false }
@property --tw-drop-shadow-alpha { syntax: "<percentage>"; inherits: false; initial-value: 100% }
@property --tw-drop-shadow-size { syntax: "*"; inherits: false }
@property --tw-backdrop-blur { syntax: "*"; inherits: false }
@property --tw-backdrop-brightness { syntax: "*"; inherits: false }
@property --tw-backdrop-contrast { syntax: "*"; inherits: false }
@property --tw-backdrop-grayscale { syntax: "*"; inherits: false }
@property --tw-backdrop-hue-rotate { syntax: "*"; inherits: false }
@property --tw-backdrop-invert { syntax: "*"; inherits: false }
@property --tw-backdrop-opacity { syntax: "*"; inherits: false }
@property --tw-backdrop-saturate { syntax: "*"; inherits: false }
@property --tw-backdrop-sepia { syntax: "*"; inherits: false }
@property --tw-duration { syntax: "*"; inherits: false }
@property --tw-ease { syntax: "*"; inherits: false }
@property --tw-animation-delay { syntax: "*"; inherits: false; initial-value: 0s }
@property --tw-animation-direction { syntax: "*"; inherits: false; initial-value: normal }
@property --tw-animation-duration { syntax: "*"; inherits: false }
@property --tw-animation-fill-mode { syntax: "*"; inherits: false; initial-value: none }
@property --tw-animation-iteration-count { syntax: "*"; inherits: false; initial-value: 1 }
@property --tw-enter-blur { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-enter-opacity { syntax: "*"; inherits: false; initial-value: 1 }
@property --tw-enter-rotate { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-enter-scale { syntax: "*"; inherits: false; initial-value: 1 }
@property --tw-enter-translate-x { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-enter-translate-y { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-exit-blur { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-exit-opacity { syntax: "*"; inherits: false; initial-value: 1 }
@property --tw-exit-rotate { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-exit-scale { syntax: "*"; inherits: false; initial-value: 1 }
@property --tw-exit-translate-x { syntax: "*"; inherits: false; initial-value: 0 }
@property --tw-exit-translate-y { syntax: "*"; inherits: false; initial-value: 0 }

/* ============================================================
   HEADER / NAVBAR
   ============================================================ */
#site-header {
    position: sticky;
    top: 2.5rem;
    z-index: 100;
    width: 100%;
    padding: 0 1rem;
}
@media (min-width: 640px) { #site-header { padding: 0 70px; } }

.header-wrapper { position: relative; }

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 80px;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-top: 1px solid rgba(255,255,255,0.2);
    border-bottom: 1px solid rgba(255,255,255,0.2);
    border-radius: 50px;
    color: #fff;
}
@media (max-width: 640px) { .header-inner { padding: 10px 20px; } }

/* Logo */
.site-logo { display: flex; align-items: center; gap: 8px; }
.site-logo svg { height: 36px; width: auto; }
.site-logo .logo-text { font-size: 1.25rem; font-weight: 700; color: #fff; }

/* Desktop Nav */
.header-nav {
    display: none;
    align-items: center;
    gap: 1.25rem;
    font-size: 0.875rem;
}
@media (min-width: 1280px) { .header-nav { display: flex; } }

.header-nav a { color: rgba(255,255,255,0.85); transition: color 0.15s; font-size: 0.9rem; }
.header-nav a:hover { color: #fff; opacity: 1; }

.nav-divider { width: 1px; height: 2rem; background: rgba(255,255,255,0.2); }

.btn-login {
    padding: 8px 16px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.2);
    background: transparent;
    color: #fff;
    font-size: 0.875rem;
    transition: background 0.15s;
}
.btn-login:hover { background: rgba(255,255,255,0.08); opacity: 1; }

.btn-signup {
    padding: 8px 16px;
    border-radius: 8px;
    background: var(--primary);
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    transition: opacity 0.15s;
}

/* Mobile Nav Toggle */
.mobile-menu-toggle {
    display: flex;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
}
@media (min-width: 1280px) { .mobile-menu-toggle { display: none; } }

.mobile-menu-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    transition: all 0.3s ease;
}

/* Mobile Dropdown */
.mobile-nav {
    display: none;
    position: absolute;
    top: calc(100% + 12px);
    left: 0;
    right: 0;
    background: rgba(31,33,39,0.97);
    backdrop-filter: blur(16px);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 1.5rem;
    flex-direction: column;
    gap: 1rem;
    margin: 0 1rem;
}
.mobile-nav.is-open { display: flex; }
.mobile-nav a { color: rgba(255,255,255,0.85); font-size: 1rem; padding: 8px 0; border-bottom: 1px solid var(--border); }
.mobile-nav a:last-child { border-bottom: none; }

/* ============================================================
   HERO SECTION
   ============================================================ */
#hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 100%;
    min-height: 90vh;
    padding: 40px 1rem;
    color: #fff;
    gap: 2.5rem;
}

.hero-content { display: flex; flex-direction: column; gap: 1.5rem; }

.hero-title {
    /*font-size: clamp(3.5rem, 9vw, 5rem);*/
	font-size: clamp(2.5rem, 3vw, 4rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.03em;
    background: linear-gradient(135deg, #ffffff 0%, rgba(255,255,255,0.7) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero-desc {
    font-size: clamp(1rem, 2vw, 1.15rem);
    color: var(--muted);
    max-width: 640px;
    margin: 0 auto;
    line-height: 1.8;
}

.hero-buttons {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
}

.btn-primary {
    background: var(--primary);
    color: #fff;
    padding: 10px 24px;
    border-radius: 12px;
    font-size: 1rem;
    font-weight: 600;
    border: none;
    transition: opacity 0.15s;
    display: inline-block;
}
.btn-primary:hover { opacity: 0.85; }

.btn-secondary {
    background: linear-gradient(135deg, #31394f, rgba(255,255,255,0.05));
    color: #fff;
    padding: 10px 24px;
    border-radius: 12px;
    font-size: 1rem;
    font-weight: 500;
    border: 1px solid rgba(255,255,255,0.2);
    width: 180px;
    text-align: center;
    transition: opacity 0.15s;
    display: inline-block;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.btn-secondary:hover { opacity: 0.85; }

/* ============================================================
   SCROLL IMAGES / CAROUSEL SECTION
   ============================================================ */
#scroll-images {
    min-height: 80vh;
    display: flex;
    align-items: center;
    width: 100%;
    padding: 60px 0;
}

.carousel-wrapper { width: 100%; overflow: hidden; position: relative; }

.carousel-track {
    display: flex;
    transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
}

.carousel-slide {
    min-width: 100%;
    display: flex;
    align-items: center;
    gap: 2.5rem;
    flex-direction: column;
    padding: 0 1rem;
}
@media (min-width: 1024px) { .carousel-slide { flex-direction: row; } }

.carousel-slide img {
    border-radius: 1.5rem;
    width: 100%;
    max-width: 850px;
    object-fit: cover;
    box-shadow: 0 24px 80px rgba(0,0,0,0.4);
}

.carousel-text h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); font-weight: 700; color: #fff; margin-bottom: 0.5rem; }
.carousel-text .slide-desc { font-size: 0.875rem; color: #6b7280; margin-bottom: 1rem; text-transform: capitalize; }
.carousel-text p { font-size: 1rem; color: rgba(255,255,255,0.75); line-height: 1.8; }

.carousel-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-top: 2rem;
}

.carousel-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.08);
    color: #fff;
    font-size: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.15s;
}
.carousel-btn:hover { background: rgba(255,255,255,0.18); }

.carousel-dots { display: flex; gap: 8px; align-items: center; }

.carousel-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,0.25);
    cursor: pointer;
    transition: background 0.2s;
    border: none;
    padding: 0;
}
.carousel-dot.active { background: var(--primary); width: 24px; border-radius: 4px; }

/* ============================================================
   FEATURES SECTION — "Why Choose Us"
   ============================================================ */
#why-choose-us { padding: 100px 0; position: relative; overflow: visible; }

.features-header { text-align: center; margin-bottom: 3rem; display: flex; flex-direction: column; gap: 0.75rem; }
.features-header .subtitle { font-size: 1.1rem; font-weight: 600; color: var(--primary); text-transform: uppercase; letter-spacing: 0.08em; }
.features-header h2 { font-size: clamp(1.75rem, 4vw, 2.5rem); font-weight: 800; color: #fff; }
.features-header p { color: var(--muted); max-width: 640px; margin: 0 auto; line-height: 1.8; }

.feature-top {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.5rem;
    margin-bottom: 2.5rem;
}

.feature-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border-radius: 50px;
    background: rgba(84,115,193,0.2);
    color: var(--primary);
    font-size: 1.125rem;
    font-weight: 700;
    margin-bottom: 1rem;
    flex-shrink: 0;
}

.features-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem 2rem;
    align-items: center;
    margin: 2.5rem 0;
}
@media (min-width: 1024px) { .features-grid { grid-template-columns: 1fr auto 1fr; } }

.features-left, .features-right { display: flex; flex-direction: column; gap: 3rem; }

.feature-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.5rem;
}
@media (min-width: 1024px) { 
	.features-left .feature-item { 
		align-items: flex-start; text-align: left; 
	} 
	.features-right .feature-item { 
		align-items: flex-end; text-align: right; 
	} 
}

.feature-item h3 { font-size: 1.1rem; font-weight: 700; color: #fff; }
.feature-item p  { color: var(--muted); font-size: 0.875rem; line-height: 1.7; }

/* Center logo — dotted glow */
.features-center-logo { display: flex; align-items: center; justify-content: center; position: relative; }

.center-logo-glow {
    position: relative;
    width: 280px;
    height: 280px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.center-logo-glow::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(84,115,193,0.25) 0%, transparent 70%);
    animation: pulse 3s ease-in-out infinite;
}
.center-logo-glow::after {
    content: '';
    position: absolute;
    inset: 20px;
    border-radius: 50%;
    border: 1px dashed rgba(84,115,193,0.4);
    animation: spin 20s linear infinite;
}
.center-logo-glow .logo-ring {
    position: absolute;
    inset: 40px;
    border-radius: 50%;
    border: 1px dashed rgba(84,115,193,0.25);
    animation: spinReverse 30s linear infinite;
}
.center-logo-inner {
    position: relative;
    z-index: 1;
    width: 100px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(8px);
}

.feature-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.5rem;
    margin-top: 2.5rem;
    padding: 2rem;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border);
    border-radius: 16px;
}

/* ============================================================
   FUNCTIONALITIES SECTION
   ============================================================ */
#functionalities { padding: 100px 0; text-align: center; }

.func-header { margin-bottom: 5rem; display: flex; flex-direction: column; gap: 0.75rem; }
.func-header h2 { font-size: clamp(1.75rem, 4vw, 2.25rem); font-weight: 800; color: #fff; }
.func-header p { color: var(--muted); }

.func-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 3rem 3rem;
}
@media (min-width: 1280px) { .func-grid { justify-content: center; } }

.func-card {
    position: relative;
    width: 100%;
    max-width: 280px;
    height: 280px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 10px;
    padding: 20px 20px 20px 43px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 0.75rem;
    text-align: left;
    cursor: pointer;
    transition: transform 0.2s ease, opacity 0.2s ease, box-shadow 0.2s ease;
}
.func-card:hover { transform: scale(1.01); opacity: 0.95; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }

.func-icon {
    position: absolute;
    top: -28px;
    left: -28px;
    width: 86px;
    height: 86px;
    border-radius: 50%;
    background: linear-gradient(135deg, #20273b, rgba(255,255,255,0.2));
    backdrop-filter: blur(3px);
    border: 1.5px solid rgba(255,255,255,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    transition: transform 0.2s;
}
.func-card:hover .func-icon { transform: scale(1.05); }

.func-card h3 { font-size: 1.05rem; font-weight: 700; color: #fff; }
.func-card p  { font-size: 0.8rem; color: var(--muted); line-height: 1.6; }

/* ============================================================
   CTA SECTION
   ============================================================ */
#join {
    min-height: 50vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 80px 1rem;
    gap: 1rem;
}
#join h2 { font-size: clamp(1.75rem, 4vw, 2.25rem); font-weight: 800; color: #fff; }
#join p   { font-size: 1.125rem; color: var(--muted); max-width: 500px; margin: 0 auto; }

.btn-join {
    background: linear-gradient(135deg, rgba(84,115,193,0.2), rgba(255,255,255,0.1));
    color: #fff;
    padding: 10px 24px;
    border-radius: 12px;
    font-size: 1rem;
    border: 1px solid rgba(255,255,255,0.2);
    width: 180px;
    text-align: center;
    margin-top: 2.5rem;
    display: inline-block;
    transition: opacity 0.15s;
    backdrop-filter: blur(8px);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.btn-join:hover { opacity: 0.85; }

/* ============================================================
   FOOTER
   ============================================================ */
#colophon {
    background: #232a3f;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2.5rem;
    padding: 66px 1rem;
    text-align: center;
}

.footer-nav { display: flex; gap: 2.5rem; flex-wrap: wrap; justify-content: center; }
.footer-nav a { font-size: 0.875rem; color: rgba(255,255,255,0.75); }
.footer-nav a:hover { color: #fff; opacity: 1; }

.footer-copy { font-size: 0.8rem; color: rgba(255,255,255,0.4); }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-page-wrap { min-height: 100vh; padding: 0.75rem; }

.contact-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 80px;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(255,255,255,0.2);
    border-bottom: 1px solid rgba(255,255,255,0.2);
    border-radius: 50px;
    color: #fff;
}
@media (max-width: 640px) { .contact-header-inner { padding: 10px 20px; } }

.back-link { display: flex; align-items: center; gap: 4px; font-size: 0.875rem; font-weight: 600; color: #fff; transition: gap 0.15s; }
.back-link:hover { gap: 8px; opacity: 1; }

.contact-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-around;
    padding: 2.5rem;
    min-height: calc(100vh - 80px);
    gap: 3rem;
}
@media (min-width: 1024px) { .contact-body { flex-direction: row; } }

.contact-logo-wrap { display: none; }
@media (min-width: 1024px) { .contact-logo-wrap { display: block; } }

/* Form */
.contact-form-section { width: 100%; max-width: 36rem; }

.form-title-block { margin-bottom: 2rem; }
.form-title-block h1 { font-size: 2.25rem; font-weight: 800; color: #fff; margin-bottom: 0.5rem; }
.form-title-block p  { color: var(--muted); }

.contact-form { display: flex; flex-direction: column; gap: 1.5rem; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 640px) { .form-row { grid-template-columns: 1fr; } }

.form-group { display: flex; flex-direction: column; gap: 0.5rem; }

.form-label { font-size: 0.875rem; font-weight: 500; color: rgba(255,255,255,0.85); }

.form-input,
.form-textarea,
.form-select {
    background: var(--input);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 10px 12px;
    color: #fff;
    font-family: var(--font-sans);
    font-size: 0.9rem;
    width: 100%;
    transition: border-color 0.15s, box-shadow 0.15s;
    outline: none;
    appearance: none;
}
.form-input:focus,
.form-textarea:focus,
.form-select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 2px rgba(84,115,193,0.25);
}
.form-input::placeholder,
.form-textarea::placeholder { color: rgba(255,255,255,0.3); }

.form-textarea { resize: vertical; min-height: 120px; }
.form-select option { background: #1f2127; color: #fff; }

.select-wrapper { position: relative; }
.select-wrapper::after {
    content: '▾';
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: rgba(255,255,255,0.5);
    pointer-events: none;
    font-size: 0.875rem;
}

.form-submit-row { display: flex; justify-content: flex-end; }

.btn-send {
    background: linear-gradient(135deg, rgba(84,115,193,0.2), rgba(255,255,255,0.1));
    color: #fff;
    padding: 10px 24px;
    border-radius: 12px;
    font-size: 0.875rem;
    border: 1px solid rgba(255,255,255,0.2);
    width: 180px;
    text-align: center;
    cursor: pointer;
    transition: opacity 0.15s;
    backdrop-filter: blur(8px);
    margin-top: 2.5rem;
    font-family: var(--font-sans);
    font-weight: 500;
}
.btn-send:hover { opacity: 0.8; }
.btn-send:disabled { opacity: 0.5; cursor: not-allowed; }

/* Toast Notification */
.toast-container {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.toast {
    padding: 12px 20px;
    border-radius: 10px;
    font-size: 0.875rem;
    color: #fff;
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
    animation: toastIn 0.3s ease forwards;
    max-width: 320px;
    border: 1px solid rgba(255,255,255,0.15);
}
.toast.success { background: #166534; border-color: rgba(34,197,94,0.4); }
.toast.error   { background: #7f1d1d; border-color: rgba(239,68,68,0.4); }
.toast-title   { font-weight: 600; margin-bottom: 4px; }
.toast-desc    { color: rgba(255,255,255,0.7); }

/* ============================================================
   MODALS — Terms & Privacy
   ============================================================ */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.7);
    z-index: 9999;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s;
}
.modal-overlay.is-open { opacity: 1; pointer-events: all; }
@media (min-width: 640px) { .modal-overlay { align-items: center; } }

.modal-content {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 24px 24px 0 0;
    width: 100%;
    max-width: 720px;
    max-height: 80vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transform: translateY(30px);
    transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
}
@media (min-width: 640px) { .modal-content { border-radius: 24px; transform: scale(0.96); } }
.modal-overlay.is-open .modal-content { transform: translateY(0); }
@media (min-width: 640px) { .modal-overlay.is-open .modal-content { transform: scale(1); } }

.modal-header { padding: 1.5rem 2rem 1rem; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.modal-header h2 { font-size: 1.25rem; font-weight: 700; color: #fff; }
.modal-header p  { font-size: 0.75rem; color: var(--muted); margin-top: 4px; }

.modal-body {
    overflow-y: auto;
    padding: 2rem;
    flex: 1;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}

.modal-close {
    position: absolute;
    top: 1.25rem;
    right: 1.25rem;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    border: 1px solid var(--border);
    color: #fff;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.15s;
}
.modal-close:hover { background: rgba(255,255,255,0.15); }

.modal-section { margin-bottom: 2rem; }
.modal-section h3 {
    font-size: 1.1rem;
    font-weight: 600;
    color: #fff;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(255,255,255,0.15);
    margin-bottom: 0.75rem;
    display: inline-block;
}
.modal-section p {
    color: rgba(255,255,255,0.7);
    font-weight: 300;
    line-height: 1.8;
    white-space: pre-line;
    font-size: 0.9rem;
}

/* ============================================================
   HELP / TIMELINE PAGE
   ============================================================ */
.timeline-page { padding: 80px 1rem; }

.timeline-container { max-width: 900px; margin: 0 auto; display: flex; flex-direction: column; gap: 3rem; }

.timeline-item { display: flex; gap: 2rem; align-items: flex-start; }

.timeline-badge {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(84,115,193,0.2);
    border: 2px solid var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.125rem;
    color: var(--primary);
    flex-shrink: 0;
}

.timeline-text h3 { font-size: 1.25rem; font-weight: 700; color: #fff; margin-bottom: 0.5rem; }
.timeline-text p  { color: var(--muted); line-height: 1.7; }

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */
.slide-up { opacity: 0; transform: translateY(32px); transition: opacity 0.6s ease, transform 0.6s ease; }
.slide-up.visible { opacity: 1; transform: translateY(0); }

/* ============================================================
   PRIVACY POLICY & TERMS PAGES
   ============================================================ */
.legal-page { padding: 80px 1rem; max-width: 800px; margin: 0 auto; }
.legal-page h1 { font-size: 2rem; font-weight: 800; margin-bottom: 2rem; }

/* ============================================================
   TAILWIND UTILITY CLASSES
   ============================================================ */
.pointer-events-none { pointer-events: none }
.visible { visibility: visible }
.sr-only { clip-path: inset(50%); white-space: nowrap; border-width: 0; width: 1px; height: 1px; margin: -1px; padding: 0; overflow: hidden; position: absolute; }
.absolute { position: absolute }
.fixed { position: fixed }
.relative { position: relative }
.sticky { position: sticky }
.inset-0 { inset: 0 }
.inset-x-0 { inset-inline: 0 }
.inset-y-0 { inset-block: 0 }
.-top-7 { top: calc(var(--spacing)*-7) }
.-top-12 { top: calc(var(--spacing)*-12) }
.-top-\[100vh\] { top: -100vh }
.top-0 { top: 0 }
.top-4 { top: calc(var(--spacing)*4) }
.top-10 { top: calc(var(--spacing)*10) }
.top-full { top: 100% }
.right-0 { right: 0 }
.right-2 { right: calc(var(--spacing)*2) }
.right-4 { right: calc(var(--spacing)*4) }
.right-10 { right: calc(var(--spacing)*10) }
.-bottom-12 { bottom: calc(var(--spacing)*-12) }
.bottom-0 { bottom: 0 }
.-left-7 { left: calc(var(--spacing)*-7) }
.left-0 { left: 0 }
.left-1\/2 { left: 50% }
.left-10 { left: calc(var(--spacing)*10) }
.-z-10 { z-index: -10 }
.-z-20 { z-index: -20 }
.z-20 { z-index: 20 }
.z-50 { z-index: 50 }
.z-\[2\] { z-index: 2 }
.z-\[3\] { z-index: 3 }
.m-auto { margin: auto }
.-mx-1 { margin-inline: calc(var(--spacing)*-1) }
.mx-auto { margin-inline: auto }
.my-1 { margin-block: calc(var(--spacing)*1) }
.-mt-4 { margin-top: calc(var(--spacing)*-4) }
.mt-4 { margin-top: calc(var(--spacing)*4) }
.mt-5 { margin-top: calc(var(--spacing)*5) }
.mt-8 { margin-top: calc(var(--spacing)*8) }
.mt-10 { margin-top: calc(var(--spacing)*10) }
.mt-auto { margin-top: auto }
.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-8 { margin-bottom: calc(var(--spacing)*8) }
.-ml-4 { margin-left: calc(var(--spacing)*-4) }
.block { display: block }
.flex { display: flex }
.grid { display: grid }
.hidden { display: none }
.inline-block { display: inline-block }
.inline-flex { display: inline-flex }
.field-sizing-content { field-sizing: content }
.size-3\.5 { width: calc(var(--spacing)*3.5); height: calc(var(--spacing)*3.5) }
.size-4 { width: calc(var(--spacing)*4); height: calc(var(--spacing)*4) }
.size-8 { width: calc(var(--spacing)*8); height: calc(var(--spacing)*8) }
.size-9 { width: calc(var(--spacing)*9); height: calc(var(--spacing)*9) }
.size-10 { width: calc(var(--spacing)*10); height: calc(var(--spacing)*10) }
.size-30 { width: calc(var(--spacing)*30); height: calc(var(--spacing)*30) }
.size-50 { width: calc(var(--spacing)*50); height: calc(var(--spacing)*50) }
.size-60 { width: calc(var(--spacing)*60); height: calc(var(--spacing)*60) }
.size-100 { width: calc(var(--spacing)*100); height: calc(var(--spacing)*100) }
.size-full { width: 100%; height: 100% }
.h-2 { height: calc(var(--spacing)*2) }
.h-2\.5 { height: calc(var(--spacing)*2.5) }
.h-5 { height: calc(var(--spacing)*5) }
.h-7 { height: calc(var(--spacing)*7) }
.h-8 { height: calc(var(--spacing)*8) }
.h-9 { height: calc(var(--spacing)*9) }
.h-10 { height: calc(var(--spacing)*10) }
.h-100 { height: calc(var(--spacing)*100) }
.h-\[50px\] { height: 50px }
.h-\[50svh\] { height: 50svh }
.h-\[86px\] { height: 86px }
.h-\[90lvh\] { height: 90lvh }
.h-\[120lvh\] { height: 120lvh }
.h-\[200vh\] { height: 200vh }
.h-\[280px\] { height: 280px }
.h-\[var\(--radix-select-trigger-height\)\] { height: var(--radix-select-trigger-height) }
.h-auto { height: auto }
.h-fit { height: fit-content }
.h-full { height: 100% }
.h-lvh { height: 100lvh }
.h-px { height: 1px }
.max-h-\(--radix-select-content-available-height\) { max-height: var(--radix-select-content-available-height) }
.min-h-16 { min-height: calc(var(--spacing)*16) }
.min-h-\[50svh\] { min-height: 50svh }
.min-h-lvh { min-height: 100lvh }
.min-h-svh { min-height: 100svh }
.w-2\.5 { width: calc(var(--spacing)*2.5) }
.w-3\/4 { width: 75% }
.w-5 { width: calc(var(--spacing)*5) }
.w-7 { width: calc(var(--spacing)*7) }
.w-\[1px\] { width: 1px; margin-left: 40px; }
.w-\[50px\] { width: 50px }
.w-\[86px\] { width: 86px }
.w-\[100px\] { width: 100px }
.w-\[180px\] { width: 180px }
.w-auto { width: auto }
.w-fit { width: fit-content }
.w-full { width: 100% }
.max-w-sm { max-width: var(--container-sm) }
.min-w-0 { min-width: 0 }
.min-w-\[8rem\] { min-width: 8rem }
.min-w-\[var\(--radix-select-trigger-width\)\] { min-width: var(--radix-select-trigger-width) }
.flex-1 { flex: 1 }
.shrink-0 { flex-shrink: 0 }
.grow-0 { flex-grow: 0 }
.basis-full { flex-basis: 100% }
.origin-\(--radix-select-content-transform-origin\) { transform-origin: var(--radix-select-content-transform-origin) }
.origin-bottom { transform-origin: bottom }
.-translate-x-1\/2 { --tw-translate-x: -50%; translate: var(--tw-translate-x) var(--tw-translate-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-30 { rotate: 30deg }
.rotate-90 { rotate: 90deg }
.transform { transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,) }
.animate-pulse { animation: var(--animate-pulse) }
.animate-spin { animation: var(--animate-spin) }
.cursor-default { cursor: default }
.cursor-pointer { cursor: pointer }
.touch-none { touch-action: none }
.resize { resize: both }
.scroll-my-1 { scroll-margin-block: calc(var(--spacing)*1) }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)) }
.flex-col { flex-direction: column }
.flex-col-reverse { flex-direction: column-reverse }
.flex-wrap { flex-wrap: wrap }
.items-center { align-items: center }
.items-end { align-items: flex-end }
.justify-around { justify-content: space-around }
.justify-between { justify-content: space-between }
.justify-center { justify-content: center }
.justify-end { justify-content: flex-end }
.justify-evenly { justify-content: space-evenly }
.gap-0\.5 { gap: calc(var(--spacing)*.5) }
.gap-1 { gap: calc(var(--spacing)*1) }
.gap-1\.5 { gap: calc(var(--spacing)*1.5) }
.gap-2 { gap: calc(var(--spacing)*2) }
.gap-3 { gap: calc(var(--spacing)*3) }
.gap-4 { gap: calc(var(--spacing)*4) }
.gap-5 { gap: calc(var(--spacing)*5) }
.gap-6 { gap: calc(var(--spacing)*6) }
.gap-10 { gap: calc(var(--spacing)*10) }
.gap-30 { gap: calc(var(--spacing)*30) }
.gap-\[39px\] { gap: 39px }
.gap-\[62px\] { gap: 62px }
: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))) }
:where(.space-y-10>:not(:last-child)) { --tw-space-y-reverse: 0; margin-block-start: calc(calc(var(--spacing)*10)*var(--tw-space-y-reverse)); margin-block-end: calc(calc(var(--spacing)*10)*calc(1 - var(--tw-space-y-reverse))) }
.overflow-hidden { overflow: hidden }
.overflow-x-hidden { overflow-x: hidden }
.overflow-y-auto { overflow-y: auto }
.rounded-3xl { border-radius: var(--radius-3xl) }
.rounded-\[8px\] { border-radius: 8px }
.rounded-\[10px\] { border-radius: 10px }
.rounded-\[12px\] { border-radius: 12px }
.rounded-\[50px\] { border-radius: 50px }
.rounded-\[86px\] { border-radius: 86px }
.rounded-\[600px\] { border-radius: 600px }
.rounded-\[inherit\] { border-radius: inherit }
.rounded-full { border-radius: 3.40282e+38px }
.rounded-lg { border-radius: var(--radius) }
.rounded-md { border-radius: calc(var(--radius) - 2px) }
.rounded-sm { border-radius: calc(var(--radius) - 4px) }
.rounded-xs { border-radius: var(--radius-xs) }
.border { border-style: var(--tw-border-style); border-width: 1px }
.border-\[0\.5px\] { border-style: var(--tw-border-style); border-width: .5px }
.border-x-\[1\.5px\] { border-inline-style: var(--tw-border-style); border-inline-width: 1.5px }
.border-y { border-block-style: var(--tw-border-style); border-block-width: 1px }
.border-t { border-top-style: var(--tw-border-style); border-top-width: 1px }
.border-r { border-right-style: var(--tw-border-style); border-right-width: 1px }
.border-b { border-bottom-style: var(--tw-border-style); border-bottom-width: 1px }
.border-l { border-left-style: var(--tw-border-style); border-left-width: 1px }
.border-input { border-color: var(--input) }
.border-white { border-color: var(--color-white) }
.border-white\/20 { border-color: #fff3 }
.border-white\/30 { border-color: #ffffff4d }
.border-y-white\/20 { border-block-color: #fff3 }
.border-t-transparent { border-top-color: transparent }
.border-l-transparent { border-left-color: transparent }
.bg-\[\#232a3f\] { background-color: #232a3f }
.bg-\[\#5473C1\] { background-color: #5473c1 }
.bg-\[\#5473C1\]\/5 { background-color: oklab(56.8735% -.0084632 -.125761/.05) }
.bg-\[\#5473C1\]\/8 { background-color: oklab(56.8735% -.0084632 -.125761/.08) }
.bg-\[\#5473C1\]\/10 { background-color: oklab(56.8735% -.0084632 -.125761/.1) }
.bg-\[\#5473C133\] { background-color: #5473c133 }
.bg-\[\#17181D\] { background-color: #17181d }
.bg-\[\#FFFFFF1A\] { background-color: #ffffff1a }
.bg-background { background-color: var(--background) }
.bg-black\/50 { background-color: #00000080 }
.bg-border { background-color: var(--border) }
.bg-neutral-800 { background-color: var(--color-neutral-800) }
.bg-primary { background-color: var(--primary) }
.bg-secondary { background-color: var(--secondary) }
.bg-transparent { background-color: transparent }
.bg-white { background-color: var(--color-white) }
.bg-white\/10 { background-color: #ffffff1a }
.bg-white\/20 { background-color: #fff3 }
.bg-gradient-to-br { --tw-gradient-position: to bottom right in oklab; background-image: linear-gradient(var(--tw-gradient-stops)) }
.bg-radial { --tw-gradient-position: in oklab; background-image: radial-gradient(var(--tw-gradient-stops)) }
.from-\[\#5473C133\] { --tw-gradient-from: #5473c133; --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-\[\#20273b\] { --tw-gradient-from: #20273b; --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-\[\#31394f\] { --tw-gradient-from: #31394f; --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-\[\#42598f\] { --tw-gradient-from: #42598f; --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-10\% { --tw-gradient-from-position: 10% }
.to-\[\#17181D\] { --tw-gradient-to: #17181d; --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-white\/5 { --tw-gradient-to: #ffffff0d; --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-white\/10 { --tw-gradient-to: #ffffff1a; --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-white\/20 { --tw-gradient-to: #fff3; --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)) }
.mask-radial-from-20\%, .mask-radial-to-90\% { -webkit-mask-image: var(--tw-mask-linear), var(--tw-mask-radial), var(--tw-mask-conic); mask-image: var(--tw-mask-linear), var(--tw-mask-radial), var(--tw-mask-conic); -webkit-mask-composite: source-in; mask-composite: intersect }
.mask-radial-from-20\% { --tw-mask-radial-stops: var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), var(--tw-mask-radial-from-color) var(--tw-mask-radial-from-position), var(--tw-mask-radial-to-color) var(--tw-mask-radial-to-position); --tw-mask-radial: radial-gradient(var(--tw-mask-radial-stops)); --tw-mask-radial-from-position: 20% }
.mask-radial-to-90\% { --tw-mask-radial-stops: var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), var(--tw-mask-radial-from-color) var(--tw-mask-radial-from-position), var(--tw-mask-radial-to-color) var(--tw-mask-radial-to-position); --tw-mask-radial: radial-gradient(var(--tw-mask-radial-stops)); --tw-mask-radial-to-position: 90% }
.mask-radial-at-center { --tw-mask-radial-position: center }
.mask-radial-at-top { --tw-mask-radial-position: top }
.object-cover { object-fit: cover }
.object-center { object-position: center }
.p-1 { padding: calc(var(--spacing)*1) }
.p-3 { padding: calc(var(--spacing)*3) }
.p-4 { padding: calc(var(--spacing)*4) }
.p-5 { padding: calc(var(--spacing)*5) }
.p-10 { padding: calc(var(--spacing)*10) }
.p-\[10px\] { padding: 10px }
.p-\[17px\] { padding: 17px }
.p-\[20px\] { padding: 20px }
.p-px { padding: 1px }
.px-0 { padding-inline: 0 }
.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-\[16px\] { padding-inline: 16px }
.px-\[24px\] { padding-inline: 24px }
.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-4 { padding-block: calc(var(--spacing)*4) }
.py-20 { padding-block: calc(var(--spacing)*20) }
.py-\[8px\] { padding-block: 8px }
.py-\[10px\] { padding-block: 10px }
.py-\[66px\] { padding-block: 66px }
.pt-4 { padding-top: calc(var(--spacing)*4) }
.pt-12 { padding-top: calc(var(--spacing)*12) }
.pt-20 { padding-top: calc(var(--spacing)*20) }
.pt-30 { padding-top: calc(var(--spacing)*30) }
.pt-40 { padding-top: calc(var(--spacing)*40) }
.pt-\[43px\] { padding-top: 43px }
.pr-8 { padding-right: calc(var(--spacing)*8) }
.pl-2 { padding-left: calc(var(--spacing)*2) }
.pl-4 { padding-left: calc(var(--spacing)*4) }
.pl-\[43px\] { padding-left: 43px }
.text-center { text-align: center }
.text-start { text-align: start }
.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-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)) }
.leading-none { --tw-leading: 1; line-height: 1 }
.font-\[200\] { --tw-font-weight: 200; font-weight: 200 }
.font-\[300\] { --tw-font-weight: 300; font-weight: 300 }
.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-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-wide { --tw-tracking: var(--tracking-wide); letter-spacing: var(--tracking-wide) }
.text-pretty { text-wrap: pretty }
.whitespace-nowrap { white-space: nowrap }
.whitespace-pre-line { white-space: pre-line }
.text-\[\#5473C1\] { color: #5473c1 }
.text-\[\#B2B2B2\] { color: #b2b2b2 }
.text-black { color: var(--color-black) }
.text-foreground { color: var(--foreground) }
.text-gray-500 { color: var(--color-gray-500) }
.text-neutral-300 { color: var(--color-neutral-300) }
.text-neutral-400 { color: var(--color-neutral-400) }
.text-neutral-500 { color: var(--color-neutral-500) }
.text-primary { color: var(--primary) }
.text-primary-foreground { color: var(--primary-foreground) }
.text-secondary-foreground { color: var(--secondary-foreground) }
.text-white { color: var(--color-white) }
.capitalize { text-transform: capitalize }
.underline-offset-4 { text-underline-offset: 4px }
.antialiased { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale }
.opacity-40 { opacity: .4 }
.opacity-50 { opacity: .5 }
.opacity-70 { opacity: .7 }
.opacity-600 { opacity: 1 }
.shadow-2xs { --tw-shadow: 0 1px var(--tw-shadow-color, #0000000d); 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-xs { --tw-shadow: 0 1px 2px 0 var(--tw-shadow-color, #0000000d); box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow) }
.shadow\/glow { --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a); box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow) }
.shadow-white\/20 { --tw-shadow-color: #fff3 }
@supports (color: color-mix(in lab, red, red)) {
    .shadow-white\/20 { --tw-shadow-color: color-mix(in oklab, color-mix(in oklab, var(--color-white) 20%, transparent) var(--tw-shadow-alpha), transparent) }
}
.ring-offset-background { --tw-ring-offset-color: var(--background) }
.outline-hidden { --tw-outline-style: none; outline-style: none }
@media (forced-colors: active) { .outline-hidden { outline-offset: 2px; outline: 2px solid transparent } }
.outline { outline-style: var(--tw-outline-style); outline-width: 1px }
.blur-2xl { --tw-blur: blur(var(--blur-2xl)); 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-3xl { --tw-backdrop-blur: blur(var(--blur-3xl)); -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,); backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,) }
.backdrop-blur-\[3px\] { --tw-backdrop-blur: blur(3px); -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,); backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,) }
.backdrop-blur-\[8px\] { --tw-backdrop-blur: blur(8px); -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,); backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,) }
.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-\[color\,box-shadow\] { transition-property: color, box-shadow; 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)) }
.delay-150 { transition-delay: .15s; --tw-animation-delay: .15s; animation-delay: .15s }
.duration-150 { --tw-duration: .15s; transition-duration: .15s }
.duration-200 { --tw-duration: .2s; transition-duration: .2s }
.duration-300 { --tw-duration: .3s; transition-duration: .3s }
.duration-400 { --tw-duration: .4s; transition-duration: .4s }
.ease-in-out { --tw-ease: var(--ease-in-out); transition-timing-function: var(--ease-in-out) }
.will-change-transform { will-change: transform }
.outline-none { --tw-outline-style: none; outline-style: none }
.select-all { -webkit-user-select: all; user-select: all }
.select-none { -webkit-user-select: none; user-select: none }
.\[animation-fill-mode\:none\] { animation-fill-mode: none }
.\[background\:radial-gradient\(100\%_120\%_at_50\%_-10\%\,\#42598f_25\%\,\#17181D_90\%\)\] { background: radial-gradient(100% 120% at 50% -10%, #42598f 25%, #17181d 90%) }
.motion-delay-150 { --motion-delay: .15s }
.motion-delay-160 { --motion-delay: .16s }

/* ============================================================
   INTERACTIVE / HOVER / STATE UTILITIES
   ============================================================ */
@media (hover: hover) {
    .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\/button\:-rotate-12:is(:where(.group\/button):hover *) { rotate: -12deg }
    .group-hover\/button\:rotate-12:is(:where(.group\/button):hover *) { rotate: 12deg }
    .hover\:scale-101:hover { --tw-scale-x: 101%; --tw-scale-y: 101%; --tw-scale-z: 101%; scale: var(--tw-scale-x) var(--tw-scale-y) }
    .hover\:gap-2:hover { gap: calc(var(--spacing)*2) }
    .hover\:bg-primary\/90:hover { background-color: color-mix(in oklab, var(--primary) 90%, transparent) }
    .hover\:bg-secondary\/80:hover { background-color: color-mix(in oklab, var(--secondary) 80%, transparent) }
    .hover\:from-\[\#5473C133\]:hover { --tw-gradient-from: #5473c133; --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-white\/10:hover { --tw-gradient-to: #ffffff1a; --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\:underline:hover { text-decoration-line: underline }
    .hover\:opacity-80:hover { opacity: .8 }
    .hover\:opacity-95:hover { opacity: .95 }
    .hover\:opacity-100:hover { opacity: 1 }
    .hover\:shadow-gray-400\/10:hover { --tw-shadow-color: color-mix(in oklab, color-mix(in oklab, var(--color-gray-400) 10%, transparent) var(--tw-shadow-alpha), transparent) }
    .dark\:hover\:bg-input\/50:hover { background-color: color-mix(in oklab, var(--input) 50%, transparent) }
}

.group-data-\[disabled\=true\]\:pointer-events-none:is(:where(.group)[data-disabled=true] *) { pointer-events: none }
.group-data-\[disabled\=true\]\:opacity-50:is(:where(.group)[data-disabled=true] *) { opacity: .5 }
.group-data-\[vaul-drawer-direction\=bottom\]\/drawer-content\:block:is(:where(.group\/drawer-content)[data-vaul-drawer-direction=bottom] *) { display: block }
.group-data-\[vaul-drawer-direction\=bottom\]\/drawer-content\:text-center:is(:where(.group\/drawer-content)[data-vaul-drawer-direction=bottom] *),
.group-data-\[vaul-drawer-direction\=top\]\/drawer-content\:text-center:is(:where(.group\/drawer-content)[data-vaul-drawer-direction=top] *) { text-align: center }
.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled ~ *) { cursor: not-allowed }
.peer-disabled\:opacity-50:is(:where(.peer):disabled ~ *) { opacity: .5 }
.selection\:bg-primary::selection, .selection\:bg-primary ::selection { background-color: var(--primary) }
.selection\:bg-white::selection, .selection\:bg-white ::selection { background-color: var(--color-white) }
.selection\:text-black::selection, .selection\:text-black ::selection { color: var(--color-black) }
.selection\:text-primary-foreground::selection, .selection\:text-primary-foreground ::selection { color: var(--primary-foreground) }
.file\:inline-flex::file-selector-button { display: inline-flex }
.file\:h-7::file-selector-button { height: calc(var(--spacing)*7) }
.file\:border-0::file-selector-button { border-style: var(--tw-border-style); border-width: 0 }
.file\:bg-transparent::file-selector-button { background-color: transparent }
.file\:text-sm::file-selector-button { font-size: var(--text-sm); line-height: var(--tw-leading, var(--text-sm--line-height)) }
.file\:font-medium::file-selector-button { --tw-font-weight: var(--font-weight-medium); font-weight: var(--font-weight-medium) }
.file\:text-foreground::file-selector-button { color: var(--foreground) }
.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-ring:focus { --tw-ring-color: var(--ring) }
.focus\:ring-offset-2:focus { --tw-ring-offset-width: 2px; --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) }
.focus\:outline-hidden:focus { --tw-outline-style: none; outline-style: none }
@media (forced-colors: active) { .focus\:outline-hidden:focus { outline-offset: 2px; outline: 2px solid transparent } }
.focus-visible\:border-ring:focus-visible { border-color: var(--ring) }
.focus-visible\:ring-\[3px\]:focus-visible { --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor); box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow) }
.focus-visible\:ring-ring\/50:focus-visible { --tw-ring-color: color-mix(in oklab, var(--ring) 50%, transparent) }
.focus-visible\:outline-1:focus-visible { outline-style: var(--tw-outline-style); outline-width: 1px }
.disabled\:pointer-events-none:disabled { pointer-events: none }
.disabled\:cursor-not-allowed:disabled { cursor: not-allowed }
.disabled\:opacity-50:disabled { opacity: .5 }
.has-\[\>svg\]\:px-2\.5:has(> svg) { padding-inline: calc(var(--spacing)*2.5) }
.has-\[\>svg\]\:px-3:has(> svg) { padding-inline: calc(var(--spacing)*3) }
.has-\[\>svg\]\:px-4:has(> svg) { padding-inline: calc(var(--spacing)*4) }
.data-\[disabled\]\:pointer-events-none[data-disabled] { pointer-events: none }
.data-\[disabled\]\:opacity-50[data-disabled] { opacity: .5 }
.data-\[side\=bottom\]\:translate-y-1[data-side=bottom] { --tw-translate-y: calc(var(--spacing)*1); translate: var(--tw-translate-x) var(--tw-translate-y) }
.data-\[side\=left\]\:-translate-x-1[data-side=left] { --tw-translate-x: calc(var(--spacing)*-1); translate: var(--tw-translate-x) var(--tw-translate-y) }
.data-\[side\=right\]\:translate-x-1[data-side=right] { --tw-translate-x: calc(var(--spacing)*1); translate: var(--tw-translate-x) var(--tw-translate-y) }
.data-\[side\=top\]\:-translate-y-1[data-side=top] { --tw-translate-y: calc(var(--spacing)*-1); translate: var(--tw-translate-x) var(--tw-translate-y) }
.data-\[size\=default\]\:h-9[data-size=default] { height: calc(var(--spacing)*9) }
.data-\[size\=sm\]\:h-8[data-size=sm] { height: calc(var(--spacing)*8) }
.data-\[state\=closed\]\:animate-out[data-state=closed] { animation: exit var(--tw-animation-duration, var(--tw-duration, .15s)) var(--tw-ease, ease) var(--tw-animation-delay, 0s) var(--tw-animation-iteration-count, 1) var(--tw-animation-direction, normal) var(--tw-animation-fill-mode, none) }
.data-\[state\=closed\]\:duration-300[data-state=closed] { --tw-duration: .3s; transition-duration: .3s }
.data-\[state\=closed\]\:fade-out-0[data-state=closed] { --tw-exit-opacity: 0 }
.data-\[state\=closed\]\:zoom-out-95[data-state=closed] { --tw-exit-scale: .95 }
.data-\[state\=closed\]\:slide-out-to-bottom[data-state=closed] { --tw-exit-translate-y: 100% }
.data-\[state\=closed\]\:slide-out-to-left[data-state=closed] { --tw-exit-translate-x: -100% }
.data-\[state\=closed\]\:slide-out-to-right[data-state=closed] { --tw-exit-translate-x: 100% }
.data-\[state\=closed\]\:slide-out-to-top[data-state=closed] { --tw-exit-translate-y: -100% }
.data-\[state\=open\]\:animate-in[data-state=open] { animation: enter var(--tw-animation-duration, var(--tw-duration, .15s)) var(--tw-ease, ease) var(--tw-animation-delay, 0s) var(--tw-animation-iteration-count, 1) var(--tw-animation-direction, normal) var(--tw-animation-fill-mode, none) }
.data-\[state\=open\]\:bg-secondary[data-state=open] { background-color: var(--secondary) }
.data-\[state\=open\]\:duration-500[data-state=open] { --tw-duration: .5s; transition-duration: .5s }
.data-\[state\=open\]\:fade-in-0[data-state=open] { --tw-enter-opacity: 0 }
.data-\[state\=open\]\:zoom-in-95[data-state=open] { --tw-enter-scale: .95 }
.data-\[state\=open\]\:slide-in-from-bottom[data-state=open] { --tw-enter-translate-y: 100% }
.data-\[state\=open\]\:slide-in-from-left[data-state=open] { --tw-enter-translate-x: -100% }
.data-\[state\=open\]\:slide-in-from-right[data-state=open] { --tw-enter-translate-x: 100% }
.data-\[state\=open\]\:slide-in-from-top[data-state=open] { --tw-enter-translate-y: -100% }
.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom] { --tw-enter-translate-y: calc(2 * var(--spacing) * -1) }
.data-\[side\=left\]\:slide-in-from-right-2[data-side=left] { --tw-enter-translate-x: calc(2 * var(--spacing)) }
.data-\[side\=right\]\:slide-in-from-left-2[data-side=right] { --tw-enter-translate-x: calc(2 * var(--spacing) * -1) }
.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top] { --tw-enter-translate-y: calc(2 * var(--spacing)) }
.data-\[vaul-drawer-direction\=bottom\]\:inset-x-0[data-vaul-drawer-direction=bottom] { inset-inline: 0 }
.data-\[vaul-drawer-direction\=bottom\]\:bottom-0[data-vaul-drawer-direction=bottom] { bottom: 0 }
.data-\[vaul-drawer-direction\=bottom\]\:mt-24[data-vaul-drawer-direction=bottom] { margin-top: calc(var(--spacing)*24) }
.data-\[vaul-drawer-direction\=bottom\]\:max-h-\[80vh\][data-vaul-drawer-direction=bottom] { max-height: 80vh }
.data-\[vaul-drawer-direction\=bottom\]\:rounded-t-lg[data-vaul-drawer-direction=bottom] { border-top-left-radius: var(--radius); border-top-right-radius: var(--radius) }
.data-\[vaul-drawer-direction\=bottom\]\:border-t[data-vaul-drawer-direction=bottom] { border-top-style: var(--tw-border-style); border-top-width: 1px }
.data-\[vaul-drawer-direction\=left\]\:inset-y-0[data-vaul-drawer-direction=left] { inset-block: 0 }
.data-\[vaul-drawer-direction\=left\]\:left-0[data-vaul-drawer-direction=left] { left: 0 }
.data-\[vaul-drawer-direction\=left\]\:w-3\/4[data-vaul-drawer-direction=left] { width: 75% }
.data-\[vaul-drawer-direction\=left\]\:border-r[data-vaul-drawer-direction=left] { border-right-style: var(--tw-border-style); border-right-width: 1px }
.data-\[vaul-drawer-direction\=right\]\:inset-y-0[data-vaul-drawer-direction=right] { inset-block: 0 }
.data-\[vaul-drawer-direction\=right\]\:right-0[data-vaul-drawer-direction=right] { right: 0 }
.data-\[vaul-drawer-direction\=right\]\:w-3\/4[data-vaul-drawer-direction=right] { width: 75% }
.data-\[vaul-drawer-direction\=right\]\:border-l[data-vaul-drawer-direction=right] { border-left-style: var(--tw-border-style); border-left-width: 1px }
.data-\[vaul-drawer-direction\=top\]\:inset-x-0[data-vaul-drawer-direction=top] { inset-inline: 0 }
.data-\[vaul-drawer-direction\=top\]\:top-0[data-vaul-drawer-direction=top] { top: 0 }
.data-\[vaul-drawer-direction\=top\]\:mb-24[data-vaul-drawer-direction=top] { margin-bottom: calc(var(--spacing)*24) }
.data-\[vaul-drawer-direction\=top\]\:max-h-\[80vh\][data-vaul-drawer-direction=top] { max-height: 80vh }
.data-\[vaul-drawer-direction\=top\]\:rounded-b-lg[data-vaul-drawer-direction=top] { border-bottom-right-radius: var(--radius); border-bottom-left-radius: var(--radius) }
.data-\[vaul-drawer-direction\=top\]\:border-b[data-vaul-drawer-direction=top] { border-bottom-style: var(--tw-border-style); border-bottom-width: 1px }
:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1 > *)[data-slot=select-value] { -webkit-line-clamp: 1; -webkit-box-orient: vertical; display: -webkit-box; overflow: hidden }
:is(.\*\:data-\[slot\=select-value\]\:flex > *)[data-slot=select-value] { display: flex }
:is(.\*\:data-\[slot\=select-value\]\:items-center > *)[data-slot=select-value] { align-items: center }
:is(.\*\:data-\[slot\=select-value\]\:gap-2 > *)[data-slot=select-value] { gap: calc(var(--spacing)*2) }
.\[\&_svg\]\:pointer-events-none svg { pointer-events: none }
.\[\&_svg\]\:shrink-0 svg { flex-shrink: 0 }
.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]) { width: calc(var(--spacing)*4); height: calc(var(--spacing)*4) }
:is(.\*\:\[span\]\:last\:flex > *):is(span):last-child { display: flex }
:is(.\*\:\[span\]\:last\:items-center > *):is(span):last-child { align-items: center }
:is(.\*\:\[span\]\:last\:gap-2 > *):is(span):last-child { gap: calc(var(--spacing)*2) }

/* ============================================================
   RESPONSIVE UTILITIES
   ============================================================ */
@media (min-width: 40rem) {
    .container { max-width: 40rem }
    .sm\:inline-block { display: inline-block }
    .sm\:size-100 { width: calc(var(--spacing)*100); height: calc(var(--spacing)*100) }
    .sm\:w-\[280px\] { width: 280px }
    .sm\:w-full { width: 100% }
    .sm\:max-w-sm { max-width: var(--container-sm) }
    .sm\:flex-row { flex-direction: row }
    .sm\:items-center { align-items: center }
    .sm\:justify-around { justify-content: space-around }
    .sm\:justify-center { justify-content: center }
    .sm\:gap-4 { gap: calc(var(--spacing)*4) }
    .sm\:gap-20 { gap: calc(var(--spacing)*20) }
    .sm\:px-\[70px\] { padding-inline: 70px }
    .sm\:px-\[80px\] { padding-inline: 80px }
    .sm\:text-center { text-align: center }
    .sm\:text-7xl { font-size: var(--text-7xl); line-height: var(--tw-leading, var(--text-7xl--line-height)) }
    .sm\:text-xl { font-size: var(--text-xl); line-height: var(--tw-leading, var(--text-xl--line-height)) }
    .data-\[vaul-drawer-direction\=left\]\:sm\:max-w-sm[data-vaul-drawer-direction=left],
    .data-\[vaul-drawer-direction\=right\]\:sm\:max-w-sm[data-vaul-drawer-direction=right] { max-width: var(--container-sm) }
}
@media (min-width: 48rem) {
    .container { max-width: 48rem }
    .md\:top-1\/2 { top: 50% }
    .md\:-right-12 { right: calc(var(--spacing)*-12) }
    .md\:-left-12 { left: calc(var(--spacing)*-12) }
    .md\:size-100 { width: calc(var(--spacing)*100); height: calc(var(--spacing)*100) }
    .md\:w-lg { width: var(--container-lg) }
    .md\:max-w-full { max-width: 100% }
    .md\:-translate-y-1\/2 { --tw-translate-y: -50%; translate: var(--tw-translate-x) var(--tw-translate-y) }
    .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) }
    .md\:gap-1\.5 { gap: calc(var(--spacing)*1.5) }
    .md\:px-8 { padding-inline: calc(var(--spacing)*8) }
    .md\:pt-0 { padding-top: 0 }
    .md\:text-left { text-align: left }
    .md\:text-sm { font-size: var(--text-sm); line-height: var(--tw-leading, var(--text-sm--line-height)) }
}
@media (min-width: 64rem) {
    .container { max-width: 64rem }
    .lg\:-ml-4 { margin-left: calc(var(--spacing)*-4) }
    .lg\:inline-block { display: inline-block }
    .lg\:size-40 { width: calc(var(--spacing)*40); height: calc(var(--spacing)*40) }
    .lg\:h-140 { height: calc(var(--spacing)*140) }
    .lg\:w-\[20\%\] { width: 20% }
    .lg\:flex-row { flex-direction: row }
    .lg\:items-center { align-items: center }
    .lg\:items-start { align-items: flex-start }
    .lg\:px-12 { padding-inline: calc(var(--spacing)*12) }
    .lg\:text-left { text-align: left }
}
@media (min-width: 80rem) {
    .container { max-width: 80rem }
    .xl\:flex { display: flex }
    .xl\:hidden { display: none }
    .xl\:size-50 { width: calc(var(--spacing)*50); height: calc(var(--spacing)*50) }
    .xl\:justify-between { justify-content: space-between }
    .xl\:gap-0 { gap: 0 }
}
@media (min-width: 96rem) {
    .container { max-width: 96rem }
}

/* ============================================================
   RESPONSIVE TWEAKS
   ============================================================ */
@media (max-width: 640px) {
    .hero-title { font-size: 3rem; }
    .hero-buttons { flex-direction: column; }
    .features-grid { grid-template-columns: 1fr; }
    .func-card { max-width: 100%; height: auto; min-height: 200px; }
}

/* ============================================================
   DARK MODE UTILITIES
   ============================================================ */
@media (prefers-color-scheme: dark) {
    .dark\:border-input { border-color: var(--input) }
    .dark\:bg-input\/30 { background-color: color-mix(in oklab, var(--input) 30%, transparent) }
    .dark\:\[--cell-border-color\:var\(--color-neutral-700\)\] { --cell-border-color: var(--color-neutral-700) }
    .dark\:\[--cell-fill-color\:var\(--color-neutral-900\)\] { --cell-fill-color: var(--color-neutral-900) }
    .dark\:\[--cell-shadow-color\:var\(--color-neutral-800\)\] { --cell-shadow-color: var(--color-neutral-800) }
    .dark\:shadow-\[0px_0px_40px_1px_var\(--cell-shadow-color\)_inset\] { --tw-shadow: 0px 0px 40px 1px var(--tw-shadow-color, var(--cell-shadow-color)) inset; box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow) }
}

/* ============================================================
   FONT FACES
   ============================================================ */
@font-face { font-family: Geist; font-style: normal; font-weight: 100 900; font-display: swap; src: url(/wp-content/themes/bidpack-theme/media/8d697b304b401681-s.woff2) format("woff2"); unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116 }
@font-face { font-family: Geist; font-style: normal; font-weight: 100 900; font-display: swap; src: url(/wp-content/themes/bidpack-theme/media/ba015fad6dcf6784-s.woff2) format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF }
@font-face { font-family: Geist; font-style: normal; font-weight: 100 900; font-display: swap; src: url(/wp-content/themes/bidpack-theme/media/4cf2300e9c8272f7-s.p.woff2) format("woff2"); unicode-range: U+00??, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD }
@font-face { font-family: "Geist Fallback"; src: local("Arial"); ascent-override: 95.94%; descent-override: 28.16%; line-gap-override: 0.00%; size-adjust: 104.76% }
.__className_188709 { font-family: Geist, "Geist Fallback"; font-style: normal }
.__variable_188709 { --font-geist-sans: "Geist", "Geist Fallback" }
@font-face { font-family: "Geist Mono"; font-style: normal; font-weight: 100 900; font-display: swap; src: url(/wp-content/themes/bidpack-theme/media/9610d9e46709d722-s.woff2) format("woff2"); unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116 }
@font-face { font-family: "Geist Mono"; font-style: normal; font-weight: 100 900; font-display: swap; src: url(/wp-content/themes/bidpack-theme/media/747892c23ea88013-s.woff2) format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF }
@font-face { font-family: "Geist Mono"; font-style: normal; font-weight: 100 900; font-display: swap; src: url(/wp-content/themes/bidpack-theme/media/93f479601ee12b01-s.p.woff2) format("woff2"); unicode-range: U+00??, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD }
@font-face { font-family: "Geist Mono Fallback"; src: local("Arial"); ascent-override: 74.67%; descent-override: 21.92%; line-gap-override: 0.00%; size-adjust: 134.59% }
.__className_9a8899 { font-family: "Geist Mono", "Geist Mono Fallback"; font-style: normal }
.__variable_9a8899 { --font-geist-mono: "Geist Mono", "Geist Mono Fallback" }

/* ============================================================
   CUSTOM OVERRIDES
   ============================================================ */
a.custom-logo-link { margin-right: auto !important; }
footer a.custom-logo-link { margin-right: unset !important; }

.feature-bottom.slide-up.visible {
    background: none !important;
    border: none !important;
}

.mx-5 {
    margin-left: 5%;
    margin-right: 5%;
}

/* ============================================================
   header sticky
   ============================================================ */
header#site-header
 {
    position: fixed !important;
    width: 100%;
    z-index: 9999 !important;
}
/* ============================================================
   logo cercle
   ============================================================ */
@media (min-width: 1280px) {
	.center-logo-glow {
		position: relative;
		width: 400px;
		height: 580px;
	}
}
@media (max-width: 425px) {
	.center-logo-glow {
		display: none !important;
		position: relative;
		width: 400px;
		height: 580px;
	}
}

/* ============================================================
	Footer links
============================================================ */
a.modal-trigger.footer-link {
    cursor: pointer;
}
/* ============================================================
	play button
============================================================ */
a#video-play-btn i {
	cursor: pointer;
    font-size: 6rem;
}
@media (max-width: 425px) {
		a#video-play-btn {
		padding-top: 10%;
	}
}
a#linkedin-btn {
    padding: 3px;
    border-radius: 5px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	margin-right: 5px;
}
#linkenin-btn-mobile i{
	 padding: 3px;
    border-radius: 5px;
	border: 1px solid rgba(255, 255, 255, 0.2);
}
.mobile-nav a.btn-login, .mobile-nav a.btn-signup {
    padding-left: 10px;
}
nav#mobile-nav {
    z-index: 9999999999999999;
}

/* ============================================================
	play button animation
============================================================ */
#video-play-btn {
    display: inline-block;
    font-size: 70px; /* adjust size */
    color: #ffffff;
    text-decoration: none;
    animation: pulse 3s infinite; /* slower (x2) */
    transition: transform 0.3s ease;
}

/* Pulse keyframes */
@keyframes pulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.15);
    }
}

/* Optional: pause on hover + scale effect */
#video-play-btn:hover {
    animation-play-state: paused;
    transform: scale(1.2);
}

/* ============================================================
	cookies
============================================================ */
.cookieadmin-poweredby{
	display: none;
}
#Features, #why-choose-us, #functionalities, #join{
	padding-top: 16%;
}
@media (max-width: 450px) {
	#Features, #why-choose-us, #functionalities, #join{
	padding-top: 50% !important;
}
}