@import url("https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/Vazirmatn-font-face.css");
/*! tailwindcss v4.1.3 | MIT License | https://tailwindcss.com */
@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-rotate-x: rotateX(0);
      --tw-rotate-y: rotateY(0);
      --tw-rotate-z: rotateZ(0);
      --tw-skew-x: skewX(0);
      --tw-skew-y: skewY(0);
      --tw-border-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-duration: initial;
      --tw-ease: initial;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
    }
  }
}

@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --spacing: .25rem;
    --radius-sm: .225rem;
    --radius-lg: .625rem;
    --ease-out: cubic-bezier(0, 0, .2, 1);
    --ease-in-out: cubic-bezier(.4, 0, .2, 1);
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-font-feature-settings: var(--font-sans--font-feature-settings);
    --default-font-variation-settings: var(--font-sans--font-variation-settings);
    --default-mono-font-family: var(--font-mono);
    --default-mono-font-feature-settings: var(--font-mono--font-feature-settings);
    --default-mono-font-variation-settings: var(--font-mono--font-variation-settings);
  }
}

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

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

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

  body {
    line-height: inherit;
  }

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

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

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

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

  b, strong {
    font-weight: bolder;
  }

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

  small {
    font-size: 80%;
  }

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

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.5em;
  }

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

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

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

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

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

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

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

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

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

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

  ::placeholder {
    opacity: 1;
    color: currentColor;
  }

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

  textarea {
    resize: vertical;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  * {
    border-color: oklch(.922 0 0);
    outline-color: color-mix(in oklab, oklch(.708 0 0) 50%, transparent);
  }

  body {
    background-color: oklch(1 0 0);
    color: oklch(.145 0 0);
  }
}

@layer utilities {
  .absolute {
    position: absolute;
  }

  .relative {
    position: relative;
  }

  .inset-\[5\.71\%_3\.21\%_5\.5\%_3\.25\%\] {
    inset: 5.71% 3.21% 5.5% 3.25%;
  }

  .block {
    display: block;
  }

  .contents {
    display: contents;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

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

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

  .size-full {
    width: 100%;
    height: 100%;
  }

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

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

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

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

  .h-full {
    height: 100%;
  }

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

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

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

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

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

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

  .w-full {
    width: 100%;
  }

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

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

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

  .opacity-80 {
    opacity: .8;
  }

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

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

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

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

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

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

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

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


:root {
  --primary: #5017d7;
  --primary-dark: #3d0fb8;
  --primary-light: #7b3fe8;
  --secondary: #b068f0;
  --accent: #e8b8ff;
  --dark: #0f0a1f;
  --dark-blue: #1a0f3d;
  --gray-50: #fafaff;
  --gray-100: #f4f3ff;
  --gray-200: #e9e7ff;
  --gray-300: #d4d0f5;
  --gray-400: #a8a3c8;
  --gray-500: #7c779b;
  --gray-600: #514d6e;
  --gray-700: #3a3751;
  --gray-800: #252234;
  --gray-900: #0f0a1f;
  --spacing-xs: .5rem;
  --spacing-sm: 1rem;
  --spacing-md: 1.5rem;
  --spacing-lg: 2rem;
  --spacing-xl: 3rem;
  --spacing-2xl: 4rem;
  --spacing-3xl: 6rem;
  --radius-sm: .5rem;
  --radius-md: .75rem;
  --radius-lg: 1rem;
  --radius-xl: 1.5rem;
  --radius-2xl: 2rem;
  --radius-full: 9999px;
  --shadow-sm: 0 1px 2px #0000000d;
  --shadow-md: 0 4px 12px #0000000d;
  --shadow-lg: 0 8px 24px #00000014;
  --shadow-xl: 0 12px 40px #0000001a;
  --shadow-2xl: 0 20px 60px #00000026;
  --transition-fast: .15s cubic-bezier(.4, 0, .2, 1);
  --transition-base: .3s cubic-bezier(.4, 0, .2, 1);
  --transition-slow: .5s cubic-bezier(.4, 0, .2, 1);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 16px;
}

body {
  color: var(--gray-900);
  text-align: right;
  direction: rtl;
  background: #fff;
  min-height: 100vh;
  font-family: Vazirmatn, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif;
  line-height: 1.7;
  position: relative;
  overflow-x: hidden;
}

body:before {
  content: "";
  opacity: .015;
  pointer-events: none;
  z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='70' height='70' viewBox='0 0 70 70' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clipPath='url(%23clip0_286_739)'%3E%3Cpath d='M67.2004 34.6334L45.2397 5.12839C43.4858 3.15925 40.8711 1.33123 38.1651 0.991276C37.8 0.946377 37.0697 0.952791 36.698 0.991276C36.3394 1.02335 35.6091 1.20936 35.2375 1.32481C33.2553 1.94698 27.5043 7.05263 25.6134 8.67541C21.4599 12.2417 17.7563 16.2762 13.8701 20.1118C12.1031 22.3824 11.6337 25.1726 12.1683 27.8088C12.3509 28.726 12.6639 29.6304 13.0812 30.4899C12.2335 30.9068 11.3859 31.3301 10.5447 31.7599C8.56255 32.7605 6.59991 33.7803 4.65031 34.8387C2.06172 36.981 0.848927 39.598 0.575071 42.9076C0.38598 45.2424 0.0860418 49.2833 0.816325 51.4192C1.14234 52.3749 1.69006 53.2344 2.25081 54.0747C4.85897 58.0001 7.85183 61.7139 10.5317 65.6073C12.2922 67.6149 14.0266 68.1601 16.5631 68.7374C23.5725 70.3281 26.448 70.6744 31.9186 65.7163C34.9897 62.9326 37.976 60.027 40.9624 57.1406C41.647 56.48 42.3251 55.8193 43.0098 55.1651C43.4923 54.7032 43.9748 54.2478 44.4573 53.786C45.8983 52.4198 48.7607 50.0915 50.6386 48.0133C51.408 47.1666 52.0144 46.3585 52.2818 45.6786C52.2818 45.6786 52.2818 45.6657 52.2883 45.6657C53.625 42.3175 52.4513 38.7 50.5278 35.8457C48.3891 32.6771 45.7027 29.0724 43.3293 26.0577C41.1449 23.2932 37.8 20.7404 34.0116 21.0226C33.5617 21.0547 33.0988 21.1701 32.6554 21.2471C31.56 21.7602 30.4645 22.267 29.3626 22.7737C29.3626 23.0367 29.4082 23.2227 29.4343 23.3445C29.6299 24.1335 30.2624 25.0507 31.3057 26.0898L31.7947 26.5644C31.9968 26.7633 32.199 26.9621 32.4076 27.1609C33.3987 26.635 34.3898 26.1154 35.3744 25.5895C37.2653 25.3265 38.8367 26.2758 39.9973 27.6548C42.8598 31.0672 45.3375 35.3133 48.0892 38.8475C48.5782 39.8673 48.7999 41.0155 48.5325 42.0417C48.3695 42.6703 48.037 43.2476 47.4697 43.7351C47.248 43.9211 47.0263 44.1071 46.8112 44.2931C46.1852 43.6966 45.5592 43.1001 44.9268 42.51C44.8681 42.4522 44.8094 42.4009 44.7507 42.3432C40.5451 38.437 36.1112 34.5693 31.9186 30.5925C31.2013 29.9126 30.4906 29.2263 29.7864 28.54L29.2974 28.0589C27.9216 26.6991 27.0153 25.3778 26.6762 24.018C26.4154 22.9789 26.4806 21.9206 26.924 20.811C27.2239 20.0541 27.6999 19.278 28.3585 18.4634C30.8427 15.4103 34.2333 11.4656 36.9719 8.67541C38.928 6.68703 40.9624 7.28354 42.775 9.0795C49.9866 18.6109 57.9741 27.6548 65.0748 37.2632C66.6136 39.3414 67.2135 40.6755 66.4506 43.3246C64.9052 46.5829 63.8815 50.3545 62.3036 53.5679C61.9385 54.3056 61.482 55.3062 60.6474 55.6205C59.3368 56.1079 58.7239 55.4473 57.8045 54.6648C56.044 53.1639 54.3422 51.5796 52.6599 49.9696C51.2907 51.4705 49.5236 53.0292 48.0892 54.2927C47.4502 54.8572 46.8438 55.3896 46.4199 55.7936C46.0352 56.1592 45.6505 56.5249 45.2658 56.8905C45.8135 57.224 46.4134 57.4357 47.0198 57.6537C50.1235 58.757 54.6617 60.2322 57.8306 60.9378C61.945 61.855 63.6794 58.4427 64.9835 55.2869C67.5851 48.9626 71.6343 40.977 67.2135 34.6398L67.2004 34.6334ZM36.0264 49.7259L38.302 51.4962C37.5718 52.1183 36.8415 52.7405 36.1047 53.3563C35.3874 53.9592 34.6767 54.5685 33.9595 55.1715C31.6839 57.0957 29.3691 59.315 27.0348 61.1174C24.3093 63.2212 21.4208 62.8364 19.269 60.2194C15.4742 55.614 12.2466 50.0594 8.61471 45.2937C7.72142 43.3182 8.01484 41.1438 9.61885 39.6172C11.3011 38.6294 12.9964 37.6545 14.7048 36.6988C15.5915 36.1985 16.4848 35.7046 17.3781 35.2107L19.7907 37.0836L36.0264 49.7323V49.7259Z' fill='%235017D7'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0_286_739'%3E%3Crect width='68.8299' height='68.8299' fill='white' transform='translate(0.350586 0.959961)'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 90vw;
  max-width: 1200px;
  height: 90vh;
  animation: 30s ease-in-out infinite floatLogo;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

@keyframes floatLogo {
  0%, 100% {
    opacity: .015;
    transform: translate(-50%, -50%)scale(1);
  }

  50% {
    opacity: .02;
    transform: translate(-50%, -52%)scale(1.05);
  }
}

h1, h2, h3, h4, h5, h6 {
  color: var(--dark-blue);
  font-weight: 700;
  line-height: 1.3;
}

h1 {
  letter-spacing: -.02em;
  font-size: 2.5rem;
}

h2 {
  letter-spacing: -.01em;
  font-size: 2rem;
}

h3 {
  font-size: 1.5rem;
}

h4 {
  font-size: 1.25rem;
}

h5 {
  font-size: 1.125rem;
}

h6 {
  font-size: 1rem;
}

p {
  color: var(--gray-600);
  line-height: 1.8;
}

a {
  color: inherit;
  transition: var(--transition-base);
  text-decoration: none;
}

:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

::selection {
  background: var(--primary-light);
  color: var(--dark);
}

::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}

::-webkit-scrollbar-track {
  background: var(--gray-100);
}

::-webkit-scrollbar-thumb {
  background: var(--gray-300);
  border-radius: var(--radius-full);
  border: 3px solid var(--gray-100);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--primary);
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

@keyframes slideInRight {
  from {
    transform: translateX(100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes slideInLeft {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(.9);
  }

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

@keyframes rotate {
  from {
    transform: rotate(0);
  }

  to {
    transform: rotate(360deg);
  }
}

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

@keyframes float {
  0%, 100% {
    transform: translateY(0)rotate(0);
  }

  50% {
    transform: translateY(-20px)rotate(5deg);
  }
}

.container {
  max-width: 1400px;
  padding: 0 var(--spacing-lg);
  margin: 0 auto;
}

.section {
  padding: var(--spacing-3xl) 0;
}

.section-sm {
  padding: var(--spacing-2xl) 0;
}

.section-lg {
  padding: 8rem 0;
}

.btn {
  justify-content: center;
  align-items: center;
  gap: var(--spacing-xs);
  border-radius: var(--radius-lg);
  transition: var(--transition-base);
  cursor: pointer;
  white-space: nowrap;
  border: none;
  padding: 1rem 2rem;
  font-size: 1rem;
  font-weight: 600;
  display: inline-flex;
}

.btn-primary {
  background: var(--primary);
  color: #fff;
  box-shadow: 0 4px 15px #5017d74d;
}

.btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px #5017d766;
}

.btn-secondary {
  color: var(--primary);
  border: 2px solid var(--primary);
  background: #fff;
}

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

.btn-ghost {
  color: var(--gray-700);
  border: 2px solid var(--gray-200);
  background: none;
}

.btn-ghost:hover {
  background: var(--gray-100);
  border-color: var(--primary);
  color: var(--primary);
}

.card {
  border-radius: var(--radius-lg);
  transition: var(--transition-base);
  background: #fff;
  border: 1px solid #5017d714;
  padding: 1.75rem;
  box-shadow: 0 2px 8px #5017d70a;
}

.card:hover {
  border-color: #5017d733;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px #5017d71f;
}

.badge {
  border-radius: var(--radius-full);
  align-items: center;
  padding: .5rem 1rem;
  font-size: .875rem;
  font-weight: 600;
  display: inline-flex;
}

.badge-primary {
  color: var(--primary-dark);
  background: #5017d71a;
  border: 1px solid #5017d733;
}

.badge-success {
  color: #059669;
  background: #10b9811a;
  border: 1px solid #10b98133;
}

.badge-warning {
  color: #d97706;
  background: #f59e0b1a;
  border: 1px solid #f59e0b33;
}

.badge-info {
  color: #2563eb;
  background: #3b82f61a;
  border: 1px solid #3b82f633;
}

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

@keyframes floatShape {
  0%, 100% {
    transform: translate(0)rotate(0);
  }

  33% {
    transform: translate(30px, -30px)rotate(120deg);
  }

  66% {
    transform: translate(-20px, 20px)rotate(240deg);
  }
}

@keyframes morphBlob {
  0%, 100% {
    border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
  }

  50% {
    border-radius: 30% 60% 70% 40% / 50% 60% 30%;
  }
}

.glass {
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background: #ffffff1a;
  border: 1px solid #fff3;
}

@media (width <= 1200px) {
  .container {
    padding: 0 var(--spacing-md);
  }
}

@media (width <= 768px) {
  html {
    font-size: 14px;
  }

  h1 {
    font-size: 2.25rem;
  }

  h2 {
    font-size: 2rem;
  }

  h3 {
    font-size: 1.5rem;
  }

  .section {
    padding: var(--spacing-2xl) 0;
  }

  .section-lg {
    padding: 5rem 0;
  }

  .container {
    padding: 0 var(--spacing-sm);
  }
}

@media print {
  * {
    color: #000 !important;
    box-shadow: none !important;
    background: #fff !important;
  }
}

.header-wrapper {
  z-index: 1000;
  -webkit-backdrop-filter: blur(20px);
  background: #fffffff2;
  border: 1px solid #6478961a;
  border-radius: 20px;
  width: calc(100% - 4rem);
  max-width: 1400px;
  transition: all .5s cubic-bezier(.34, 1.56, .64, 1);
  position: fixed;
  top: 1rem;
  left: 50%;
  overflow: hidden;
  transform: translateX(-50%);
  box-shadow: 0 2px 12px #0000000a;
}

.header-wrapper:before {
  content: "";
  background: #5017d705;
  width: 100%;
  height: 100%;
  transition: left .8s;
  position: absolute;
  top: 0;
  left: -100%;
}

.header-wrapper:hover:before {
  left: 100%;
}

.header-wrapper.scrolled {
  background: #fffffffa;
  border-color: #6478961f;
  border-radius: 16px;
  top: .5rem;
  box-shadow: 0 4px 20px #0000000f;
}

.header-container {
  z-index: 1;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 2rem;
  padding: .875rem 2rem;
  display: grid;
  position: relative;
}

.header-logo {
  border-radius: 12px;
  justify-self: center;
  align-items: center;
  gap: .875rem;
  padding: .5rem 1.5rem;
  text-decoration: none;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  position: relative;
}

.header-logo:before {
  content: "";
  opacity: 0;
  background: #5017d705;
  border-radius: 12px;
  transition: opacity .4s;
  position: absolute;
  inset: 0;
}

.header-logo:hover:before {
  opacity: 1;
}

.header-logo-icon {
  z-index: 1;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  display: flex;
  position: relative;
}

.header-logo-icon svg {
  width: 44px;
  height: 44px;
  color: var(--primary);
  filter: drop-shadow(0 1px 3px #0000001a);
}

.header-logo-text {
  color: #1e293b;
  letter-spacing: -.03em;
  z-index: 1;
  font-size: 1.375rem;
  font-weight: 800;
  transition: all .3s;
  position: relative;
}

.header-logo:hover .header-logo-text {
  letter-spacing: .02em;
}

.header-nav {
  justify-content: flex-end;
  display: flex;
}

.header-nav-list {
  align-items: center;
  gap: .375rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.header-nav-item {
  position: relative;
}

.header-nav-link {
  color: #475569;
  white-space: nowrap;
  border-radius: 10px;
  align-items: center;
  padding: .625rem 1rem;
  font-size: .9375rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  position: relative;
}

.header-nav-link:after {
  content: "";
  background: #5017d7;
  border-radius: 2px;
  width: 20px;
  height: 3px;
  transition: transform .3s cubic-bezier(.34, 1.56, .64, 1);
  position: absolute;
  bottom: .5rem;
  left: 50%;
  transform: translateX(-50%)scaleX(0);
}

.header-nav-link:hover {
  color: var(--primary);
  background: #5017d708;
}

.header-nav-link:hover:after {
  transform: translateX(-50%)scaleX(1);
}

.header-cta-button {
  color: #fff;
  background: #5017d7;
  border-radius: 12px;
  justify-self: start;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.5rem;
  font-size: .9375rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 10px #5017d726;
}

.header-cta-button:before {
  content: "";
  opacity: 0;
  background: #b068f0;
  transition: opacity .3s;
  position: absolute;
  inset: 0;
}

.header-cta-button span, .header-cta-button svg {
  z-index: 1;
  position: relative;
}

.header-cta-button svg {
  transition: transform .4s;
}

.header-cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px #5017d740;
}

.header-cta-button:hover:before {
  opacity: 1;
}

.header-cta-button:hover svg {
  transform: scale(1.1);
}

.header-cta-button:active {
  transform: translateY(0);
}

.header-mobile-toggle {
  color: #475569;
  cursor: pointer;
  background: #fff;
  border: 1px solid #64789626;
  border-radius: 12px;
  justify-content: center;
  justify-self: end;
  align-items: center;
  width: 48px;
  height: 48px;
  transition: all .3s;
  display: none;
}

.header-mobile-toggle:hover {
  background: #6478960f;
  border-color: #64748b;
  transform: scale(1.05);
}

.header-mobile-toggle:active {
  transform: scale(.95);
}

.header-mobile-menu {
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  background: #0f0a1f80;
  transition: all .4s;
  position: fixed;
  inset: 0;
}

.header-mobile-menu.open {
  opacity: 1;
  visibility: visible;
}

.header-mobile-menu-content {
  background: #fff;
  width: 85%;
  max-width: 400px;
  padding: 2rem;
  transition: transform .5s cubic-bezier(.34, 1.56, .64, 1);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  overflow-y: auto;
  transform: translateX(100%);
  box-shadow: -8px 0 32px #00000026;
}

.header-mobile-menu.open .header-mobile-menu-content {
  transform: translateX(0);
}

.header-mobile-menu-header {
  border-bottom: 2px solid #6478961a;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 3rem;
  padding-bottom: 1.5rem;
  display: flex;
}

.header-mobile-close {
  color: #475569;
  cursor: pointer;
  background: #64789614;
  border: none;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  transition: all .3s;
  display: flex;
}

.header-mobile-close:hover {
  color: #5017d7;
  background: #5017d71a;
  transform: rotate(90deg)scale(1.05);
}

.header-mobile-nav-list {
  flex-direction: column;
  gap: .625rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.header-mobile-nav-link {
  color: #475569;
  background: #6478960a;
  border: 1px solid #64789614;
  border-radius: 12px;
  justify-content: space-between;
  align-items: center;
  padding: 1.125rem 1.5rem;
  font-size: 1.0625rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  position: relative;
}

.header-mobile-nav-link:after {
  content: "◄";
  color: #64748b;
  opacity: 0;
  font-size: .875rem;
  transition: all .3s;
  transform: translateX(10px);
}

.header-mobile-nav-link:hover {
  color: #1e293b;
  background: #5017d708;
  border-color: #5017d71a;
  padding-right: 2rem;
}

.header-mobile-nav-link:hover:after {
  opacity: 1;
  color: #5017d7;
  transform: translateX(0);
}

.header-mobile-cta {
  border-top: 2px solid #6478961a;
  margin-top: 2.5rem;
  padding-top: 2rem;
}

.header-mobile-cta .header-cta-button {
  justify-content: center;
  width: 100%;
  padding: 1rem 1.5rem;
  font-size: 1rem;
}

.header-mobile-social {
  border-top: 2px solid #6478961a;
  flex-direction: column;
  gap: .75rem;
  margin-top: 2rem;
  padding-top: 2rem;
  display: flex;
}

.header-mobile-social-card {
  opacity: 0;
  background: #fff;
  border-radius: 16px;
  padding: 0;
  text-decoration: none;
  animation: .6s cubic-bezier(.4, 0, .2, 1) forwards fadeInUp;
  display: block;
  position: relative;
  overflow: hidden;
}

.header-mobile-social-card-bg {
  opacity: 1;
  background: linear-gradient(135deg, #fff 0%, #f8f5ff 100%);
  transition: opacity .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: 0;
}

.header-mobile-social-card:hover .header-mobile-social-card-bg {
  opacity: 0;
}

.header-mobile-social-card:before {
  content: "";
  background: linear-gradient(135deg, var(--platform-color, #5017d7) 0%, #5017d7 100%);
  opacity: 0;
  transition: opacity .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: 0;
}

.header-mobile-social-card:hover:before {
  opacity: .05;
}

.header-mobile-social-card-border {
  pointer-events: none;
  border: 2px solid #e8e8f0;
  border-radius: 16px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: 0;
}

.header-mobile-social-card:hover .header-mobile-social-card-border {
  border-color: var(--platform-color, #5017d7);
  box-shadow: 0 8px 32px #5017d726;
}

.header-mobile-social-card-inner {
  z-index: 1;
  align-items: center;
  gap: 16px;
  padding: 20px 22px;
  display: flex;
  position: relative;
}

.header-mobile-social-icon-wrapper {
  flex-shrink: 0;
  position: relative;
}

.header-mobile-social-icon-bg {
  background: var(--platform-color, #5017d7);
  opacity: .1;
  border-radius: 14px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: -6px;
  transform: scale(.9);
}

.header-mobile-social-card:hover .header-mobile-social-icon-bg {
  opacity: .15;
  transform: scale(1);
}

.header-mobile-social-icon {
  background: linear-gradient(135deg, var(--platform-color, #5017d7) 0%, #5017d7 100%);
  color: #fff;
  z-index: 1;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 52px;
  height: 52px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: relative;
}

.header-mobile-social-card:hover .header-mobile-social-icon {
  transform: scale(1.05)rotate(-5deg);
  box-shadow: 0 8px 24px #00000026;
}

.header-mobile-social-content {
  flex-direction: column;
  flex: 1;
  gap: 4px;
  display: flex;
}

.header-mobile-social-name {
  color: #1a1a1a;
  font-size: 1rem;
  font-weight: 600;
  transition: all .3s;
}

.header-mobile-social-card:hover .header-mobile-social-name {
  color: var(--platform-color, #5017d7);
  transform: translateX(-4px);
}

.header-mobile-social-cta {
  color: #666;
  font-size: .875rem;
  transition: all .3s;
}

.header-mobile-social-card:hover .header-mobile-social-cta {
  color: #999;
  transform: translateX(-4px);
}

.header-mobile-social-arrow {
  color: #999;
  background: #f5f5f5;
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  transform: rotate(180deg);
}

.header-mobile-social-card:hover .header-mobile-social-arrow {
  background: var(--platform-color, #5017d7);
  color: #fff;
  transform: translateX(-4px)rotate(180deg);
}

@media (width <= 1200px) {
  .header-container {
    gap: 1.5rem;
  }

  .header-nav-list {
    gap: .25rem;
  }

  .header-nav-link {
    padding: .625rem .875rem;
    font-size: .875rem;
  }
}

@media (width <= 1024px) {
  .header-wrapper {
    width: calc(100% - 3rem);
    top: .75rem;
  }

  .header-wrapper.scrolled {
    top: .25rem;
  }

  .header-container {
    grid-template-columns: auto 1fr auto;
    gap: 1rem;
  }

  .header-logo {
    justify-self: start;
    padding: .5rem;
  }

  .header-nav {
    display: none;
  }

  .header-mobile-toggle {
    display: flex;
  }

  .header-cta-button {
    display: none;
  }
}

@media (width <= 768px) {
  .header-wrapper {
    width: calc(100% - 2rem);
    top: .5rem;
  }

  .header-container {
    padding: .75rem 1.25rem;
  }

  .header-logo-text {
    font-size: 1.125rem;
  }

  .header-logo-icon svg {
    width: 38px;
    height: 38px;
  }

  .header-mobile-menu-content {
    width: 90%;
    padding: 1.75rem;
  }
}

@media (width <= 480px) {
  .header-wrapper {
    border-radius: 16px;
    width: calc(100% - 1.5rem);
    top: .5rem;
  }

  .header-container {
    padding: .625rem 1rem;
  }

  .header-mobile-toggle {
    width: 44px;
    height: 44px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .header-wrapper, .header-logo, .header-nav-link, .header-cta-button, .header-mobile-menu, .header-mobile-menu-content, .header-mobile-nav-link {
    transition: none;
  }

  .header-wrapper:before {
    display: none;
  }
}

.header-nav-link:focus-visible, .header-cta-button:focus-visible, .header-mobile-toggle:focus-visible, .header-mobile-nav-link:focus-visible {
  outline-offset: 2px;
  outline: 3px solid #5017d7;
}

.hero-section {
  background: #fff;
  align-items: center;
  min-height: 100vh;
  padding: 10rem 2rem 6rem;
  display: flex;
  position: relative;
  overflow: hidden;
}

.hero-background {
  z-index: 0;
  pointer-events: none;
  perspective: 1000px;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.hero-section:hover .hero-bg-gradient-1 {
  filter: blur(100px) brightness(1.1);
  transition: all 2s;
  transform: scale(1.05);
}

.hero-section:hover .hero-bg-gradient-2 {
  filter: blur(90px) brightness(1.1);
  transition: all 2s;
  transform: scale(1.05);
}

.hero-bg-gradient-1, .hero-bg-gradient-2, .hero-bg-gradient-3 {
  display: none;
}

.hero-bg-circle-1 {
  border: 1px solid #5017d714;
  border-radius: 50%;
  width: 300px;
  height: 300px;
  animation: 40s linear infinite rotateCircle, 15s ease-in-out infinite scaleCircle;
  position: absolute;
  top: 15%;
  right: 10%;
}

.hero-bg-circle-1:before {
  content: "";
  border: 1px solid #5017d70d;
  border-radius: 50%;
  width: 250px;
  height: 250px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.hero-bg-circle-2 {
  border: 1px solid #b068f00f;
  border-radius: 50%;
  width: 200px;
  height: 200px;
  animation: 35s linear infinite reverse rotateCircle;
  position: absolute;
  bottom: 20%;
  left: 8%;
}

.hero-bg-circle-3 {
  border: 1px dashed #5017d70a;
  border-radius: 50%;
  width: 150px;
  height: 150px;
  animation: 45s linear infinite rotateCircle;
  position: absolute;
  top: 50%;
  left: 15%;
}

.hero-bg-circle-1:after {
  content: "";
  background: #5017d733;
  border-radius: 50%;
  width: 8px;
  height: 8px;
  animation: 3s ease-in-out infinite dotPulse;
  position: absolute;
  top: -4px;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 0 12px #5017d74d;
}

@keyframes dotPulse {
  0%, 100% {
    opacity: .4;
    transform: translateX(-50%)scale(1);
  }

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

@keyframes scaleCircle {
  0%, 100% {
    transform: scale(1)rotate(0);
  }

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

.hero-bg-line-1 {
  background: #5017d71a;
  width: 2px;
  height: 300px;
  animation: 8s ease-in-out infinite fadeInOut, 12s ease-in-out infinite lineMove;
  position: absolute;
  top: 10%;
  right: 25%;
  transform: rotate(15deg);
}

.hero-bg-line-1:before {
  content: "";
  background: #5017d766;
  border-radius: 50%;
  width: 6px;
  height: 6px;
  animation: 4s ease-in-out infinite particleMove;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.hero-bg-line-2 {
  background: #b068f014;
  width: 2px;
  height: 250px;
  animation-name: fadeInOut, lineMove;
  animation-duration: 10s, 15s;
  animation-timing-function: ease-in-out, ease-in-out;
  animation-iteration-count: infinite, infinite;
  animation-direction: normal, normal;
  animation-play-state: running, running;
  animation-delay: 3s;
  animation-fill-mode: none, none;
  animation-timeline: auto, auto;
  position: absolute;
  bottom: 15%;
  left: 30%;
  transform: rotate(-20deg);
}

.hero-bg-line-2:before {
  content: "";
  background: #b068f066;
  border-radius: 50%;
  width: 6px;
  height: 6px;
  animation: 5s ease-in-out 1.5s infinite particleMove;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

@keyframes particleMove {
  0% {
    opacity: 0;
    top: 0;
  }

  20% {
    opacity: 1;
  }

  80% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    top: 100%;
  }
}

@keyframes lineMove {
  0%, 100% {
    transform: rotate(15deg)translateY(0);
  }

  50% {
    transform: rotate(15deg)translateY(-20px);
  }
}

@keyframes floatGradient {
  0%, 100% {
    opacity: 1;
    transform: translate(0)scale(1);
  }

  33% {
    opacity: .8;
    transform: translate(30px, -40px)scale(1.1);
  }

  66% {
    opacity: .9;
    transform: translate(-25px, 35px)scale(.95);
  }
}

@keyframes rotateCircle {
  from {
    transform: rotate(0);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes fadeInOut {
  0%, 100% {
    opacity: .2;
  }

  50% {
    opacity: .6;
  }
}

@keyframes floatOrb {
  0%, 100% {
    transform: translate(0)scale(1);
  }

  33% {
    transform: translate(30px, -40px)scale(1.05);
  }

  66% {
    transform: translate(-20px, 30px)scale(.98);
  }
}

.hero-container {
  z-index: 2;
  grid-template-columns: 1.1fr .9fr;
  align-items: center;
  gap: 4rem;
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  position: relative;
}

.hero-container:before {
  content: "";
  background: #6478961f;
  width: 1px;
  height: 200px;
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
}

.hero-content {
  flex-direction: column;
  gap: 2rem;
  animation: 1s ease-out fadeInRight;
  display: flex;
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translateX(-40px);
  }

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

.hero-logo-container {
  justify-content: center;
  align-items: center;
  width: fit-content;
  margin-bottom: .5rem;
  animation: 1s ease-out .2s backwards fadeInDown;
  display: inline-flex;
}

.hero-logo {
  width: 156px;
  height: auto;
  color: var(--primary);
  filter: drop-shadow(0 2px 8px #5017d71f);
  transition: all .3s;
  animation: 6s ease-in-out infinite logoFloat;
}

.hero-logo:hover {
  filter: drop-shadow(0 4px 12px #5017d733);
  transform: scale(1.05);
}

@keyframes logoFloat {
  0%, 100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-8px);
  }
}

@keyframes shimmer {
  0% {
    left: -100%;
  }

  100% {
    left: 100%;
  }
}

.hero-badge svg {
  color: #9d4edd;
  animation: 2s ease-in-out infinite sparkle;
}

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

  50% {
    opacity: .7;
    transform: scale(.95);
  }
}

.hero-title {
  color: #5017d7;
  letter-spacing: -.03em;
  margin: 0;
  font-size: 3.25rem;
  font-weight: 900;
  line-height: 1.15;
  animation: 1s ease-out .3s backwards fadeInUp;
}

.hero-description {
  color: #64748b;
  max-width: 560px;
  font-size: 1.125rem;
  line-height: 1.8;
  animation: 1s ease-out .4s backwards fadeInUp;
}

.hero-cta-group {
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  animation: 1s ease-out .5s backwards fadeInUp;
  display: flex;
}

.cta-button {
  border-radius: 14px;
  align-items: center;
  gap: .625rem;
  padding: 1rem 2rem;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: inline-flex;
  position: relative;
  overflow: hidden;
}

.cta-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 16px #5017d740;
}

.cta-primary span, .cta-primary svg {
  z-index: 1;
  position: relative;
}

.cta-secondary {
  color: #475569;
  background: #fff;
  border: 2px solid #64789633;
  position: relative;
  box-shadow: 0 2px 8px #00000008;
}

.cta-secondary:before {
  content: "";
  opacity: 0;
  z-index: -1;
  background: #5017d71a;
  border-radius: 14px;
  transition: opacity .3s;
  position: absolute;
  inset: -2px;
}

.cta-secondary:hover {
  color: #5017d7;
  background: #f8fafc;
  border-color: #5017d74d;
  transform: translateY(-3px);
  box-shadow: 0 6px 16px #5017d714;
}

.cta-secondary:hover:before {
  opacity: 1;
}

.hero-stats {
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  padding: 2rem 0 0;
  animation: 1s ease-out .6s backwards fadeInUp;
  display: grid;
}

.hero-stat-item {
  background: #fff;
  border: 1px solid #5017d714;
  border-radius: 14px;
  flex-direction: column;
  gap: .5rem;
  padding: 1.5rem;
  transition: all .3s;
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 8px #00000008;
}

.hero-stat-item:before {
  content: "";
  background: radial-gradient(circle, #5017d70d, #0000 70%);
  border-radius: 50%;
  width: 60px;
  height: 60px;
  transition: all .3s;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(30%, -30%);
}

.hero-stat-item:after {
  content: "";
  opacity: 0;
  background: #5017d708;
  transition: opacity .3s;
  position: absolute;
  inset: 0;
}

.hero-stat-item:hover {
  border-color: #5017d733;
  transform: translateY(-4px);
  box-shadow: 0 6px 16px #5017d71f;
}

.hero-stat-item:hover:before {
  transform: translate(30%, -30%)scale(1.5);
}

.hero-stat-item:hover:after {
  opacity: 1;
}

.hero-stat-number {
  color: #5017d7;
  z-index: 1;
  font-size: 2.25rem;
  font-weight: 800;
  line-height: 1;
  position: relative;
}

.hero-stat-label {
  color: #64748b;
  font-size: .875rem;
  font-weight: 500;
}

.hero-visual {
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  animation: 1s ease-out .4s backwards fadeInLeft;
  display: grid;
  position: relative;
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translateX(40px);
  }

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

.visual-card {
  background: #fff;
  border: 1px solid #5017d714;
  border-radius: 16px;
  padding: 2rem;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 12px #5017d70f;
}

.visual-card:before {
  content: "";
  background: radial-gradient(circle, #b068f00f, #0000 70%);
  border-radius: 50%;
  width: 120px;
  height: 120px;
  transition: all .4s;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(40%, -40%);
}

.visual-card:after {
  content: "";
  transform-origin: 0;
  background: #5017d780;
  width: 100%;
  height: 3px;
  transition: transform .4s;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: scaleX(0);
}

.visual-card:hover {
  border-color: #5017d733;
  transform: translateY(-6px)scale(1.02);
  box-shadow: 0 12px 32px #5017d726;
}

.visual-card:hover:before {
  background: radial-gradient(circle, #5017d71a, #0000 65%);
  transform: translate(40%, -40%)scale(1.4);
}

.visual-card:hover:after {
  transform: scaleX(1);
}

.visual-card:first-child {
  grid-column: span 2;
}

.visual-card:nth-child(2), .visual-card:nth-child(3) {
  transform: translateY(2rem);
}

.visual-icon {
  width: 56px;
  height: 56px;
  color: var(--primary);
  background: #5017d70a;
  border: 1px solid #5017d71a;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  margin-bottom: 1.25rem;
  transition: all .4s;
  display: inline-flex;
}

.visual-card:hover .visual-icon {
  color: #fff;
  background: #5017d7;
  border-color: #0000;
  transform: scale(1.1)rotate(-8deg);
  box-shadow: 0 6px 16px #5017d733;
}

.visual-card h3 {
  color: #1e293b;
  margin-bottom: .625rem;
  font-size: 1.125rem;
  font-weight: 700;
}

.visual-card p {
  color: #64748b;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.7;
}

.section-container {
  z-index: 1;
  max-width: 1300px;
  margin: 0 auto;
  padding: 5rem 2rem;
  position: relative;
}

.section-header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto 4rem;
}

.section-title {
  color: #1e293b;
  margin-bottom: 1rem;
  font-size: 2.25rem;
  font-weight: 800;
  line-height: 1.3;
}

.section-description {
  color: #64748b;
  font-size: 1.0625rem;
  line-height: 1.8;
}

.services-section {
  background: #fff;
  padding-bottom: 8rem;
  position: relative;
}

.services-timeline {
  justify-content: center;
  gap: 6rem;
  max-width: 1200px;
  margin-top: 6rem;
  margin-left: auto;
  margin-right: auto;
  padding: 4rem 2rem;
  display: flex;
  position: relative;
}

.timeline-line {
  background: linear-gradient(to left, #5017d726, #5017d74d, #5017d726);
  height: 2px;
  position: absolute;
  top: 50%;
  left: 10%;
  right: 10%;
  transform: translateY(-50%);
}

.timeline-item {
  flex-direction: column;
  flex: 1;
  align-items: center;
  display: flex;
  position: relative;
}

.timeline-position-top {
  flex-direction: column-reverse;
}

.timeline-position-bottom {
  flex-direction: column;
}

.timeline-dot {
  z-index: 2;
  background: #fff;
  border: 3px solid #5017d7;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  transition: all .3s;
  position: relative;
}

.timeline-item:hover .timeline-dot {
  transform: scale(1.3);
  box-shadow: 0 0 0 8px #5017d71a;
}

.timeline-dot-inner {
  background: #5017d7;
  border-radius: 50%;
  width: 8px;
  height: 8px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.timeline-connector {
  background: linear-gradient(#5017d7, #5017d74d);
  width: 2px;
  height: 60px;
}

.timeline-position-top .timeline-connector {
  background: linear-gradient(to top, #5017d7, #5017d74d);
}

.service-card {
  background: #fff;
  border: 1px solid #5017d714;
  border-radius: 20px;
  flex-direction: column;
  gap: 1rem;
  width: 100%;
  max-width: 320px;
  padding: 2rem;
  transition: all .3s;
  display: flex;
}

.service-card:hover {
  border-color: #5017d733;
  transform: translateY(-8px);
  box-shadow: 0 16px 40px #5017d71f;
}

.service-icon-wrapper {
  color: #5017d7;
  background: #5017d70f;
  border-radius: 14px;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  transition: all .3s;
  display: flex;
}

.service-card:hover .service-icon-wrapper {
  background: #5017d71a;
  transform: scale(1.05);
}

.service-card h3 {
  color: #1e293b;
  margin: 0;
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.3;
}

.service-card p {
  color: #64748b;
  margin: 0;
  font-size: .875rem;
  line-height: 1.6;
}

.service-badge {
  color: #5017d7;
  background: #5017d70d;
  border: 1px solid #5017d71a;
  border-radius: 8px;
  width: fit-content;
  margin-top: auto;
  padding: .375rem .875rem;
  font-size: .75rem;
  font-weight: 600;
  display: inline-flex;
}

.cta-floating-wrapper {
  z-index: 10;
  margin-top: -120px;
  margin-bottom: -120px;
  padding: 0 2rem;
  position: relative;
}

.cta-section {
  background: #fff;
  border: 2px solid #5017d71f;
  border-radius: 32px;
  max-width: 1000px;
  margin: 0 auto;
  padding: 4rem;
  transition: all .4s;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 60px #00000014;
}

.cta-section:hover {
  border-color: #5017d740;
  transform: translateY(-8px);
  box-shadow: 0 24px 60px #5017d726;
}

.cta-bg-pattern {
  pointer-events: none;
  background: radial-gradient(circle, #5017d70a, #0000 70%);
  border-radius: 50%;
  width: 600px;
  height: 600px;
  animation: 8s ease-in-out infinite ctaPulse;
  position: absolute;
  top: -50%;
  right: -20%;
}

@keyframes ctaPulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1)translate(0);
  }

  50% {
    opacity: .8;
    transform: scale(1.2)translate(-30px, 30px);
  }
}

.cta-content-wrapper {
  z-index: 1;
  align-items: center;
  gap: 3rem;
  display: flex;
  position: relative;
}

.cta-icon-float {
  color: #fff;
  background: linear-gradient(135deg, #5017d7 0%, #7839e8 100%);
  border-radius: 24px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 100px;
  height: 100px;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  animation: 3s ease-in-out infinite ctaIconFloat;
  display: flex;
  box-shadow: 0 12px 32px #5017d74d;
}

@keyframes ctaIconFloat {
  0%, 100% {
    transform: translateY(0)rotate(0);
  }

  50% {
    transform: translateY(-10px)rotate(5deg);
  }
}

.cta-section:hover .cta-icon-float {
  transform: scale(1.1)rotate(10deg);
  box-shadow: 0 16px 48px #5017d766;
}

.cta-text-content {
  flex-direction: column;
  flex: 1;
  gap: .75rem;
  display: flex;
}

.cta-section h3 {
  color: #1e293b;
  margin: 0;
  font-size: 2rem;
  font-weight: 900;
  line-height: 1.2;
}

.cta-section p {
  color: #64748b;
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
}

.cta-button {
  color: #fff;
  background: #5017d7;
  border: none;
  border-radius: 16px;
  flex-shrink: 0;
  align-items: center;
  gap: .75rem;
  padding: 1.125rem 2rem;
  font-size: 1rem;
  font-weight: 700;
  text-decoration: none;
  transition: all .3s cubic-bezier(.34, 1.56, .64, 1);
  display: inline-flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 24px #5017d740;
}

.cta-button:before {
  content: "";
  background: linear-gradient(90deg, #0000, #fff3, #0000);
  width: 100%;
  height: 100%;
  transition: left .5s;
  position: absolute;
  top: 0;
  left: -100%;
}

.cta-button:hover:before {
  left: 100%;
}

.cta-button:hover {
  background: #6028e0;
  transform: scale(1.05);
  box-shadow: 0 12px 32px #5017d759;
}

.cta-button-text {
  z-index: 1;
  position: relative;
}

.cta-button-icon {
  transition: transform .3s;
  display: flex;
}

.cta-button:hover .cta-button-icon {
  transform: translateX(-4px);
}

.cta-glow {
  pointer-events: none;
  background: radial-gradient(circle, #5017d70f, #0000 60%);
  border-radius: 50%;
  width: 400px;
  height: 400px;
  animation: 6s ease-in-out infinite reverse ctaGlowPulse;
  position: absolute;
  bottom: -50%;
  left: -20%;
}

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

  50% {
    opacity: .6;
    transform: scale(1.3);
  }
}

.products-section {
  background: #fafafa;
  padding-top: 8rem;
  position: relative;
  overflow: hidden;
}

.products-bg {
  pointer-events: none;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.products-bg-base {
  background: radial-gradient(at 15% 25%, #8b5cf60a, #0000 45%), radial-gradient(at 85% 20%, #a855f709, #0000 50%), radial-gradient(at 40% 75%, #5017d70b, #0000 48%), radial-gradient(at 90% 80%, #9333ea08, #0000 52%);
  position: absolute;
  inset: 0;
}

.products-bg-shape {
  opacity: 1;
  position: absolute;
}

.products-bg-shape-1 {
  width: 200px;
  height: 200px;
  top: 8%;
  right: 12%;
}

.products-bg-shape-2 {
  width: 180px;
  height: 180px;
  bottom: 15%;
  left: 6%;
}

.products-bg-shape-3 {
  width: 150px;
  height: 150px;
  top: 45%;
  right: 25%;
}

.products-bg-shape-4 {
  width: 120px;
  height: 140px;
  top: 20%;
  left: 8%;
}

.products-bg-shape-5 {
  width: 100px;
  height: 100px;
  bottom: 25%;
  right: 15%;
}

.products-bg-grid {
  opacity: .5;
  background-image: linear-gradient(#5017d705 1px, #0000 1px), linear-gradient(90deg, #5017d705 1px, #0000 1px);
  background-size: 50px 50px;
  position: absolute;
  inset: 0;
  mask-image: radial-gradient(#000 35%, #0000 70%);
}

.products-bg-orb {
  filter: blur(50px);
  border-radius: 50%;
  position: absolute;
}

.products-bg-orb-1 {
  background: radial-gradient(circle, #8b5cf614, #0000 65%);
  width: 380px;
  height: 380px;
  top: -8%;
  right: -3%;
}

.products-bg-orb-2 {
  background: radial-gradient(circle, #a855f712, #0000 60%);
  width: 340px;
  height: 340px;
  bottom: -5%;
  left: -2%;
}

.products-bg-orb-3 {
  background: radial-gradient(circle, #5017d70f, #0000 58%);
  width: 280px;
  height: 280px;
  top: 40%;
  left: 50%;
  transform: translateX(-50%);
}

.products-bg-lines {
  opacity: 1;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.products-grid {
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(280px, auto);
  gap: 1.25rem;
  display: grid;
}

.product-card:first-child, .product-card:nth-child(4) {
  grid-area: span 2 / span 3;
}

.product-card:nth-child(2), .product-card:nth-child(3), .product-card:nth-child(5) {
  grid-area: span 1 / span 3;
}

.product-card {
  background: #fff;
  border: 1px solid #64789614;
  border-radius: 20px;
  flex-direction: column;
  gap: 1.25rem;
  padding: 2rem;
  text-decoration: none;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 12px #00000008;
}

.product-card:before {
  content: "";
  opacity: 0;
  pointer-events: none;
  background: radial-gradient(circle at 100% 0, #5017d70d 0%, #0000 60%);
  transition: opacity .4s;
  position: absolute;
  inset: 0;
}

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

.product-card:hover {
  border-color: #5017d733;
  transform: translateY(-6px)scale(1.01);
  box-shadow: 0 12px 32px #5017d71f, 0 4px 12px #0000000f;
}

.product-header {
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  display: flex;
}

.product-category {
  color: #475569;
  white-space: nowrap;
  background: #64789614;
  border-radius: 6px;
  padding: .375rem .875rem;
  font-size: .75rem;
  font-weight: 600;
}

.product-status {
  border-radius: 6px;
  align-items: center;
  gap: .375rem;
  padding: .375rem .875rem;
  font-size: .75rem;
  font-weight: 600;
  display: inline-flex;
}

.status-badge-success {
  color: #059669;
  background: #10b98114;
}

.status-badge-warning {
  color: #d97706;
  background: #f59e0b14;
}

.status-badge-info {
  color: #2563eb;
  background: #3b82f614;
}

.product-card h3 {
  color: #1e293b;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
}

.product-card p {
  color: #64748b;
  flex: 1;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.7;
}

.product-link-arrow {
  color: #5017d7;
  align-items: center;
  gap: .5rem;
  margin-top: .5rem;
  font-size: .875rem;
  font-weight: 600;
  transition: all .3s;
  display: inline-flex;
}

.product-card:hover .product-link-arrow {
  gap: .75rem;
}

.product-link-arrow svg {
  transition: transform .3s;
}

.product-card:hover .product-link-arrow svg {
  transform: translateX(-4px);
}

.products-interactive-section {
  background: linear-gradient(#fafbff 0%, #fff 100%);
  position: relative;
}

.products-interactive-grid {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2rem;
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
}

.product-interactive-card {
  cursor: pointer;
  background: #fff;
  border: 1px solid #64748b1a;
  border-radius: 24px;
  flex-direction: column;
  padding: 2.5rem;
  text-decoration: none;
  transition: all .5s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  position: relative;
  overflow: hidden;
}

.product-interactive-card:hover {
  border-color: #0000;
  transform: translateY(-16px)scale(1.02);
  box-shadow: 0 32px 64px #5017d726, 0 0 0 1px #5017d71a, inset 0 1px #ffffff80;
}

.product-card-bg {
  opacity: 0;
  pointer-events: none;
  transition: opacity .5s;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.product-interactive-card:hover .product-card-bg {
  opacity: 1;
}

.product-card-circle {
  background: radial-gradient(circle, var(--card-accent) 0%, transparent 70%);
  opacity: .08;
  border-radius: 50%;
  position: absolute;
}

.product-card-circle-1 {
  width: 300px;
  height: 300px;
  animation: 6s ease-in-out infinite float;
  top: -100px;
  right: -100px;
}

.product-card-circle-2 {
  width: 200px;
  height: 200px;
  animation: 8s ease-in-out infinite reverse float;
  bottom: -50px;
  left: -50px;
}

.product-card-mesh {
  background-image: linear-gradient(45deg, #0000 48%, #5017d705 48% 52%, #0000 52%), linear-gradient(-45deg, #0000 48%, #5017d705 48% 52%, #0000 52%);
  background-size: 40px 40px;
  position: absolute;
  inset: 0;
}

.product-card-top {
  z-index: 2;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
  display: flex;
  position: relative;
}

.product-card-icon-badge {
  background: linear-gradient(135deg, #5017d714, #5017d70a);
  border: 2px solid #5017d71f;
  border-radius: 16px;
  justify-content: center;
  align-items: center;
  width: 56px;
  height: 56px;
  font-size: 1.75rem;
  transition: all .4s;
  display: flex;
}

.product-interactive-card:hover .product-card-icon-badge {
  background: linear-gradient(135deg, #5017d726, #5017d714);
  border-color: #5017d740;
  transform: rotate(-10deg)scale(1.1);
  box-shadow: 0 8px 24px #5017d733;
}

.product-card-category {
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: .5px;
  background: #64748b0f;
  border-radius: 8px;
  padding: 8px 14px;
  font-size: .8125rem;
  font-weight: 700;
  transition: all .3s;
}

.product-interactive-card:hover .product-card-category {
  color: #5017d7;
  background: #5017d71a;
}

.product-card-logo-section {
  z-index: 2;
  justify-content: center;
  margin-bottom: 2rem;
  display: flex;
  position: relative;
}

.product-card-logo-container {
  background: #fff;
  border: 3px solid #5017d714;
  border-radius: 24px;
  justify-content: center;
  align-items: center;
  width: 160px;
  height: 160px;
  transition: all .5s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  box-shadow: 0 4px 12px #0000000a, inset 0 1px #fffc;
}

.product-interactive-card:hover .product-card-logo-container {
  background: linear-gradient(135deg, #fff 0%, #fafbff 100%);
  border-color: #5017d733;
  transform: translateY(-12px)rotate(5deg)scale(1.05);
  box-shadow: 0 20px 40px #5017d726, inset 0 1px #fff;
}

.product-card-content {
  z-index: 2;
  flex: 1;
  margin-bottom: 2rem;
  position: relative;
}

.product-card-title {
  color: #0f172a;
  margin: 0 0 1rem;
  font-size: 1.875rem;
  font-weight: 800;
  line-height: 1.2;
  transition: color .3s;
}

.product-interactive-card:hover .product-card-title {
  color: #5017d7;
}

.product-card-description {
  color: #64748b;
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
}

.product-card-footer {
  z-index: 2;
  border-top: 1px solid #64748b14;
  justify-content: space-between;
  align-items: center;
  padding-top: 1.5rem;
  display: flex;
  position: relative;
}

.product-card-client {
  opacity: .5;
  align-items: center;
  gap: 8px;
  transition: opacity .3s;
  display: flex;
}

.product-card-client span {
  color: #64748b;
  font-size: .875rem;
  font-weight: 600;
}

.product-interactive-card:hover .product-card-client {
  opacity: 1;
}

.product-card-arrow {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #7c3aed);
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  box-shadow: 0 4px 12px #5017d740;
}

.product-interactive-card:hover .product-card-arrow {
  transform: translateX(-8px)scale(1.1);
  box-shadow: 0 8px 24px #5017d766;
}

.product-card-shine {
  pointer-events: none;
  background: linear-gradient(90deg, #0000, #fff6, #0000);
  width: 100%;
  height: 100%;
  transition: right .6s;
  position: absolute;
  top: 0;
  right: -100%;
}

.product-interactive-card:hover .product-card-shine {
  right: 100%;
}

@media (width <= 1024px) {
  .products-interactive-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
  }

  .product-interactive-card {
    padding: 2rem;
  }

  .product-card-logo-container {
    width: 140px;
    height: 140px;
  }

  .product-card-title {
    font-size: 1.625rem;
  }
}

@media (width <= 768px) {
  .products-interactive-grid {
    grid-template-columns: 1fr;
  }

  .product-interactive-card {
    padding: 1.75rem;
  }

  .product-card-logo-container {
    width: 120px;
    height: 120px;
  }

  .product-card-title {
    font-size: 1.5rem;
  }

  .product-interactive-card:hover {
    transform: translateY(-8px)scale(1);
  }
}

.solutions-section {
  background: #fff;
  position: relative;
}

.solutions-grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.75rem;
  display: grid;
}

.solution-card {
  background: #fff;
  border: 1px solid #64789614;
  border-radius: 14px;
  padding: 1.75rem;
  transition: all .3s;
  position: relative;
  box-shadow: 0 2px 8px #00000005;
}

.solution-card:hover {
  border-color: #5017d71a;
  transform: translateY(-4px);
  box-shadow: 0 6px 16px #0000000f;
}

.solution-category {
  color: #475569;
  background: #64789614;
  border-radius: 6px;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1rem;
  padding: .375rem .875rem;
  font-size: .75rem;
  font-weight: 600;
  display: inline-flex;
}

.solution-card h3 {
  color: #1e293b;
  margin-bottom: .875rem;
  font-size: 1.125rem;
  font-weight: 700;
}

.solution-card p {
  color: #64748b;
  margin-bottom: 1.25rem;
  font-size: .9375rem;
  line-height: 1.7;
}

.solution-features {
  flex-direction: column;
  gap: .625rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.solution-features li {
  color: #475569;
  align-items: center;
  gap: .625rem;
  font-size: .875rem;
  display: flex;
}

.solution-features li:before {
  content: "";
  background: #64748b;
  border-radius: 50%;
  flex-shrink: 0;
  width: 5px;
  height: 5px;
}

.cta-section {
  text-align: center;
  background: #fff;
  border: 1px solid #6478961f;
  border-radius: 20px;
  max-width: 900px;
  margin: 4rem auto;
  padding: 3rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 16px #0000000a;
}

.cta-section:before {
  content: "";
  background: radial-gradient(circle, #b068f00a, #0000 70%);
  border-radius: 50%;
  width: 250px;
  height: 250px;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(40%, -40%);
}

.cta-section:after {
  content: "";
  background: radial-gradient(circle, #5017d708, #0000 75%);
  border-radius: 50%;
  width: 200px;
  height: 200px;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translate(-40%, 40%);
}

.cta-section h3 {
  color: #1e293b;
  margin-bottom: 1rem;
  font-size: 1.75rem;
  font-weight: 800;
}

.cta-section p {
  color: #64748b;
  max-width: 600px;
  margin-bottom: 2rem;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.0625rem;
}

.partners-section {
  background: linear-gradient(135deg, #fafafa 0%, #fff 50%, #f8f9fc 100%);
  margin-bottom: 0;
  padding-bottom: 12rem;
  position: relative;
  overflow: hidden;
}

.partners-section:before {
  content: "";
  background: linear-gradient(90deg, #0000, #5017d71a, #0000);
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}

.partners-section:after {
  content: "";
  pointer-events: none;
  background: radial-gradient(circle, #5017d705, #0000 70%);
  border-radius: 50%;
  width: 600px;
  height: 600px;
  position: absolute;
  top: -200px;
  right: -100px;
}

.partners-grid {
  z-index: 1;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.5rem;
  margin-top: 4rem;
  display: grid;
  position: relative;
}

.partner-card {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  cursor: pointer;
  background: #fff9;
  border: 1px solid #5017d714;
  border-radius: 20px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.25rem;
  min-height: 160px;
  padding: 3rem 2rem;
  transition: all .5s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 20px #5017d708;
}

.partner-card:before {
  content: "";
  opacity: 0;
  z-index: -1;
  background: linear-gradient(135deg, #5017d705, #b068f005);
  transition: opacity .5s;
  position: absolute;
  inset: 0;
}

.partner-card:after {
  content: "";
  transform-origin: 0;
  background: linear-gradient(90deg, #5017d7, #b068f0, #5017d7) 0 0 / 200% 100%;
  height: 3px;
  transition: transform .5s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  transform: scaleX(0);
}

.partner-card:hover {
  background: #fffffff2;
  border-color: #5017d733;
  transform: translateY(-10px)scale(1.02);
  box-shadow: 0 16px 48px #5017d726;
}

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

.partner-card:hover:after {
  animation: 2s ease-in-out infinite shimmerGradient;
  transform: scaleX(1);
}

@keyframes shimmerGradient {
  0% {
    background-position: 0%;
  }

  50% {
    background-position: 100%;
  }

  100% {
    background-position: 0%;
  }
}

.partner-logo-wrapper {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 60px;
  transition: all .5s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: relative;
}

.partner-logo-wrapper:before {
  content: "";
  opacity: 0;
  background: radial-gradient(circle, #5017d70d, #0000 70%);
  border-radius: 50%;
  transition: opacity .5s;
  position: absolute;
  inset: -10px;
}

.partner-card:hover .partner-logo-wrapper:before {
  opacity: 1;
}

.partner-logo {
  object-fit: contain;
  opacity: .7;
  width: auto;
  height: 58px;
  transition: all .5s cubic-bezier(.4, 0, .2, 1);
}

.partner-card:hover .partner-logo {
  opacity: 1;
  transform: scale(1.1);
}

.partner-name {
  color: #94a3b8;
  text-align: center;
  opacity: .7;
  letter-spacing: .02em;
  font-size: .875rem;
  font-weight: 600;
  transition: all .5s cubic-bezier(.4, 0, .2, 1);
  transform: translateY(5px);
}

.partner-card:hover .partner-name {
  opacity: 1;
  color: #5017d7;
  transform: translateY(0);
}

.services-section:after {
  content: "";
  pointer-events: none;
  z-index: 0;
  background-image: radial-gradient(circle, #64789604 1px, #0000 1px);
  background-size: 30px 30px;
  position: absolute;
  inset: 0;
}

.products-section:after {
  content: "";
  pointer-events: none;
  z-index: 0;
  background-image: linear-gradient(45deg, #64789603 25%, #0000 25%), linear-gradient(-45deg, #64789603 25%, #0000 25%), linear-gradient(45deg, #0000 75%, #64789603 75%), linear-gradient(-45deg, #0000 75%, #64789603 75%);
  background-position: 0 0, 0 25px, 25px -25px, -25px 0;
  background-size: 50px 50px;
  position: absolute;
  inset: 0;
}

@media (width <= 1200px) {
  .hero-container {
    gap: 3rem;
  }
}

@media (width <= 1024px) {
  .hero-section {
    padding: 9rem 2rem 5rem;
  }

  .hero-container {
    grid-template-columns: 1fr;
    gap: 4rem;
  }

  .hero-visual {
    order: -1;
  }

  .services-timeline {
    gap: 3rem;
    padding: 3rem 1.5rem;
  }

  .timeline-line {
    left: 5%;
    right: 5%;
  }

  .service-card {
    max-width: 280px;
    padding: 1.75rem;
  }

  .timeline-connector {
    height: 50px;
  }

  .services-section {
    padding-bottom: 6rem;
  }

  .products-section {
    padding-top: 6rem;
  }

  .products-bg-shape-1 {
    width: 140px;
    height: 140px;
  }

  .products-bg-shape-2 {
    width: 130px;
    height: 130px;
  }

  .products-bg-shape-3 {
    width: 110px;
    height: 110px;
  }

  .products-bg-shape-4 {
    width: 90px;
    height: 105px;
  }

  .products-bg-shape-5 {
    width: 75px;
    height: 75px;
  }

  .products-bg-orb-1, .products-bg-orb-2 {
    width: 280px;
    height: 280px;
  }

  .products-bg-orb-3 {
    width: 220px;
    height: 220px;
  }

  .cta-floating-wrapper {
    margin-top: -100px;
    margin-bottom: -100px;
    padding: 0 1.5rem;
  }

  .cta-section {
    padding: 3rem 2rem;
  }

  .cta-content-wrapper {
    gap: 2rem;
  }

  .cta-icon-float {
    width: 80px;
    height: 80px;
  }

  .cta-icon-float svg {
    width: 36px;
    height: 36px;
  }

  .cta-section h3 {
    font-size: 1.625rem;
  }

  .cta-button {
    padding: 1rem 1.75rem;
  }

  .products-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: minmax(260px, auto);
  }

  .product-card:first-child, .product-card:nth-child(4) {
    grid-area: span 1 / span 2;
  }

  .product-card:nth-child(2), .product-card:nth-child(3), .product-card:nth-child(5) {
    grid-area: span 1 / span 1;
  }

  .solutions-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  }
}

@media (width <= 768px) {
  .hero-section {
    min-height: auto;
    padding: 8rem 1.5rem 4rem;
  }

  .hero-container {
    flex-direction: column;
    display: flex;
  }

  .hero-content {
    order: 1;
  }

  .hero-logo-container {
    margin-top: 4rem;
  }

  .hero-visual {
    display: none;
  }

  .hero-bg-gradient-1 {
    width: 400px;
    height: 400px;
    top: -100px;
    right: -50px;
  }

  .hero-bg-gradient-2 {
    width: 350px;
    height: 350px;
    bottom: -100px;
    left: -50px;
  }

  .hero-bg-gradient-3 {
    width: 300px;
    height: 300px;
  }

  .hero-bg-circle-1 {
    width: 200px;
    height: 200px;
  }

  .hero-bg-circle-1:before {
    width: 160px;
    height: 160px;
  }

  .hero-bg-circle-2 {
    width: 150px;
    height: 150px;
  }

  .hero-bg-circle-3 {
    width: 100px;
    height: 100px;
  }

  .hero-bg-line-1, .hero-bg-line-2 {
    height: 200px;
  }

  .hero-background:before {
    background-size: 40px 40px;
  }

  .hero-title {
    font-size: 2.5rem;
  }

  .hero-description {
    font-size: 1rem;
  }

  .hero-stats {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .hero-stat-number {
    font-size: 2rem;
  }

  .visual-card:first-child {
    grid-column: span 1;
  }

  .visual-card:nth-child(2), .visual-card:nth-child(3) {
    transform: translateY(0);
  }

  .products-bg-shape-1 {
    width: 100px;
    height: 100px;
  }

  .products-bg-shape-2 {
    width: 95px;
    height: 95px;
  }

  .products-bg-shape-3 {
    width: 85px;
    height: 85px;
  }

  .products-bg-shape-4 {
    width: 70px;
    height: 82px;
  }

  .products-bg-shape-5 {
    width: 60px;
    height: 60px;
  }

  .products-bg-orb-1, .products-bg-orb-2 {
    width: 200px;
    height: 200px;
  }

  .products-bg-orb-3 {
    width: 160px;
    height: 160px;
  }

  .products-bg-grid {
    background-size: 35px 35px;
  }

  .section-container {
    padding: 3.5rem 1.5rem;
  }

  .section-title {
    font-size: 1.875rem;
  }

  .services-timeline {
    flex-direction: column;
    gap: 2rem;
    margin-top: 3rem;
    padding: 2rem 1rem;
  }

  .timeline-line {
    display: none;
  }

  .timeline-item {
    flex-direction: column !important;
  }

  .timeline-dot, .timeline-connector {
    display: none;
  }

  .service-card {
    max-width: 100%;
    padding: 1.75rem;
  }

  .service-icon-wrapper {
    width: 56px;
    height: 56px;
  }

  .service-card h3 {
    font-size: 1.125rem;
  }

  .service-card:hover {
    transform: translateY(-4px);
  }

  .products-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
    gap: 1.25rem;
  }

  .product-card:first-child, .product-card:nth-child(4), .product-card:nth-child(2), .product-card:nth-child(3), .product-card:nth-child(5) {
    grid-area: span 1 / span 1;
  }

  .solutions-grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  .services-section {
    padding-bottom: 4rem;
  }

  .products-section {
    padding-top: 4rem;
  }

  .cta-floating-wrapper {
    margin-top: -80px;
    margin-bottom: -80px;
    padding: 0 1rem;
  }

  .cta-section {
    border-radius: 24px;
    padding: 2.5rem 1.5rem;
  }

  .cta-content-wrapper {
    text-align: center;
    flex-direction: column;
    gap: 2rem;
  }

  .cta-icon-float {
    width: 72px;
    height: 72px;
    margin: 0 auto;
  }

  .cta-icon-float svg {
    width: 32px;
    height: 32px;
  }

  .cta-section h3 {
    font-size: 1.375rem;
  }

  .cta-section p {
    font-size: .9375rem;
  }

  .cta-button {
    justify-content: center;
    width: 100%;
    padding: 1rem 1.5rem;
    font-size: .9375rem;
  }

  .cta-bg-pattern, .cta-glow {
    display: none;
  }

  .partners-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1.5rem;
  }

  .partners-section {
    padding-bottom: 10rem;
  }
}

@media (width <= 480px) {
  .hero-section {
    padding: 7rem 1rem 3rem;
  }

  .hero-badge {
    padding: .625rem 1.25rem;
    font-size: .8125rem;
  }

  .hero-title {
    font-size: 2rem;
  }

  .cta-button {
    padding: .875rem 1.5rem;
    font-size: .9375rem;
  }

  .section-title {
    font-size: 1.625rem;
  }

  .section-description {
    font-size: 1rem;
  }

  .partners-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }

  .partners-section {
    padding-bottom: 8rem;
  }
}

.contact-cta-section {
  background: linear-gradient(#fff 0%, #fafafa 100%);
  padding: 6rem 2rem 10rem;
  position: relative;
  overflow: hidden;
}

.contact-cta-content {
  background: #fff;
  border: 1px solid #5017d714;
  border-radius: 24px;
  max-width: 900px;
  margin: 0 auto;
  padding: 3.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px #5017d714;
}

.contact-cta-content:before {
  content: "";
  pointer-events: none;
  background: radial-gradient(circle, #5017d70d, #0000 70%);
  border-radius: 50%;
  width: 300px;
  height: 300px;
  position: absolute;
  top: -100px;
  right: -100px;
}

.contact-cta-content:after {
  content: "";
  pointer-events: none;
  background: radial-gradient(circle, #b068f00a, #0000 70%);
  border-radius: 50%;
  width: 250px;
  height: 250px;
  position: absolute;
  bottom: -80px;
  left: -80px;
}

.contact-cta-header {
  text-align: center;
  z-index: 1;
  margin-bottom: 3rem;
  position: relative;
}

.contact-cta-title {
  color: #1e293b;
  background: linear-gradient(135deg, #1e293b 0%, #5017d7 100%);
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 1rem;
  font-size: 2rem;
  font-weight: 800;
}

.contact-cta-description {
  color: #64748b;
  max-width: 600px;
  margin: 0 auto;
  font-size: 1.125rem;
  line-height: 1.7;
}

.contact-cta-info {
  z-index: 1;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 2rem;
  margin-bottom: 3rem;
  display: grid;
  position: relative;
}

.contact-info-item {
  color: inherit;
  background: #5017d705;
  border: 1px solid #5017d714;
  border-radius: 16px;
  align-items: center;
  gap: 1.25rem;
  padding: 1.5rem;
  text-decoration: none;
  transition: all .3s;
  display: flex;
}

.contact-info-item:hover {
  background: #5017d70d;
  border-color: #5017d726;
  transform: translateY(-2px);
  box-shadow: 0 4px 16px #5017d71a;
}

.contact-info-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7 0%, #b068f0 100%);
  border-radius: 12px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  display: flex;
  box-shadow: 0 4px 12px #5017d733;
}

.contact-info-details {
  flex-direction: column;
  gap: .25rem;
  display: flex;
}

.contact-info-label {
  color: #64748b;
  font-size: .875rem;
  font-weight: 600;
}

.contact-info-value {
  color: #1e293b;
  text-align: right;
  direction: ltr;
  font-size: 1.125rem;
  font-weight: 700;
}

.contact-cta-buttons {
  z-index: 1;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  display: flex;
  position: relative;
}

@media (width <= 768px) {
  .contact-cta-section {
    padding: 4rem 1.5rem 8rem;
  }

  .contact-cta-content {
    padding: 2.5rem 1.5rem;
  }

  .contact-cta-title {
    font-size: 1.625rem;
  }

  .contact-cta-description {
    font-size: 1rem;
  }

  .contact-cta-info {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  .contact-cta-buttons {
    flex-direction: column;
  }

  .cta-button {
    justify-content: center;
    width: 100%;
  }
}

@media (width <= 480px) {
  .contact-cta-content {
    padding: 2rem 1.25rem;
  }

  .contact-cta-title {
    font-size: 1.375rem;
  }

  .contact-info-item {
    padding: 1.25rem;
  }

  .contact-info-icon {
    width: 40px;
    height: 40px;
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }
}

.about-page {
  direction: rtl;
  background: #fff;
  min-height: 100vh;
}

.about-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
}

.section-label {
  align-items: center;
  gap: .75rem;
  margin-bottom: 1rem;
  display: inline-flex;
}

.section-label-line {
  background: linear-gradient(90deg, #5017d7, #b068f0);
  border-radius: 2px;
  width: 40px;
  height: 3px;
}

.section-label span {
  color: #5017d7;
  letter-spacing: .5px;
  font-size: .875rem;
}

.about-hero-section {
  text-align: center;
  background: linear-gradient(#fafaff 0%, #fff 100%);
  padding: 8rem 2rem 4rem;
  position: relative;
  overflow: hidden;
}

.about-hero-pattern {
  pointer-events: none;
  background-image: radial-gradient(circle at 20% 20%, #5017d70f 0%, #0000 50%), radial-gradient(circle at 80% 80%, #b068f00f 0%, #0000 50%), radial-gradient(circle, #5017d708 1px, #0000 1px);
  background-size: 100% 100%, 100% 100%, 30px 30px;
  position: absolute;
  inset: 0;
}

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

.about-hero-badge {
  color: #5017d7;
  background: #fff;
  border: 1.5px solid #5017d726;
  border-radius: 50px;
  align-items: center;
  gap: .5rem;
  margin-bottom: 2.5rem;
  padding: .75rem 1.5rem;
  animation: .8s ease-out fadeInUp;
  display: inline-flex;
  box-shadow: 0 4px 20px #5017d71a;
}

.about-hero-badge svg {
  color: #5017d7;
}

.about-hero-title {
  background: linear-gradient(135deg, #1e293b 0%, #5017d7 50%, #b068f0 100%);
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0 0 2rem;
  line-height: 1.3;
  animation: .8s ease-out .2s both fadeInUp;
}

.about-hero-description {
  color: #64748b;
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.9;
  animation: .8s ease-out .6s both fadeInUp;
}

.about-hero-logo {
  justify-content: center;
  margin: 0 0 2.5rem;
  animation: .8s ease-out .4s both fadeInUp;
  display: flex;
}

.about-hero-logo svg {
  color: #5017d7;
  width: auto;
  height: 2.5rem;
}

.about-story-section {
  background: #fff;
  padding: 5rem 0;
}

.about-story-content {
  grid-template-columns: 1fr 1fr;
  align-items: flex-start;
  gap: 3rem;
  display: grid;
}

.about-story-text {
  flex-direction: column;
  gap: 1.25rem;
  display: flex;
}

.about-story-title {
  color: #1e293b;
  margin: 0;
}

.about-story-description {
  color: #64748b;
  margin: 0;
  font-size: 1.0625rem;
  line-height: 1.9;
}

.about-story-highlights {
  flex-direction: column;
  gap: 1rem;
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.about-story-highlight-item {
  background: linear-gradient(135deg, #5017d708, #b068f008);
  border: 1.5px solid #5017d714;
  border-radius: 14px;
  align-items: flex-start;
  gap: .875rem;
  padding: 1.25rem;
  transition: all .3s;
  display: flex;
}

.about-story-highlight-item:hover {
  background: linear-gradient(135deg, #5017d70d, #b068f00d);
  border-color: #5017d733;
  transform: translateX(-4px);
}

.highlight-icon {
  color: #5017d7;
  flex-shrink: 0;
  margin-top: .125rem;
}

.about-story-highlight-item span {
  color: #475569;
  font-size: .9375rem;
  line-height: 1.7;
}

.about-story-visual {
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  display: grid;
  position: relative;
}

.story-visual-card {
  background: #fff;
  border: 1.5px solid #5017d71a;
  border-radius: 20px;
  flex-direction: column;
  gap: 1rem;
  padding: 2rem;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  box-shadow: 0 4px 20px #5017d70f;
}

.story-card-1 {
  grid-area: 1 / 1 / 2 / 2;
}

.story-card-2 {
  grid-area: 1 / 2 / 2 / 3;
  margin-top: 2rem;
}

.story-card-3 {
  grid-area: 2 / 1 / 3 / 3;
}

.story-visual-card:hover {
  border-color: #5017d740;
  transform: translateY(-8px);
  box-shadow: 0 12px 40px #5017d726;
}

.story-card-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d71a, #b068f01a);
  border-radius: 16px;
  justify-content: center;
  align-items: center;
  width: 64px;
  height: 64px;
  transition: all .3s;
  display: flex;
}

.story-visual-card:hover .story-card-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1)rotate(-5deg);
}

.story-card-text {
  color: #1e293b;
  font-size: 1.0625rem;
  line-height: 1.6;
}

.about-stats-section {
  background: linear-gradient(135deg, #5017d7 0%, #7b3fe4 100%);
  padding: 4rem 0;
  position: relative;
  overflow: hidden;
}

.about-stats-section:before {
  content: "";
  pointer-events: none;
  background-image: radial-gradient(circle at 20% 30%, #ffffff1a 0%, #0000 50%), radial-gradient(circle at 80% 70%, #ffffff14 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

.about-stats-header {
  text-align: center;
  z-index: 1;
  margin-bottom: 3rem;
  position: relative;
}

.about-stats-title {
  color: #fff;
  margin: 0;
}

.about-stats-grid {
  z-index: 1;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  display: grid;
  position: relative;
}

.about-stat-card {
  text-align: center;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff1a;
  border: 1.5px solid #ffffff26;
  border-radius: 20px;
  padding: 2.5rem 1.5rem;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  animation: .8s ease-out both fadeInUp;
}

.about-stat-card:hover {
  background: #ffffff26;
  border-color: #ffffff4d;
  transform: translateY(-8px);
  box-shadow: 0 12px 40px #0003;
}

.stat-number {
  color: #fff;
  justify-content: center;
  align-items: baseline;
  gap: .25rem;
  margin-bottom: .75rem;
  font-size: 3rem;
  display: flex;
}

.stat-suffix {
  font-size: 2rem;
}

.stat-label {
  color: #ffffffe6;
  font-size: 1rem;
}

.about-values-section {
  background: #fafaff;
  padding: 5rem 0;
}

.about-values-header {
  text-align: center;
  margin-bottom: 3rem;
}

.about-values-title {
  color: #1e293b;
  margin: 0;
}

.about-values-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  display: grid;
}

.about-value-card {
  background: #fff;
  border: 1.5px solid #5017d71a;
  border-radius: 20px;
  padding: 2.5rem;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  animation: .8s ease-out both fadeInUp;
  box-shadow: 0 4px 20px #5017d70f;
}

.about-value-card:hover {
  border-color: #5017d740;
  transform: translateY(-8px);
  box-shadow: 0 12px 40px #5017d726;
}

.value-card-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d71a, #b068f01a);
  border-radius: 18px;
  justify-content: center;
  align-items: center;
  width: 72px;
  height: 72px;
  margin-bottom: 1.5rem;
  transition: all .3s;
  display: flex;
}

.about-value-card:hover .value-card-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1)rotate(-5deg);
}

.value-card-title {
  color: #1e293b;
  margin: 0 0 1rem;
}

.value-card-description {
  color: #64748b;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.8;
}

.about-team-section {
  background: #fff;
  padding: 5rem 0;
}

.about-team-header {
  text-align: center;
  margin-bottom: 3rem;
}

.about-team-title {
  color: #1e293b;
  margin: 0;
}

.about-team-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  display: grid;
}

.about-team-card {
  text-align: center;
  background: #fff;
  border: 1.5px solid #5017d71a;
  border-radius: 20px;
  padding: 2.5rem;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  animation: .8s ease-out both fadeInUp;
  box-shadow: 0 4px 20px #5017d70f;
}

.about-team-card:hover {
  border-color: #5017d740;
  transform: translateY(-8px);
  box-shadow: 0 12px 40px #5017d726;
}

.team-card-avatar {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d71a, #b068f01a);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 96px;
  height: 96px;
  margin: 0 auto 1.5rem;
  font-size: 2rem;
  transition: all .3s;
  display: flex;
}

.about-team-card:hover .team-card-avatar {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1);
}

.team-card-name {
  color: #1e293b;
  margin: 0 0 .5rem;
}

.team-card-role {
  color: #5017d7;
  margin-bottom: 1rem;
  font-size: .875rem;
}

.team-card-bio {
  color: #64748b;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.7;
}

.about-mission-section {
  background: linear-gradient(#fafaff 0%, #fff 100%);
  padding: 5rem 0;
}

.about-mission-content {
  grid-template-columns: 1fr 1fr;
  align-items: flex-start;
  gap: 3rem;
  display: grid;
}

.about-mission-title {
  color: #1e293b;
  margin: 0 0 1.5rem;
}

.about-mission-description {
  color: #64748b;
  margin: 0;
  font-size: 1.0625rem;
  line-height: 1.9;
}

.about-mission-goals {
  flex-direction: column;
  gap: 1.5rem;
  display: flex;
}

.mission-goal-item {
  background: #fff;
  border: 1.5px solid #5017d71a;
  border-radius: 20px;
  gap: 1.5rem;
  padding: 2rem;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  box-shadow: 0 4px 20px #5017d70f;
}

.mission-goal-item:hover {
  border-color: #5017d740;
  transform: translateX(-8px);
  box-shadow: 0 12px 40px #5017d726;
}

.mission-goal-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d71a, #b068f01a);
  border-radius: 16px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 64px;
  height: 64px;
  transition: all .3s;
  display: flex;
}

.mission-goal-item:hover .mission-goal-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1)rotate(-5deg);
}

.mission-goal-content {
  flex: 1;
}

.mission-goal-title {
  color: #1e293b;
  margin: 0 0 .5rem;
  font-size: 1.125rem;
}

.mission-goal-description {
  color: #64748b;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.7;
}

.about-cta-section {
  background: #fff;
  padding: 5rem 0 6rem;
}

.about-cta-card {
  background: linear-gradient(135deg, #5017d7 0%, #7b3fe4 100%);
  border-radius: 24px;
  justify-content: space-between;
  align-items: center;
  gap: 3rem;
  padding: 3.5rem;
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 60px #5017d740;
}

.about-cta-card:before {
  content: "";
  pointer-events: none;
  background-image: radial-gradient(circle at 20% 30%, #ffffff1a 0%, #0000 50%), radial-gradient(circle at 80% 70%, #ffffff14 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

.about-cta-content {
  z-index: 1;
  flex: 1;
  position: relative;
}

.about-cta-title {
  color: #fff;
  margin: 0 0 1rem;
}

.about-cta-description {
  color: #ffffffe6;
  margin: 0 0 2rem;
  font-size: 1.125rem;
  line-height: 1.8;
}

.about-cta-buttons {
  flex-wrap: wrap;
  gap: 1rem;
  display: flex;
}

.cta-button {
  cursor: pointer;
  border: none;
  border-radius: 12px;
  align-items: center;
  gap: .5rem;
  padding: 1rem 2rem;
  font-family: inherit;
  font-size: 1rem;
  text-decoration: none;
  transition: all .3s;
  display: inline-flex;
}

.cta-button-primary {
  color: #5017d7;
  background: #fff;
  box-shadow: 0 4px 16px #fff3;
}

.cta-button-primary:hover {
  background: #f8f9ff;
  transform: translateY(-3px);
  box-shadow: 0 8px 24px #ffffff4d;
}

.cta-button-secondary {
  color: #fff;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff26;
  border: 1.5px solid #ffffff4d;
}

.cta-button-secondary:hover {
  background: #ffffff40;
  border-color: #ffffff80;
  transform: translateY(-3px);
}

.about-cta-visual {
  flex-shrink: 0;
  width: 200px;
  height: 200px;
  position: relative;
}

.cta-visual-circle {
  border: 2px solid #fff3;
  border-radius: 50%;
  position: absolute;
}

.cta-circle-1 {
  width: 200px;
  height: 200px;
  animation: 4s ease-in-out infinite pulse;
  top: 0;
  left: 0;
}

.cta-circle-2 {
  width: 150px;
  height: 150px;
  animation: 4s ease-in-out 1s infinite pulse;
  top: 25px;
  left: 25px;
}

.cta-circle-3 {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff1a;
  width: 100px;
  height: 100px;
  animation: 4s ease-in-out 2s infinite pulse;
  top: 50px;
  left: 50px;
}

@media (width <= 1024px) {
  .about-story-content, .about-mission-content {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .about-mission-text {
    position: static;
  }

  .about-stats-grid, .about-values-grid, .about-team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (width <= 768px) {
  .about-container {
    padding: 0 1.5rem;
  }

  .about-hero-section {
    padding: 7rem 1.5rem 3rem;
  }

  .about-story-section, .about-values-section, .about-team-section, .about-mission-section {
    padding: 3.5rem 0;
  }

  .about-stats-section, .about-cta-section {
    padding: 3rem 0;
  }

  .about-stats-grid, .about-values-grid, .about-team-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .about-cta-card {
    flex-direction: column;
    padding: 3rem 2rem;
  }

  .about-cta-visual {
    display: none;
  }

  .about-cta-buttons {
    flex-direction: column;
  }

  .cta-button {
    justify-content: center;
    width: 100%;
  }

  .about-story-visual {
    grid-template-columns: 1fr;
  }

  .story-card-1, .story-card-2, .story-card-3 {
    grid-column: 1;
    margin-top: 0;
  }
}

@media (width <= 480px) {
  .about-hero-section {
    padding: 6rem 1rem 2.5rem;
  }

  .about-hero-description {
    font-size: 1rem;
  }

  .about-story-section, .about-values-section, .about-team-section, .about-mission-section {
    padding: 3rem 0;
  }

  .about-stats-section, .about-cta-section {
    padding: 2.5rem 0;
  }

  .stat-number {
    font-size: 2.5rem;
  }

  .stat-suffix {
    font-size: 1.75rem;
  }

  .about-cta-card {
    padding: 2.5rem 1.5rem;
  }

  .about-cta-title {
    font-size: 1.5rem;
  }

  .about-cta-description {
    font-size: 1rem;
  }
}

.ds-page {
  direction: rtl;
  background: #fff;
  min-height: 100vh;
}

.ds-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
}

.ds-hero-section {
  background: linear-gradient(135deg, #5017d7 0%, #7b3fe8 100%);
  padding: 8rem 2rem 6rem;
  position: relative;
  overflow: hidden;
}

.ds-hero-pattern {
  pointer-events: none;
  background-image: radial-gradient(circle at 20% 30%, #ffffff1a 0%, #0000 50%), radial-gradient(circle at 80% 70%, #ffffff14 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

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

.ds-hero-content {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 4rem;
  display: grid;
}

.ds-hero-text {
  color: #fff;
}

.ds-hero-badge {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: #fff;
  background: #ffffff26;
  border: 1px solid #fff3;
  border-radius: 50px;
  align-items: center;
  gap: .5rem;
  margin-bottom: 2rem;
  padding: .625rem 1.25rem;
  font-size: .875rem;
  display: inline-flex;
}

.ds-hero-title {
  color: #fff;
  margin: 0 0 1.5rem;
  font-size: 3rem;
  line-height: 1.2;
}

.ds-hero-description {
  color: #ffffffe6;
  margin-bottom: 2rem;
  font-size: 1.125rem;
  line-height: 1.8;
}

.ds-hero-actions-row {
  flex-wrap: wrap;
  align-items: center;
  gap: 1.5rem;
  display: flex;
}

.ds-hero-cta {
  color: #5017d7;
  background: #fff;
  border-radius: 12px;
  align-items: center;
  gap: .75rem;
  padding: 1rem 2rem;
  font-size: 1.0625rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s;
  display: inline-flex;
  box-shadow: 0 4px 20px #00000026;
}

.ds-hero-cta:hover {
  background: #fffffff2;
  transform: translateY(-2px);
  box-shadow: 0 8px 30px #00000040;
}

.ds-hero-cta svg {
  transition: transform .3s;
}

.ds-hero-cta:hover svg {
  transform: translateX(-4px);
}

.ds-hero-stats {
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 3rem;
  display: grid;
}

.ds-stat-item {
  text-align: center;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff1a;
  border: 1px solid #ffffff26;
  border-radius: 16px;
  padding: 1.5rem;
  transition: all .3s;
}

.ds-stat-item:hover {
  background: #ffffff26;
  border-color: #ffffff4d;
  transform: translateY(-4px);
}

.ds-stat-number {
  color: #fff;
  margin-bottom: .5rem;
  font-size: 2.5rem;
  font-weight: 800;
  display: block;
}

.ds-stat-label {
  color: #ffffffd9;
  font-size: .9375rem;
  display: block;
}

.ds-hero-visual {
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.ds-hero-circle {
  justify-content: center;
  align-items: center;
  width: 400px;
  height: 400px;
  display: flex;
  position: relative;
}

.ds-hero-circle-bg {
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background: #ffffff1a;
  border: 2px solid #fff3;
  border-radius: 50%;
  animation: 3s ease-in-out infinite pulse-circle;
  position: absolute;
  inset: 0;
}

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

  50% {
    opacity: .8;
    transform: scale(1.05);
  }
}

.ds-hero-logo {
  z-index: 2;
  filter: drop-shadow(0 10px 30px #0003);
  aspect-ratio: 464 / 249;
  width: 280px;
  position: relative;
}

.ds-hero-client-badge {
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background: #ffffff26;
  border: 1px solid #ffffff40;
  border-radius: 12px;
  align-items: center;
  gap: 1rem;
  width: fit-content;
  padding: .75rem 1.25rem;
  display: flex;
}

.ds-hero-client-logo {
  background: #fff;
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  padding: .5rem;
  display: flex;
}

.ds-hero-client-logo svg {
  object-fit: contain;
  width: 100%;
  height: 100%;
}

.ds-hero-client-text {
  color: #fff;
  white-space: nowrap;
  font-size: .9375rem;
  font-weight: 500;
}

.ds-section {
  padding: 6rem 2rem;
}

.ds-section-alt {
  background: linear-gradient(#fafaff 0%, #fff 100%);
}

.ds-section-header {
  text-align: center;
  margin-bottom: 4rem;
}

.ds-section-label {
  color: #5017d7;
  background: #5017d714;
  border-radius: 20px;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1rem;
  padding: .5rem 1rem;
  font-size: .875rem;
  font-weight: 600;
  display: inline-flex;
}

.ds-section-title {
  color: #1a1a1a;
  margin: 0 0 1rem;
  font-size: 2.5rem;
  line-height: 1.3;
}

.ds-section-description {
  color: #666;
  max-width: 700px;
  margin: 0 auto;
  font-size: 1.125rem;
  line-height: 1.7;
}

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

.ds-platform-card {
  text-align: center;
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 20px;
  padding: 2.5rem;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  position: relative;
  overflow: hidden;
}

.ds-platform-card:before {
  content: "";
  transform-origin: 100%;
  background: linear-gradient(90deg, #5017d7, #b068f0);
  height: 4px;
  transition: transform .4s;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  transform: scaleX(0);
}

.ds-platform-card:hover:before {
  transform: scaleX(1);
}

.ds-platform-card:hover {
  border-color: #5017d7;
  transform: translateY(-8px);
  box-shadow: 0 20px 60px #5017d726;
}

.ds-platform-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d714, #b068f014);
  border-radius: 20px;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  margin-bottom: 1.5rem;
  transition: all .4s;
  display: inline-flex;
}

.ds-platform-card:hover .ds-platform-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1)rotate(-5deg);
}

.ds-platform-title {
  color: #1a1a1a;
  margin: 0 0 .75rem;
  font-size: 1.375rem;
}

.ds-platform-description {
  color: #666;
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
}

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

.ds-feature-card {
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 16px;
  padding: 2rem;
  transition: all .3s;
  position: relative;
}

.ds-feature-card:hover {
  border-color: #5017d7;
  transform: translateY(-4px);
  box-shadow: 0 12px 40px #5017d71f;
}

.ds-feature-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d714, #b068f014);
  border-radius: 16px;
  justify-content: center;
  align-items: center;
  width: 64px;
  height: 64px;
  margin-bottom: 1.5rem;
  transition: all .3s;
  display: inline-flex;
}

.ds-feature-card:hover .ds-feature-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.05);
}

.ds-feature-title {
  color: #1a1a1a;
  margin: 0 0 .75rem;
  font-size: 1.25rem;
}

.ds-feature-description {
  color: #666;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.7;
}

.ds-enterprise-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
}

.ds-enterprise-item {
  color: #333;
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 12px;
  align-items: center;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  font-size: .9375rem;
  transition: all .3s;
  display: flex;
}

.ds-enterprise-item:hover {
  background: #5017d705;
  border-color: #5017d7;
  transform: translateX(-4px);
}

.ds-enterprise-item svg {
  color: #10b981;
  flex-shrink: 0;
}

.ds-legal-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
}

.ds-legal-card {
  color: #fff;
  text-align: center;
  background: linear-gradient(135deg, #5017d7 0%, #7b3fe8 100%);
  border-radius: 20px;
  padding: 2.5rem;
  transition: all .4s;
  position: relative;
  overflow: hidden;
}

.ds-legal-card:before {
  content: "";
  opacity: 0;
  background: radial-gradient(circle, #ffffff1a 0%, #0000 70%);
  transition: opacity .4s;
  position: absolute;
  inset: 0;
}

.ds-legal-card:hover:before {
  opacity: 1;
}

.ds-legal-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 60px #5017d74d;
}

.ds-legal-icon {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: #fff;
  background: #ffffff26;
  border: 1px solid #fff3;
  border-radius: 18px;
  justify-content: center;
  align-items: center;
  width: 72px;
  height: 72px;
  margin-bottom: 1.5rem;
  display: inline-flex;
}

.ds-legal-title {
  color: #fff;
  margin: 0 0 .75rem;
  font-size: 1.375rem;
}

.ds-legal-description {
  color: #ffffffe6;
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
}

.ds-usecases-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  max-width: 900px;
  margin: 0 auto;
  display: grid;
}

.ds-usecase-item {
  color: #333;
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 12px;
  align-items: center;
  gap: .875rem;
  padding: 1rem 1.25rem;
  font-size: .9375rem;
  transition: all .3s;
  display: flex;
}

.ds-usecase-item:hover {
  background: #5017d705;
  border-color: #5017d7;
  transform: translateX(-4px);
  box-shadow: 0 4px 12px #5017d714;
}

.ds-usecase-item svg {
  color: #5017d7;
  flex-shrink: 0;
}

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

.ds-faq-item {
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 16px;
  transition: all .3s;
  overflow: hidden;
}

.ds-faq-item:hover {
  border-color: #5017d7;
  box-shadow: 0 4px 20px #5017d714;
}

.ds-faq-question {
  text-align: right;
  cursor: pointer;
  background: none;
  border: none;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  width: 100%;
  padding: 1.5rem 2rem;
  transition: all .3s;
  display: flex;
}

.ds-faq-question:hover {
  background: #5017d705;
}

.ds-faq-question h3 {
  color: #1a1a1a;
  flex: 1;
  margin: 0;
  font-size: 1.125rem;
}

.ds-faq-icon {
  color: #5017d7;
  flex-shrink: 0;
  transition: transform .3s;
}

.ds-faq-icon-open {
  transform: rotate(180deg);
}

.ds-faq-answer {
  padding: 0 2rem 1.5rem;
  animation: .3s slideDown;
}

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

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

.ds-faq-answer p {
  color: #666;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.8;
}

.ds-cta-section {
  background: linear-gradient(135deg, #5017d7 0%, #7b3fe8 100%);
  padding: 6rem 2rem;
  position: relative;
  overflow: hidden;
}

.ds-cta-pattern {
  pointer-events: none;
  background-image: radial-gradient(circle at 30% 40%, #ffffff1a 0%, #0000 50%), radial-gradient(circle at 70% 60%, #ffffff14 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

.ds-cta-container {
  text-align: center;
  z-index: 1;
  max-width: 800px;
  margin: 0 auto;
  position: relative;
}

.ds-cta-title {
  color: #fff;
  margin: 0 0 1.5rem;
  font-size: 2.5rem;
  line-height: 1.3;
}

.ds-cta-description {
  color: #ffffffe6;
  margin-bottom: 2.5rem;
  font-size: 1.125rem;
  line-height: 1.7;
}

.ds-cta-buttons {
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 1.25rem;
  display: flex;
}

.ds-cta-button {
  border-radius: 12px;
  align-items: center;
  gap: .625rem;
  padding: 1rem 2rem;
  font-size: 1.0625rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s;
  display: inline-flex;
}

.ds-cta-button-primary {
  color: #5017d7;
  background: #fff;
  box-shadow: 0 4px 20px #0003;
}

.ds-cta-button-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px #0000004d;
}

.ds-cta-button-secondary {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: #fff;
  background: #ffffff26;
  border: 1px solid #ffffff4d;
}

.ds-cta-button-secondary:hover {
  background: #ffffff40;
  transform: translateY(-2px);
}

@media (width <= 1024px) {
  .ds-hero-content {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .ds-hero-visual {
    order: -1;
  }

  .ds-hero-circle {
    width: 300px;
    height: 300px;
  }

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

@media (width <= 768px) {
  .ds-hero-section {
    padding: 6rem 1.5rem 4rem;
  }

  .ds-hero-title {
    font-size: 2.25rem;
  }

  .ds-hero-stats {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .ds-section {
    padding: 4rem 1.5rem;
  }

  .ds-section-title {
    font-size: 2rem;
  }

  .ds-platforms-grid, .ds-features-grid, .ds-legal-grid, .ds-enterprise-grid, .ds-usecases-grid {
    grid-template-columns: 1fr;
  }

  .ds-cta-title {
    font-size: 2rem;
  }
}

@media (width <= 480px) {
  .ds-hero-title {
    font-size: 1.875rem;
  }

  .ds-hero-circle {
    width: 250px;
    height: 250px;
  }

  .ds-section-title {
    font-size: 1.75rem;
  }

  .ds-cta-buttons {
    flex-direction: column;
    width: 100%;
  }

  .ds-cta-button {
    justify-content: center;
    width: 100%;
  }
}

.dm-page {
  direction: rtl;
  background: #fff;
  min-height: 100vh;
}

.dm-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
}

.dm-hero-section {
  background: linear-gradient(#fafaff 0%, #fff 100%);
  padding: 8rem 2rem 6rem;
  position: relative;
  overflow: hidden;
}

.dm-hero-pattern {
  pointer-events: none;
  background-image: radial-gradient(circle at 30% 20%, #5017d714 0%, #0000 50%), radial-gradient(circle at 70% 80%, #b068f00f 0%, #0000 50%), radial-gradient(circle, #5017d708 1px, #0000 1px);
  background-size: 100% 100%, 100% 100%, 30px 30px;
  position: absolute;
  inset: 0;
}

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

.dm-hero-content {
  grid-template-columns: 1.2fr 1fr;
  align-items: center;
  gap: 4rem;
  display: grid;
}

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

.dm-hero-badge {
  color: #5017d7;
  background: #5017d714;
  border: 1px solid #5017d726;
  border-radius: 50px;
  align-items: center;
  gap: .5rem;
  width: fit-content;
  padding: .625rem 1.25rem;
  font-size: .875rem;
  font-weight: 600;
  display: inline-flex;
}

.dm-hero-title {
  background: linear-gradient(135deg, #1e293b 0%, #5017d7 50%, #b068f0 100%);
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0;
  font-size: 3rem;
  line-height: 1.2;
}

.dm-hero-description {
  color: #666;
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.8;
}

.dm-hero-highlights {
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1rem;
  display: flex;
}

.dm-highlight-badge {
  color: #333;
  background: #fff;
  border: 1px solid #5017d726;
  border-radius: 12px;
  align-items: center;
  gap: .5rem;
  padding: .625rem 1rem;
  font-size: .875rem;
  transition: all .3s;
  display: inline-flex;
}

.dm-highlight-badge:hover {
  background: #5017d70d;
  border-color: #5017d7;
  transform: translateY(-2px);
}

.dm-client-badge {
  background: linear-gradient(135deg, #5017d7 0%, #7b3ff2 100%);
  border: 1px solid #fff3;
  border-radius: 12px;
  align-items: center;
  gap: .75rem;
  padding: .625rem 1rem;
  transition: all .3s;
  display: inline-flex;
}

.dm-client-badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px #5017d74d;
}

.dm-client-logo {
  background: #fff;
  border-radius: 6px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  padding: .25rem;
  display: flex;
}

.dm-client-logo svg {
  object-fit: contain;
  width: 100%;
  height: 100%;
}

.dm-client-text {
  color: #fff;
  white-space: nowrap;
  font-size: .875rem;
  font-weight: 500;
}

.dm-hero-visual {
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.dm-hero-circle {
  justify-content: center;
  align-items: center;
  width: 350px;
  height: 350px;
  display: flex;
  position: relative;
}

.dm-hero-circle-bg {
  background: linear-gradient(135deg, #5017d714, #b068f014);
  border: 2px solid #5017d733;
  border-radius: 50%;
  animation: 3s ease-in-out infinite dm-pulse-circle;
  position: absolute;
  inset: 0;
}

@keyframes dm-pulse-circle {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .8;
    transform: scale(1.05);
  }
}

.dm-hero-logo {
  z-index: 2;
  position: relative;
}

.dm-hero-stats {
  position: absolute;
  inset: 0;
}

.dm-stat-floating {
  text-align: center;
  background: #fff;
  border: 1px solid #5017d726;
  border-radius: 16px;
  padding: 1rem 1.5rem;
  animation: 3s ease-in-out infinite dm-float;
  position: absolute;
  box-shadow: 0 8px 24px #5017d71f;
}

.dm-stat-floating:first-child {
  animation-delay: 0s;
  top: 10%;
  right: -10%;
}

.dm-stat-floating:nth-child(2) {
  animation-delay: 1s;
  bottom: 20%;
  right: -15%;
}

.dm-stat-floating:nth-child(3) {
  animation-delay: 2s;
  top: 50%;
  left: -20%;
}

@keyframes dm-float {
  0%, 100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }
}

.dm-stat-number {
  color: #5017d7;
  margin-bottom: .25rem;
  font-size: 1.75rem;
  font-weight: 800;
  display: block;
}

.dm-stat-label {
  color: #666;
  font-size: .8125rem;
  display: block;
}

.dm-section {
  padding: 6rem 2rem;
}

.dm-section-alt {
  background: linear-gradient(#fafaff 0%, #fff 100%);
}

.dm-section-header {
  text-align: center;
  margin-bottom: 4rem;
}

.dm-section-label {
  color: #5017d7;
  background: #5017d714;
  border-radius: 20px;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1rem;
  padding: .5rem 1rem;
  font-size: .875rem;
  font-weight: 600;
  display: inline-flex;
}

.dm-section-title {
  color: #1a1a1a;
  margin: 0 0 1rem;
  font-size: 2.5rem;
  line-height: 1.3;
}

.dm-section-description {
  color: #666;
  max-width: 700px;
  margin: 0 auto;
  font-size: 1.125rem;
  line-height: 1.7;
}

.dm-users-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
}

.dm-user-card {
  text-align: center;
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 16px;
  padding: 2rem;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  position: relative;
  overflow: hidden;
}

.dm-user-card:before {
  content: "";
  transform-origin: 100%;
  background: linear-gradient(90deg, #5017d7, #b068f0);
  height: 3px;
  transition: transform .4s;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  transform: scaleX(0);
}

.dm-user-card:hover:before {
  transform: scaleX(1);
}

.dm-user-card:hover {
  border-color: #5017d7;
  transform: translateY(-8px);
  box-shadow: 0 16px 48px #5017d726;
}

.dm-user-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d714, #b068f014);
  border-radius: 16px;
  justify-content: center;
  align-items: center;
  width: 64px;
  height: 64px;
  margin-bottom: 1.25rem;
  transition: all .4s;
  display: inline-flex;
}

.dm-user-card:hover .dm-user-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1)rotate(-5deg);
}

.dm-user-role {
  color: #1a1a1a;
  margin: 0 0 .75rem;
  font-size: 1.125rem;
}

.dm-user-benefit {
  color: #666;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.6;
}

.dm-features-container {
  flex-direction: column;
  gap: 4rem;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
}

.dm-feature-item {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 4rem;
  display: grid;
}

.dm-feature-item-reverse {
  direction: ltr;
}

.dm-feature-visual {
  justify-content: center;
  align-items: center;
  padding: 3rem;
  display: flex;
  position: relative;
}

.dm-feature-icon-large {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d714, #b068f014);
  border: 2px solid #5017d726;
  border-radius: 30px;
  justify-content: center;
  align-items: center;
  width: 200px;
  height: 200px;
  transition: all .4s;
  display: flex;
  position: relative;
}

.dm-feature-item:hover .dm-feature-icon-large {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.05)rotate(-3deg);
  box-shadow: 0 20px 60px #5017d740;
}

.dm-feature-icon-large:before {
  content: "";
  z-index: -1;
  background: radial-gradient(circle, #5017d71a 0%, #0000 70%);
  border-radius: 50%;
  position: absolute;
  inset: -20px;
}

.dm-feature-content {
  direction: rtl;
  flex-direction: column;
  gap: 1.5rem;
  display: flex;
}

.dm-feature-number {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  font-size: 1.25rem;
  font-weight: 800;
  display: inline-flex;
}

.dm-feature-title {
  color: #1a1a1a;
  margin: 0;
  font-size: 2rem;
  line-height: 1.3;
}

.dm-feature-subtitle {
  color: #5017d7;
  margin: 0;
  font-size: 1.0625rem;
  font-weight: 600;
}

.dm-feature-description {
  color: #666;
  margin: 0;
  font-size: 1rem;
  line-height: 1.8;
}

.dm-feature-list {
  flex-direction: column;
  gap: 1rem;
  margin-top: 1rem;
  display: flex;
}

.dm-feature-list-item {
  background: #5017d708;
  border: 1px solid #5017d71a;
  border-radius: 12px;
  align-items: flex-start;
  gap: .875rem;
  padding: 1rem;
  transition: all .3s;
  display: flex;
}

.dm-feature-list-item:hover {
  background: #5017d70d;
  border-color: #5017d7;
  transform: translateX(-4px);
}

.dm-feature-list-item svg {
  color: #10b981;
  flex-shrink: 0;
  margin-top: 2px;
}

.dm-feature-list-content {
  flex: 1;
}

.dm-feature-list-title {
  color: #1a1a1a;
  margin-right: .25rem;
  font-weight: 600;
}

.dm-feature-list-desc {
  color: #666;
}

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

.dm-faq-item {
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 16px;
  transition: all .3s;
  overflow: hidden;
}

.dm-faq-item:hover {
  border-color: #5017d7;
  box-shadow: 0 4px 20px #5017d714;
}

.dm-faq-question {
  text-align: right;
  cursor: pointer;
  background: none;
  border: none;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  width: 100%;
  padding: 1.5rem 2rem;
  transition: all .3s;
  display: flex;
}

.dm-faq-question:hover {
  background: #5017d705;
}

.dm-faq-question h3 {
  color: #1a1a1a;
  flex: 1;
  margin: 0;
  font-size: 1.125rem;
}

.dm-faq-icon {
  color: #5017d7;
  flex-shrink: 0;
  transition: transform .3s;
}

.dm-faq-icon-open {
  transform: rotate(180deg);
}

.dm-faq-answer {
  padding: 0 2rem 1.5rem;
  animation: .3s dm-slideDown;
}

@keyframes dm-slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

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

.dm-faq-answer p {
  color: #666;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.8;
}

@media (width <= 1024px) {
  .dm-hero-content {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .dm-hero-visual {
    order: -1;
  }

  .dm-hero-circle {
    width: 300px;
    height: 300px;
  }

  .dm-stat-floating {
    display: none;
  }

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

  .dm-feature-item {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .dm-feature-item-reverse {
    direction: rtl;
  }

  .dm-feature-visual {
    order: -1;
  }
}

@media (width <= 768px) {
  .dm-hero-section {
    padding: 6rem 1.5rem 4rem;
  }

  .dm-hero-title {
    font-size: 2.25rem;
  }

  .dm-section {
    padding: 4rem 1.5rem;
  }

  .dm-section-title {
    font-size: 2rem;
  }

  .dm-users-grid {
    grid-template-columns: 1fr;
  }

  .dm-feature-title {
    font-size: 1.75rem;
  }
}

@media (width <= 480px) {
  .dm-hero-title {
    font-size: 1.875rem;
  }

  .dm-hero-circle {
    width: 250px;
    height: 250px;
  }

  .dm-section-title {
    font-size: 1.75rem;
  }

  .dm-feature-icon-large {
    width: 150px;
    height: 150px;
  }
}

.dc-page {
  direction: rtl;
  background: #fff;
  min-height: 100vh;
}

.dc-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
}

.dc-hero-section {
  background: linear-gradient(135deg, #5017d7 0%, #7b3fe8 100%);
  padding: 8rem 2rem 6rem;
  position: relative;
  overflow: hidden;
}

.dc-hero-pattern {
  pointer-events: none;
  background-image: radial-gradient(circle at 20% 30%, #ffffff1a 0%, #0000 50%), radial-gradient(circle at 80% 70%, #ffffff14 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

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

.dc-hero-content {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 4rem;
  display: grid;
}

.dc-hero-text {
  flex-direction: column;
  gap: 2rem;
  display: flex;
}

.dc-hero-badge {
  color: #fff;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff26;
  border: 1px solid #ffffff40;
  border-radius: 50px;
  align-items: center;
  gap: .5rem;
  width: fit-content;
  padding: .75rem 1.5rem;
  font-size: .9375rem;
  font-weight: 600;
  display: inline-flex;
}

.dc-hero-title {
  color: #fff;
  margin: 0;
  font-size: 3rem;
  line-height: 1.2;
}

.dc-hero-description {
  color: #fffffff2;
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.8;
}

.dc-hero-stats {
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 1rem;
  display: grid;
}

.dc-stat-item {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff1a;
  border: 1px solid #fff3;
  border-radius: 16px;
  flex-direction: column;
  gap: .5rem;
  padding: 1.5rem;
  transition: all .3s;
  display: flex;
}

.dc-stat-item:hover {
  background: #ffffff26;
  transform: translateY(-4px);
}

.dc-stat-number {
  color: #fff;
  font-size: 2rem;
  font-weight: 800;
}

.dc-stat-label {
  color: #ffffffe6;
  font-size: .875rem;
}

.dc-hero-visual {
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.dc-hero-circle {
  justify-content: center;
  align-items: center;
  width: 400px;
  height: 400px;
  display: flex;
  position: relative;
}

.dc-hero-circle-bg {
  background: #ffffff1a;
  border: 2px solid #fff3;
  border-radius: 50%;
  animation: 3s ease-in-out infinite dc-pulse-circle;
  position: absolute;
  inset: 0;
}

@keyframes dc-pulse-circle {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .8;
    transform: scale(1.05);
  }
}

.dc-hero-logo {
  z-index: 2;
  position: relative;
}

.dc-section {
  padding: 6rem 2rem;
}

.dc-section-alt {
  background: linear-gradient(#fafaff 0%, #fff 100%);
}

.dc-section-header {
  text-align: center;
  margin-bottom: 4rem;
}

.dc-section-label {
  color: #5017d7;
  background: #5017d714;
  border-radius: 20px;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1rem;
  padding: .5rem 1rem;
  font-size: .875rem;
  font-weight: 600;
  display: inline-flex;
}

.dc-section-title {
  color: #1a1a1a;
  margin: 0 0 1rem;
  font-size: 2.5rem;
  line-height: 1.3;
}

.dc-section-description {
  color: #666;
  max-width: 700px;
  margin: 0 auto;
  font-size: 1.125rem;
  line-height: 1.7;
}

.dc-achievements-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
}

.dc-achievement-card {
  text-align: center;
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 20px;
  padding: 2.5rem 2rem;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  position: relative;
  overflow: hidden;
}

.dc-achievement-card:before {
  content: "";
  transform-origin: 100%;
  background: linear-gradient(90deg, #5017d7, #b068f0);
  height: 4px;
  transition: transform .4s;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  transform: scaleX(0);
}

.dc-achievement-card:hover:before {
  transform: scaleX(1);
}

.dc-achievement-card:hover {
  border-color: #5017d7;
  transform: translateY(-8px);
  box-shadow: 0 20px 60px #5017d726;
}

.dc-achievement-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d714, #b068f014);
  border-radius: 20px;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  margin-bottom: 1.5rem;
  transition: all .4s;
  display: inline-flex;
}

.dc-achievement-card:hover .dc-achievement-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1)rotate(-5deg);
}

.dc-achievement-number {
  color: #5017d7;
  margin-bottom: .5rem;
  font-size: 2.5rem;
  font-weight: 800;
}

.dc-achievement-label {
  color: #1a1a1a;
  margin: 0 0 .75rem;
  font-size: 1.125rem;
}

.dc-exp-accordion-slider {
  gap: 1rem;
  max-width: 1400px;
  height: 500px;
  margin: 0 auto;
  padding: 2rem 0;
  display: flex;
}

.dc-accordion-card {
  background: var(--card-gradient);
  cursor: pointer;
  border-radius: 28px;
  flex: 1;
  min-width: 80px;
  transition: all .6s cubic-bezier(.4, 0, .2, 1);
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 32px #0000001f;
}

.dc-accordion-card:hover {
  flex: 4;
  box-shadow: 0 20px 60px #00000040;
}

.dc-accordion-card:not(:hover) {
  filter: brightness(.85);
}

.dc-accordion-front {
  color: #fff;
  opacity: 1;
  z-index: 2;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
  padding: 2rem 1rem;
  transition: opacity .4s;
  display: flex;
  position: absolute;
  inset: 0;
}

.dc-accordion-card:hover .dc-accordion-front {
  opacity: 0;
  pointer-events: none;
}

.dc-accordion-number-wrapper {
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  display: flex;
  position: relative;
}

.dc-accordion-number-bg {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff26;
  border-radius: 50%;
  animation: 3s ease-in-out infinite dc-pulse-slow;
  position: absolute;
  inset: 0;
}

@keyframes dc-pulse-slow {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .8;
    transform: scale(1.1);
  }
}

.dc-accordion-number {
  z-index: 2;
  text-shadow: 0 4px 12px #0000004d;
  font-family: Vazirmatn, sans-serif;
  font-size: 2rem;
  font-weight: 800;
  position: relative;
}

.dc-accordion-preview-text {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  text-align: center;
  text-overflow: ellipsis;
  text-shadow: 0 2px 8px #0000004d;
  max-height: 200px;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.4;
  overflow: hidden;
  transform: rotate(180deg);
}

.dc-accordion-content {
  opacity: 0;
  z-index: 1;
  justify-content: center;
  align-items: center;
  padding: 3rem;
  transition: opacity .4s .2s;
  display: flex;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.dc-accordion-card:hover .dc-accordion-content {
  opacity: 1;
}

.dc-accordion-bg-icon {
  opacity: .08;
  color: #fff;
  pointer-events: none;
  z-index: 0;
  transition: all .6s;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.dc-accordion-card:hover .dc-accordion-bg-icon {
  opacity: .12;
  transform: translate(-50%, -50%)scale(1.1)rotate(8deg);
}

.dc-accordion-content-inner {
  color: #fff;
  z-index: 2;
  flex-direction: column;
  gap: 1.5rem;
  max-width: 600px;
  display: flex;
  position: relative;
}

.dc-accordion-badge {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #fff3;
  border: 2px solid #ffffff4d;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 72px;
  height: 72px;
  display: inline-flex;
  box-shadow: 0 8px 24px #0003;
}

.dc-accordion-badge span {
  font-family: Vazirmatn, sans-serif;
  font-size: 1.75rem;
  font-weight: 800;
}

.dc-accordion-full-text {
  color: #fff;
  text-shadow: 0 2px 8px #0000004d;
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.9;
}

.dc-accordion-particles {
  pointer-events: none;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.dc-particle {
  background: #fff6;
  border-radius: 50%;
  width: 6px;
  height: 6px;
  animation: 8s ease-in-out infinite dc-float;
  position: absolute;
}

.dc-particle-1 {
  animation-delay: 0s;
  top: 20%;
  right: 15%;
}

.dc-particle-2 {
  width: 8px;
  height: 8px;
  animation-delay: 2s;
  top: 60%;
  right: 30%;
}

.dc-particle-3 {
  width: 4px;
  height: 4px;
  animation-delay: 4s;
  top: 80%;
  right: 60%;
}

@keyframes dc-float {
  0%, 100% {
    opacity: .3;
    transform: translateY(0)translateX(0);
  }

  50% {
    opacity: .6;
    transform: translateY(-30px)translateX(20px);
  }
}

.dc-solutions-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
}

.dc-solution-card {
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 20px;
  flex-direction: column;
  gap: 1.5rem;
  padding: 2.5rem;
  transition: all .4s;
  display: flex;
}

.dc-solution-card:hover {
  border-color: #5017d7;
  transform: translateY(-4px);
  box-shadow: 0 16px 48px #5017d71f;
}

.dc-solution-header {
  align-items: center;
  gap: 1.5rem;
  display: flex;
}

.dc-solution-icon {
  color: #5017d7;
  background: linear-gradient(135deg, #5017d714, #b068f014);
  border-radius: 16px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 64px;
  height: 64px;
  transition: all .4s;
  display: flex;
}

.dc-solution-card:hover .dc-solution-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transform: scale(1.1)rotate(-5deg);
}

.dc-solution-title {
  color: #1a1a1a;
  flex: 1;
  margin: 0;
  font-size: 1.25rem;
  line-height: 1.4;
}

.dc-solution-description {
  color: #666;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.8;
}

.dc-solution-features {
  grid-template-columns: repeat(2, 1fr);
  gap: .75rem;
  margin-top: .5rem;
  display: grid;
}

.dc-solution-feature {
  color: #333;
  background: #5017d70a;
  border-radius: 8px;
  align-items: center;
  gap: .5rem;
  padding: .625rem .875rem;
  font-size: .875rem;
  display: flex;
}

.dc-solution-feature svg {
  color: #10b981;
  flex-shrink: 0;
}

.dc-section-subtitle {
  color: #5017d7;
  text-align: center;
  margin: .5rem 0 0;
  font-size: 1.25rem;
  font-weight: 700;
}

.dc-achievements-grid-new {
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  max-width: 1200px;
  margin: 3rem auto 0;
  display: grid;
}

.dc-achievement-card {
  background: linear-gradient(135deg, #5017d7 0%, #7b3fe8 100%);
  border-radius: 24px;
  flex-direction: column;
  gap: 2rem;
  min-height: 280px;
  padding: 3rem 2.5rem;
  transition: all .5s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: relative;
  overflow: hidden;
}

.dc-achievement-card:before {
  content: "";
  opacity: 0;
  background: linear-gradient(135deg, #ffffff1a 0%, #fff0 100%);
  transition: opacity .5s;
  position: absolute;
  inset: 0;
}

.dc-achievement-card:hover:before {
  opacity: 1;
}

.dc-achievement-card:hover {
  transform: translateY(-8px)scale(1.02);
  box-shadow: 0 24px 48px #5017d74d, 0 0 80px #5017d733;
}

.dc-achievement-glow {
  opacity: 0;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(at bottom, #ffffff26 0%, #0000 70%);
  height: 100%;
  transition: opacity .5s;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

.dc-achievement-card:hover .dc-achievement-glow {
  opacity: 1;
}

.dc-achievement-number-section {
  z-index: 2;
  align-items: baseline;
  gap: .75rem;
  display: flex;
  position: relative;
}

.dc-achievement-number {
  color: #fff;
  text-shadow: 0 4px 20px #0003;
  font-size: 4rem;
  font-weight: 900;
  line-height: 1;
  transition: all .4s;
}

.dc-achievement-card:hover .dc-achievement-number {
  text-shadow: 0 8px 30px #0000004d;
  transform: scale(1.05);
}

.dc-achievement-unit {
  color: #ffffffe6;
  margin-bottom: .5rem;
  font-size: 1.5rem;
  font-weight: 700;
}

.dc-achievement-content {
  z-index: 2;
  flex-direction: column;
  gap: .75rem;
  display: flex;
  position: relative;
}

.dc-achievement-label {
  color: #fff;
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.4;
}

.dc-achievement-description {
  color: #ffffffe6;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.7;
}

.dc-achievement-badge {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: #fff;
  z-index: 2;
  background: #ffffff26;
  border: 1px solid #ffffff40;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  transition: all .4s;
  display: flex;
  position: absolute;
  top: 2rem;
  left: 2rem;
}

.dc-achievement-card:hover .dc-achievement-badge {
  background: #ffffff40;
  transform: scale(1.1)rotate(-10deg);
}

.dc-clients-wrapper {
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
}

.dc-client-item {
  background: #fff;
  border: 1px solid #0000000f;
  border-radius: 16px;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  padding: 2.5rem 1.5rem 2rem;
  transition: all .35s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: relative;
  overflow: hidden;
}

.dc-client-item:before {
  content: "";
  transform-origin: 0;
  background: linear-gradient(90deg, #5017d7, #b068f0);
  height: 3px;
  transition: transform .35s;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  transform: scaleX(0);
}

.dc-client-item:hover:before {
  transform: scaleX(1);
}

.dc-client-item:hover {
  border-color: #5017d726;
  transform: translateY(-6px);
  box-shadow: 0 8px 24px #5017d714, 0 2px 8px #0000000a;
}

.dc-client-logo-box {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 90px;
  transition: transform .35s;
  display: flex;
}

.dc-client-logo-box svg {
  filter: grayscale(.2);
  opacity: .9;
  width: auto;
  height: 60px;
  transition: all .35s;
}

.dc-client-item:hover .dc-client-logo-box {
  transform: scale(1.08);
}

.dc-client-item:hover .dc-client-logo-box svg {
  filter: grayscale(0);
  opacity: 1;
}

.dc-client-text {
  text-align: center;
  flex-direction: column;
  align-items: center;
  gap: .375rem;
  display: flex;
}

.dc-client-name {
  color: #1a1a1a;
  font-size: 1.0625rem;
  font-weight: 700;
  transition: color .3s;
}

.dc-client-item:hover .dc-client-name {
  color: #5017d7;
}

.dc-client-type {
  color: #737373;
  font-size: .8125rem;
  font-weight: 500;
}

.dc-platform-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
}

.dc-platform-item {
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 16px;
  align-items: flex-start;
  gap: 1.25rem;
  padding: 2rem;
  transition: all .3s;
  display: flex;
}

.dc-platform-item:hover {
  background: #5017d705;
  border-color: #5017d7;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px #5017d71a;
}

.dc-platform-item svg {
  color: #10b981;
  flex-shrink: 0;
  margin-top: 2px;
}

.dc-platform-content {
  flex: 1;
}

.dc-platform-title {
  color: #1a1a1a;
  margin: 0 0 .5rem;
  font-size: 1.0625rem;
  font-weight: 600;
}

.dc-platform-description {
  color: #666;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.7;
}

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

.dc-faq-item {
  background: #fff;
  border: 1px solid #5017d71a;
  border-radius: 16px;
  transition: all .3s;
  overflow: hidden;
}

.dc-faq-item:hover {
  border-color: #5017d7;
  box-shadow: 0 4px 20px #5017d714;
}

.dc-faq-question {
  text-align: right;
  cursor: pointer;
  background: none;
  border: none;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  width: 100%;
  padding: 1.5rem 2rem;
  transition: all .3s;
  display: flex;
}

.dc-faq-question:hover {
  background: #5017d705;
}

.dc-faq-question h3 {
  color: #1a1a1a;
  flex: 1;
  margin: 0;
  font-size: 1.125rem;
}

.dc-faq-icon {
  color: #5017d7;
  flex-shrink: 0;
  transition: transform .3s;
}

.dc-faq-icon-open {
  transform: rotate(180deg);
}

.dc-faq-answer {
  padding: 0 2rem 1.5rem;
  animation: .3s dc-slideDown;
}

@keyframes dc-slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

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

.dc-faq-answer p {
  color: #666;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.8;
}

@media (width <= 1200px) {
  .dc-achievements-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .dc-solutions-grid {
    grid-template-columns: 1fr;
  }
}

@media (width <= 1024px) {
  .dc-hero-content {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .dc-hero-visual {
    order: -1;
  }

  .dc-hero-circle {
    width: 320px;
    height: 320px;
  }

  .dc-hero-stats {
    grid-template-columns: repeat(3, 1fr);
  }

  .dc-achievements-grid-new {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }

  .dc-clients-wrapper {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }

  .dc-client-item {
    padding: 2rem 1.5rem 1.75rem;
  }

  .dc-client-logo-box {
    height: 75px;
  }

  .dc-client-logo-box svg {
    height: 50px;
  }

  .dc-platform-grid {
    grid-template-columns: 1fr;
  }
}

@media (width <= 768px) {
  .dc-hero-section {
    padding: 6rem 1.5rem 4rem;
  }

  .dc-hero-title {
    font-size: 2.25rem;
  }

  .dc-hero-stats {
    grid-template-columns: 1fr;
  }

  .dc-section {
    padding: 4rem 1.5rem;
  }

  .dc-section-title {
    font-size: 2rem;
  }

  .dc-achievements-grid {
    grid-template-columns: 1fr;
  }

  .dc-achievements-grid-new {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  .dc-achievement-card {
    min-height: auto;
    padding: 2.5rem 2rem;
  }

  .dc-achievement-number {
    font-size: 3rem;
  }

  .dc-achievement-label {
    font-size: 1.125rem;
  }

  .dc-achievement-description {
    font-size: .875rem;
  }

  .dc-exp-accordion-slider {
    gap: .75rem;
    height: 450px;
  }

  .dc-accordion-card {
    min-width: 70px;
  }

  .dc-accordion-number-wrapper {
    width: 64px;
    height: 64px;
  }

  .dc-accordion-number {
    font-size: 1.625rem;
  }

  .dc-accordion-preview-text {
    font-size: 1rem;
  }

  .dc-accordion-content {
    padding: 2rem;
  }

  .dc-accordion-badge {
    width: 64px;
    height: 64px;
  }

  .dc-accordion-badge span {
    font-size: 1.5rem;
  }

  .dc-accordion-full-text {
    font-size: 1rem;
  }

  .dc-solution-features {
    grid-template-columns: 1fr;
  }

  .dc-clients-wrapper {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .dc-client-item {
    padding: 2rem 1.5rem 1.75rem;
  }

  .dc-client-logo-box {
    height: 70px;
  }

  .dc-client-logo-box svg {
    height: 45px;
  }
}

@media (width <= 480px) {
  .dc-hero-title {
    font-size: 1.875rem;
  }

  .dc-hero-circle {
    width: 280px;
    height: 280px;
  }

  .dc-section-title {
    font-size: 1.75rem;
  }

  .dc-achievement-number {
    font-size: 2.5rem;
  }

  .dc-achievement-unit {
    font-size: 1.125rem;
  }

  .dc-solution-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .dc-clients-wrapper {
    grid-template-columns: 1fr;
  }

  .dc-exp-accordion-slider {
    flex-direction: column;
    gap: 1rem;
    height: auto;
  }

  .dc-accordion-card {
    flex: none;
    min-width: auto;
    min-height: 100px;
  }

  .dc-accordion-card:hover {
    flex: none;
    min-height: 320px;
  }

  .dc-accordion-front {
    flex-direction: row;
    justify-content: flex-start;
    gap: 1rem;
    padding: 1.5rem;
  }

  .dc-accordion-number-wrapper {
    width: 56px;
    height: 56px;
  }

  .dc-accordion-number {
    font-size: 1.375rem;
  }

  .dc-accordion-preview-text {
    writing-mode: horizontal-tb;
    text-orientation: mixed;
    text-align: right;
    flex: 1;
    max-height: none;
    font-size: .9375rem;
    transform: none;
  }

  .dc-accordion-content {
    padding: 1.5rem;
  }

  .dc-accordion-content-inner {
    gap: 1.25rem;
  }

  .dc-accordion-badge {
    width: 56px;
    height: 56px;
  }

  .dc-accordion-badge span {
    font-size: 1.25rem;
  }

  .dc-accordion-full-text {
    font-size: .9375rem;
  }
}

.contact-page {
  background: linear-gradient(135deg, #fff 0%, #f8f5ff 100%);
  min-height: 100vh;
}

.contact-hero-section {
  background: linear-gradient(135deg, #5017d7 0%, #7b3ff2 100%);
  padding: 120px 24px 80px;
  position: relative;
  overflow: hidden;
}

.contact-hero-pattern {
  opacity: .1;
  background-image: radial-gradient(circle at 20% 30%, #ffffff4d 0%, #0000 50%), radial-gradient(circle at 80% 70%, #fff3 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

.contact-hero-container {
  text-align: center;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

.contact-hero-badge {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: #fff;
  background: #ffffff26;
  border: 1px solid #fff3;
  border-radius: 100px;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
  padding: 8px 20px;
  display: inline-flex;
}

.contact-hero-title {
  color: #fff;
  max-width: 800px;
  margin-bottom: 16px;
  margin-left: auto;
  margin-right: auto;
}

.contact-hero-description {
  color: #ffffffe6;
  max-width: 600px;
  margin: 0 auto;
}

.contact-main-section {
  padding: 80px 24px;
}

.contact-container {
  max-width: 1200px;
  margin: 0 auto;
}

.contact-grid {
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: 80px;
  display: grid;
}

@media (width <= 968px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

.contact-info-section {
  flex-direction: column;
  gap: 24px;
  display: flex;
}

.contact-info-header {
  margin-bottom: 8px;
}

.contact-info-title {
  color: #1a1a1a;
  margin-bottom: 8px;
}

.contact-info-cards {
  flex-direction: column;
  gap: 16px;
  display: flex;
}

.contact-info-card {
  background: #fff;
  border: 1px solid #e8e8f0;
  border-radius: 16px;
  padding: 24px;
  transition: all .3s cubic-bezier(.4, 0, .2, 1);
  position: relative;
  overflow: hidden;
}

.contact-info-card:before {
  content: "";
  transform-origin: top;
  background: linear-gradient(135deg, #5017d7 0%, #7b3ff2 100%);
  width: 4px;
  height: 100%;
  transition: transform .3s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  top: 0;
  right: 0;
  transform: scaleY(0);
}

.contact-info-card:hover {
  border-color: #5017d7;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px #5017d71a;
}

.contact-info-card:hover:before {
  transform: scaleY(1);
}

.contact-info-card-content {
  gap: 16px;
  display: flex;
}

.contact-info-icon {
  color: #fff;
  background: linear-gradient(135deg, #5017d7 0%, #7b3ff2 100%);
  border-radius: 12px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  display: flex;
}

.contact-info-details {
  flex: 1;
}

.contact-info-label {
  color: #666;
  margin-bottom: 4px;
  display: block;
}

.contact-info-value {
  color: #1a1a1a;
  margin-bottom: 4px;
  transition: color .2s;
  display: block;
}

.contact-info-card a .contact-info-value:hover {
  color: #5017d7;
}

.contact-info-description {
  color: #999;
}

.contact-form-section {
  background: #fff;
  border: 1px solid #e8e8f0;
  border-radius: 24px;
  padding: 32px;
  box-shadow: 0 4px 16px #0000000a;
}

.contact-form-header {
  margin-bottom: 24px;
}

.contact-form-title {
  color: #1a1a1a;
  margin-bottom: 8px;
}

.contact-form-description {
  color: #666;
}

.contact-form {
  flex-direction: column;
  gap: 20px;
  display: flex;
}

.contact-form-group {
  flex-direction: column;
  gap: 8px;
  display: flex;
}

.contact-form-label {
  color: #1a1a1a;
  align-items: center;
  gap: 4px;
  display: flex;
}

.contact-form-required {
  color: #f44;
}

.contact-form-input, .contact-form-select, .contact-form-textarea {
  color: #1a1a1a;
  background: #fff;
  border: 1px solid #e8e8f0;
  border-radius: 12px;
  width: 100%;
  padding: 12px 16px;
  font-family: inherit;
  transition: all .2s;
}

.contact-form-input:focus, .contact-form-select:focus, .contact-form-textarea:focus {
  border-color: #5017d7;
  outline: none;
  box-shadow: 0 0 0 3px #5017d71a;
}

.contact-form-textarea {
  resize: vertical;
  min-height: 120px;
}

.contact-form-submit {
  color: #fff;
  cursor: pointer;
  background: linear-gradient(135deg, #5017d7 0%, #7b3ff2 100%);
  border: none;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 14px 32px;
  transition: all .3s cubic-bezier(.4, 0, .2, 1);
  display: flex;
}

.contact-form-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px #5017d74d;
}

.contact-form-submit:active {
  transform: translateY(0);
}

.contact-social-section {
  background: #fff;
  border-top: 1px solid #e8e8f0;
  padding: 80px 24px;
}

.contact-social-container {
  text-align: center;
  max-width: 1200px;
  margin: 0 auto;
}

.contact-social-title {
  color: #1a1a1a;
  margin-bottom: 80px;
}

.contact-social-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 900px;
  margin: 0 auto;
  display: grid;
}

@media (width <= 768px) {
  .contact-social-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

.contact-social-card {
  opacity: 0;
  background: #fff;
  border-radius: 20px;
  padding: 0;
  text-decoration: none;
  animation: .6s cubic-bezier(.4, 0, .2, 1) forwards fadeInUp;
  display: block;
  position: relative;
  overflow: hidden;
}

.contact-social-card-bg {
  opacity: 1;
  background: linear-gradient(135deg, #fff 0%, #f8f5ff 100%);
  transition: opacity .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: 0;
}

.contact-social-card:hover .contact-social-card-bg {
  opacity: 0;
}

.contact-social-card:before {
  content: "";
  background: linear-gradient(135deg, var(--platform-color, #5017d7) 0%, #5017d7 100%);
  opacity: 0;
  transition: opacity .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: 0;
}

.contact-social-card:hover:before {
  opacity: .05;
}

.contact-social-card-border {
  pointer-events: none;
  border: 2px solid #e8e8f0;
  border-radius: 20px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: 0;
}

.contact-social-card:hover .contact-social-card-border {
  border-color: var(--platform-color, #5017d7);
  box-shadow: 0 8px 32px #5017d726;
}

.contact-social-card-inner {
  z-index: 1;
  align-items: center;
  gap: 20px;
  padding: 24px 28px;
  display: flex;
  position: relative;
}

.contact-social-icon-wrapper {
  flex-shrink: 0;
  position: relative;
}

.contact-social-icon-bg {
  background: var(--platform-color, #5017d7);
  opacity: .1;
  border-radius: 16px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  position: absolute;
  inset: -8px;
  transform: scale(.9);
}

.contact-social-card:hover .contact-social-icon-bg {
  opacity: .15;
  transform: scale(1);
}

.contact-social-icon {
  background: linear-gradient(135deg, var(--platform-color, #5017d7) 0%, #5017d7 100%);
  color: #fff;
  z-index: 1;
  border-radius: 14px;
  justify-content: center;
  align-items: center;
  width: 56px;
  height: 56px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: relative;
}

.contact-social-card:hover .contact-social-icon {
  transform: scale(1.05)rotate(-5deg);
  box-shadow: 0 8px 24px #00000026;
}

.contact-social-content {
  flex-direction: column;
  flex: 1;
  gap: 4px;
  display: flex;
}

.contact-social-name {
  color: #1a1a1a;
  transition: all .3s;
}

.contact-social-card:hover .contact-social-name {
  color: var(--platform-color, #5017d7);
  transform: translateX(-4px);
}

.contact-social-cta {
  color: #666;
  font-size: .9em;
  transition: all .3s;
}

.contact-social-card:hover .contact-social-cta {
  color: #999;
  transform: translateX(-4px);
}

.contact-social-arrow {
  color: #999;
  background: #f5f5f5;
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  transition: all .4s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  transform: rotate(180deg);
}

.contact-social-card:hover .contact-social-arrow {
  background: var(--platform-color, #5017d7);
  color: #fff;
  transform: translateX(-4px)rotate(180deg);
}

.contact-success-message {
  color: #2e7d32;
  background: #e8f5e9;
  border: 1px solid #4caf50;
  border-radius: 12px;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
  padding: 16px 20px;
  display: flex;
}

.contact-success-icon {
  color: #4caf50;
  flex-shrink: 0;
}

[dir="rtl"] .contact-info-card:before {
  left: 0;
  right: auto;
}

.not-found-wrapper {
  background: linear-gradient(135deg, #f8f9ff 0%, #fff 50%, #f5f3ff 100%);
  justify-content: center;
  align-items: center;
  min-height: calc(100vh - 80px);
  padding: 12rem 1rem 4rem;
  display: flex;
  position: relative;
  overflow: hidden;
}

.not-found-background {
  pointer-events: none;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.not-found-bg-circle {
  opacity: .05;
  border-radius: 50%;
  position: absolute;
}

.not-found-bg-circle-1 {
  background: #5017d7;
  width: 600px;
  height: 600px;
  animation: 20s ease-in-out infinite float;
  top: -200px;
  right: -200px;
}

.not-found-bg-circle-2 {
  background: #7c3aed;
  width: 400px;
  height: 400px;
  animation: 15s ease-in-out infinite reverse float;
  bottom: -100px;
  left: -100px;
}

.not-found-bg-circle-3 {
  background: #6d28d9;
  width: 300px;
  height: 300px;
  animation: 10s ease-in-out infinite pulse;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.not-found-container {
  z-index: 1;
  width: 100%;
  max-width: 1200px;
  position: relative;
}

.not-found-content {
  text-align: center;
  margin-bottom: 4rem;
}

.not-found-number {
  margin-bottom: 2rem;
  display: inline-block;
  position: relative;
}

.not-found-number-text {
  background: linear-gradient(135deg, #5017d7 0%, #7c3aed 50%, #6d28d9 100%);
  -webkit-text-fill-color: transparent;
  letter-spacing: -.05em;
  background-clip: text;
  font-size: clamp(8rem, 20vw, 16rem);
  font-weight: 800;
  line-height: 1;
  display: inline-block;
  position: relative;
}

.not-found-number-glow {
  filter: blur(40px);
  opacity: .2;
  background: linear-gradient(135deg, #5017d7 0%, #7c3aed 100%);
  animation: 3s ease-in-out infinite glow;
  position: absolute;
  inset: 0;
}

.not-found-icon-float {
  animation: 3s ease-in-out infinite iconFloat;
  position: absolute;
}

.not-found-icon-1 {
  color: #5017d7;
  opacity: .3;
  top: 20%;
  right: 10%;
}

.not-found-icon-2 {
  color: #7c3aed;
  opacity: .3;
  animation-delay: 1s;
  bottom: 30%;
  left: 15%;
}

.not-found-icon-3 {
  color: #6d28d9;
  opacity: .3;
  animation-delay: 2s;
  top: 40%;
  left: 5%;
}

.not-found-heading {
  color: #1a1a1a;
  margin-bottom: 1rem;
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 700;
}

.not-found-description {
  color: #666;
  max-width: 600px;
  margin: 0 auto 3rem;
  font-size: clamp(1rem, 2vw, 1.25rem);
  line-height: 1.8;
}

.not-found-suggestions {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
  margin-bottom: 3rem;
  display: grid;
}

.suggestion-card {
  background: #fff;
  border: 2px solid #f0f0f0;
  border-radius: 1rem;
  padding: 1.5rem;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}

.suggestion-card:before {
  content: "";
  background: linear-gradient(#5017d7, #7c3aed);
  width: 4px;
  height: 0;
  transition: height .3s;
  position: absolute;
  top: 0;
  right: 0;
}

.suggestion-card:hover {
  border-color: #5017d7;
  transform: translateY(-4px);
  box-shadow: 0 12px 24px #5017d71a;
}

.suggestion-card:hover:before {
  height: 100%;
}

.suggestion-number {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #7c3aed);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  margin-bottom: 1rem;
  font-size: .875rem;
  font-weight: 700;
  display: inline-flex;
}

.suggestion-card h3 {
  color: #1a1a1a;
  margin-bottom: .5rem;
  font-size: 1.125rem;
  font-weight: 700;
}

.suggestion-card p {
  color: #666;
  font-size: .9375rem;
  line-height: 1.6;
}

.not-found-quick-links {
  background: #fff;
  border: 2px solid #f0f0f0;
  border-radius: 1.5rem;
  margin-bottom: 3rem;
  padding: 2.5rem;
}

.quick-links-title {
  text-align: center;
  color: #1a1a1a;
  margin-bottom: 2rem;
  font-size: 1.5rem;
  font-weight: 700;
}

.quick-links-grid {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  display: grid;
}

.quick-link-card {
  text-align: center;
  background: #fafafa;
  border: 2px solid #0000;
  border-radius: 1rem;
  flex-direction: column;
  align-items: center;
  padding: 1.5rem 1rem;
  text-decoration: none;
  transition: all .3s;
  display: flex;
  position: relative;
  overflow: hidden;
}

.quick-link-card:before {
  content: "";
  opacity: 0;
  background: linear-gradient(135deg, #5017d7, #7c3aed);
  transition: opacity .3s;
  position: absolute;
  inset: 0;
}

.quick-link-card:hover {
  background: #fff;
  border-color: #5017d7;
  transform: translateY(-4px);
  box-shadow: 0 8px 16px #5017d71a;
}

.quick-link-card:hover:before {
  opacity: .05;
}

.quick-link-icon {
  color: #fff;
  z-index: 1;
  background: linear-gradient(135deg, #5017d7, #7c3aed);
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  margin-bottom: 1rem;
  transition: all .3s;
  display: flex;
  position: relative;
}

.quick-link-card:hover .quick-link-icon {
  transform: scale(1.1)rotate(5deg);
}

.quick-link-title {
  color: #1a1a1a;
  z-index: 1;
  margin-bottom: .25rem;
  font-size: 1rem;
  font-weight: 700;
  position: relative;
}

.quick-link-description {
  color: #666;
  z-index: 1;
  font-size: .875rem;
  position: relative;
}

.not-found-cta {
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin-bottom: 3rem;
  display: flex;
}

.not-found-btn {
  border: 2px solid #0000;
  border-radius: .75rem;
  align-items: center;
  gap: .5rem;
  padding: 1rem 2rem;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s;
  display: inline-flex;
  position: relative;
  overflow: hidden;
}

.not-found-btn:before {
  content: "";
  opacity: 0;
  background: linear-gradient(135deg, #fff3, #fff0);
  transition: opacity .3s;
  position: absolute;
  inset: 0;
}

.not-found-btn:hover:before {
  opacity: 1;
}

.not-found-btn-primary {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #7c3aed);
  box-shadow: 0 4px 12px #5017d74d;
}

.not-found-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px #5017d766;
}

.not-found-btn-secondary {
  color: #5017d7;
  background: #fff;
  border-color: #5017d7;
}

.not-found-btn-secondary:hover {
  color: #fff;
  background: #5017d7;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px #5017d733;
}

.not-found-contact {
  text-align: center;
  background: #fff;
  border: 2px solid #f0f0f0;
  border-radius: 1rem;
  padding: 2rem;
}

.not-found-contact h3 {
  color: #1a1a1a;
  margin-bottom: 1rem;
  font-size: 1.25rem;
  font-weight: 700;
}

.not-found-contact-links {
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
  display: flex;
}

.not-found-contact-link {
  color: #5017d7;
  align-items: center;
  gap: .5rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s;
  display: inline-flex;
}

.not-found-contact-link:hover {
  color: #7c3aed;
  gap: .75rem;
}

.not-found-contact-icon {
  justify-content: center;
  align-items: center;
  width: 20px;
  height: 20px;
  display: flex;
}

@keyframes glow {
  0%, 100% {
    opacity: .2;
  }

  50% {
    opacity: .3;
  }
}

@keyframes iconFloat {
  0%, 100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-15px);
  }
}

@media (width <= 768px) {
  .not-found-wrapper {
    min-height: calc(100vh - 60px);
    padding: 10rem 1rem 2rem;
  }

  .not-found-number-text {
    font-size: clamp(6rem, 15vw, 10rem);
  }

  .not-found-suggestions {
    grid-template-columns: 1fr;
  }

  .not-found-quick-links {
    padding: 1.5rem;
  }

  .quick-links-grid {
    grid-template-columns: 1fr;
  }

  .not-found-cta {
    flex-direction: column;
    width: 100%;
  }

  .not-found-btn {
    justify-content: center;
    width: 100%;
  }

  .not-found-contact-links {
    flex-direction: column;
    gap: 1rem;
  }

  .not-found-icon-float {
    display: none;
  }
}

@media (width <= 480px) {
  .not-found-wrapper {
    padding: 8rem 1rem 2rem;
  }

  .not-found-description {
    font-size: 1rem;
  }

  .suggestion-card, .not-found-quick-links, .not-found-contact {
    padding: 1.25rem;
  }
}

.footer-wrapper {
  background: linear-gradient(#fafaff 0%, #f8f9ff 100%);
  margin-top: 0;
  padding: 16rem 2rem 3rem;
  position: relative;
  overflow: visible;
}

.footer-newsletter-container {
  z-index: 10;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}

.footer-newsletter-highlight {
  background: #5017d7;
  border-radius: 24px;
  justify-content: space-between;
  align-items: center;
  gap: 3rem;
  margin-top: 0;
  margin-bottom: 0;
  padding: 3rem;
  animation: .8s ease-out .4s both fadeInUp;
  display: flex;
  position: relative;
  overflow: hidden;
  transform: translateY(-50%);
  box-shadow: 0 20px 50px #5017d740, inset 0 0 0 1px #ffffff1a;
}

.cta-logo-background {
  opacity: .08;
  pointer-events: none;
  z-index: 0;
  position: absolute;
  top: 50%;
  left: -8%;
  transform: translateY(-50%)rotate(-15deg);
}

.cta-logo-watermark {
  color: #fff;
  width: 280px;
  height: 280px;
}

.newsletter-content {
  z-index: 1;
  flex: 1;
  align-items: center;
  gap: 1.5rem;
  display: flex;
  position: relative;
}

.newsletter-icon-wrapper {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff26;
  border: 2px solid #fff3;
  border-radius: 20px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 72px;
  height: 72px;
  display: flex;
}

.newsletter-big-icon {
  color: #fff;
}

.newsletter-text {
  flex: 1;
}

.newsletter-heading {
  color: #fff;
  margin: 0 0 .5rem;
  font-size: 1.75rem;
}

.newsletter-subtext {
  color: #ffffffe6;
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
}

.cta-btn {
  cursor: pointer;
  white-space: nowrap;
  z-index: 1;
  border: none;
  border-radius: 12px;
  align-items: center;
  gap: .625rem;
  padding: 1rem 2rem;
  font-family: inherit;
  font-size: 1rem;
  text-decoration: none;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: inline-flex;
  position: relative;
  overflow: hidden;
}

.cta-primary {
  color: #5017d7;
  background: #fff;
  box-shadow: 0 2px 10px #fff3;
}

.cta-primary:before {
  content: "";
  opacity: 0;
  background: #f8f9ff;
  transition: opacity .3s;
  position: absolute;
  inset: 0;
}

.cta-primary:hover {
  color: #5017d7;
  transform: translateY(-3px);
  box-shadow: 0 4px 16px #fff6;
}

.cta-text-with-logo {
  z-index: 1;
  align-items: center;
  gap: .5rem;
  display: inline-flex;
  position: relative;
}

.cta-inline-logo {
  vertical-align: middle;
  width: auto;
  height: 1em;
  color: inherit;
  display: inline-block;
}

.cta-primary:hover:before {
  opacity: 1;
}

.cta-primary svg {
  z-index: 1;
  color: inherit;
  position: relative;
}

.cta-primary:after {
  content: "";
  background: #5017d71a;
  width: 100%;
  height: 100%;
  transition: left .6s;
  position: absolute;
  top: 0;
  left: -100%;
}

.cta-primary:hover:after {
  left: 100%;
}

.footer-pattern {
  pointer-events: none;
  z-index: 0;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.pattern-gradient {
  background: radial-gradient(circle at 20% 30%, #5017d714 0%, #0000 50%), radial-gradient(circle at 80% 70%, #b068f014 0%, #0000 50%);
  position: absolute;
  inset: 0;
}

.pattern-dots {
  opacity: .6;
  background-image: radial-gradient(circle, #5017d70d 1px, #0000 1px);
  background-size: 24px 24px;
  position: absolute;
  inset: 0;
}

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

.footer-grid {
  grid-template-columns: 2fr repeat(3, 1fr);
  gap: 3.5rem;
  margin-bottom: 3.5rem;
  padding: 0 .5rem;
  display: grid;
}

.footer-col {
  flex-direction: column;
  gap: 1.5rem;
  display: flex;
}

.footer-col-title {
  color: #1e293b;
  margin: 0;
  padding-bottom: .75rem;
  font-size: 1.125rem;
  position: relative;
}

.footer-col-title:after {
  content: "";
  background: linear-gradient(90deg, #5017d7, #b068f0);
  border-radius: 2px;
  width: 40px;
  height: 3px;
  position: absolute;
  bottom: 0;
  right: 0;
}

.footer-brand-col {
  gap: 2rem;
}

.brand-header {
  align-items: center;
  gap: 1rem;
  display: flex;
}

.brand-logo-icon {
  color: #5017d7;
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
}

.brand-logo-icon:hover {
  filter: drop-shadow(0 8px 24px #5017d740);
  transform: scale(1.05)rotate(-3deg);
}

.brand-info {
  flex-direction: column;
  gap: .375rem;
  display: flex;
}

.brand-name {
  color: #1e293b;
  align-items: center;
  gap: .5rem;
  margin: 0;
  display: inline-flex;
}

.brand-name-logo {
  vertical-align: middle;
  color: #5017d7;
  width: auto;
  height: 1.2em;
  font-size: 1.25rem;
  display: inline-block;
}

.brand-tagline {
  color: #5017d7;
  font-size: .9375rem;
}

.brand-description {
  color: #475569;
  margin: 0;
  font-size: .9375rem;
  line-height: 1.8;
}

.social-section {
  flex-direction: column;
  gap: 1rem;
  display: flex;
}

.social-label {
  color: #1e293b;
  font-size: .9375rem;
}

.social-icons {
  gap: .75rem;
  width: 100%;
  display: flex;
}

.social-icon-link {
  color: #64748b;
  background: #fff;
  border: 1.5px solid #5017d71f;
  border-radius: 12px;
  flex: 1;
  justify-content: center;
  align-items: center;
  gap: .5rem;
  height: 42px;
  text-decoration: none;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 8px #5017d70a;
}

.social-icon-link span {
  z-index: 1;
  transition: all .3s;
  position: relative;
}

.social-icon-link:before {
  content: "";
  opacity: 0;
  background: linear-gradient(135deg, #5017d7, #b068f0);
  transition: opacity .3s;
  position: absolute;
  inset: 0;
}

.social-icon-link svg {
  z-index: 1;
  transition: all .3s;
  position: relative;
}

.social-icon-link:hover {
  border-color: #5017d74d;
  transform: translateY(-4px);
  box-shadow: 0 8px 20px #5017d72e;
}

.social-icon-link:hover:before {
  opacity: 1;
}

.social-icon-link:hover svg {
  color: #fff;
  transform: scale(1.1);
}

.social-icon-link:hover span {
  color: #fff;
}

.footer-nav-list {
  flex-direction: column;
  gap: .875rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.footer-nav-link {
  color: #64748b;
  font-size: .9375rem;
  text-decoration: none;
  transition: all .3s;
  display: inline-block;
  position: relative;
}

.footer-nav-link:after {
  content: "";
  background: linear-gradient(90deg, #5017d7, #b068f0);
  border-radius: 1px;
  width: 0;
  height: 2px;
  transition: width .3s;
  position: absolute;
  bottom: -2px;
  right: 0;
}

.footer-nav-link:hover {
  color: #5017d7;
  transform: translateX(-4px);
}

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

.contact-list {
  flex-direction: column;
  gap: 1rem;
  display: flex;
}

.contact-link {
  color: #64748b;
  align-items: flex-start;
  gap: .875rem;
  padding: .5rem 0;
  font-size: .9375rem;
  line-height: 1.6;
  text-decoration: none;
  transition: all .3s;
  display: flex;
}

.contact-link svg {
  color: #5017d7;
  flex-shrink: 0;
  margin-top: .125rem;
  transition: all .3s;
}

.contact-link:hover {
  color: #1e293b;
}

.contact-link:hover svg {
  color: #7b3fe4;
  transform: scale(1.15);
}

.footer-bottom-bar {
  border-top: 1px solid #5017d714;
  justify-content: space-between;
  align-items: center;
  gap: 2rem;
  padding: 2rem .5rem 0;
  display: flex;
}

.copyright-text {
  color: #64748b;
  margin: 0;
  font-size: .9375rem;
}

.copyright-text strong {
  color: #1e293b;
}

.copyright-text-inline {
  flex-wrap: wrap;
  align-items: center;
  gap: .375rem;
  display: inline-flex;
}

.copyright-inline-logo {
  vertical-align: middle;
  color: #1e293b;
  width: auto;
  height: 1.125em;
  display: inline-block;
  position: relative;
  top: -1px;
}

.footer-meta {
  align-items: center;
  gap: 2rem;
  display: flex;
}

.made-with {
  color: #64748b;
  align-items: center;
  gap: .375rem;
  font-size: .9375rem;
  display: inline-flex;
}

.heart-beat {
  color: #ef4444;
  animation: 1.5s ease-in-out infinite heartbeat;
}

@keyframes heartbeat {
  0%, 100% {
    transform: scale(1);
  }

  10%, 30% {
    transform: scale(1.2);
  }

  20%, 40% {
    transform: scale(.95);
  }
}

.back-to-top {
  color: #5017d7;
  cursor: pointer;
  background: #fff;
  border: 1.5px solid #5017d726;
  border-radius: 12px;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.5rem;
  font-family: inherit;
  font-size: .9375rem;
  transition: all .4s cubic-bezier(.34, 1.56, .64, 1);
  display: inline-flex;
  box-shadow: 0 2px 8px #5017d70f;
}

.back-to-top:hover {
  color: #fff;
  background: linear-gradient(135deg, #5017d7, #7b3fe4);
  border-color: #0000;
  transform: translateY(-3px);
  box-shadow: 0 8px 20px #5017d733;
}

.back-to-top svg {
  transition: transform .3s;
}

.back-to-top:hover svg {
  transform: translateY(-2px);
}

@media (width <= 1200px) {
  .footer-grid {
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 2.5rem;
  }
}

@media (width <= 1024px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2.5rem;
  }

  .footer-brand-col {
    grid-column: 1 / -1;
  }
}

@media (width <= 768px) {
  .footer-wrapper {
    padding: 14rem 1.5rem 2rem;
  }

  .footer-container {
    padding-top: 0;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .footer-bottom-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.5rem;
  }

  .footer-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
    width: 100%;
  }

  .back-to-top {
    justify-content: center;
    width: 100%;
  }

  .footer-newsletter-container {
    padding: 0 1.5rem;
  }

  .footer-newsletter-highlight {
    flex-direction: column;
    align-items: stretch;
    gap: 2rem;
    padding: 2.5rem;
  }

  .newsletter-content {
    text-align: center;
    justify-content: center;
  }

  .cta-btn {
    justify-content: center;
    width: 100%;
  }
}

@media (width <= 640px) {
  .footer-wrapper {
    padding: 12rem 1rem 1.5rem;
  }

  .brand-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .brand-logo-icon {
    width: 52px;
    height: 52px;
  }

  .footer-grid {
    gap: 2rem;
  }

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

  .footer-newsletter-container {
    padding: 0 1rem;
  }

  .footer-newsletter-highlight {
    border-radius: 20px;
    padding: 2rem;
  }

  .newsletter-content {
    text-align: center;
    flex-direction: column;
  }

  .newsletter-heading {
    font-size: 1.5rem;
  }

  .newsletter-subtext {
    font-size: .9375rem;
  }

  .cta-logo-background {
    left: -15%;
  }

  .cta-logo-watermark {
    width: 220px;
    height: 220px;
  }
}

@media (width <= 480px) {
  .brand-name {
    font-size: 1.125rem;
  }

  .brand-tagline, .brand-description {
    font-size: .875rem;
  }

  .footer-col-title {
    font-size: 1rem;
  }

  .copyright-text, .made-with {
    font-size: .875rem;
  }

  .footer-newsletter-highlight {
    padding: 1.75rem;
  }

  .newsletter-icon-wrapper {
    width: 60px;
    height: 60px;
  }

  .newsletter-big-icon {
    width: 28px;
    height: 28px;
  }

  .newsletter-heading {
    font-size: 1.25rem;
  }

  .newsletter-subtext {
    font-size: .875rem;
  }

  .cta-logo-background {
    left: -20%;
  }

  .cta-logo-watermark {
    width: 180px;
    height: 180px;
  }

  .cta-btn {
    padding: .875rem 1.5rem;
    font-size: .9375rem;
  }
}

@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
  initial-value: rotateX(0);
}

@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
  initial-value: rotateY(0);
}

@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
  initial-value: rotateZ(0);
}

@property --tw-skew-x {
  syntax: "*";
  inherits: false;
  initial-value: skewX(0);
}

@property --tw-skew-y {
  syntax: "*";
  inherits: false;
  initial-value: skewY(0);
}

@property --tw-border-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-duration {
  syntax: "*";
  inherits: false
}

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

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

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

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