:root {
  /* Colors */
  --color-primary: #7c3aed;
  /* Violet-600 */
  --color-primary-dark: #6d28d9;
  /* Violet-700 */
  --color-primary-light: #ddd6fe;
  /* Violet-200 */
  --color-primary-bg: #8b5cf6;
  /* for gradients */
  --color-bg: #ffffff;
  --color-bg-alt: #f8fafc;
  /* Slate-50 */
  --color-text: #1e293b;
  /* Slate-800 */
  --color-text-muted: #64748b;
  /* Slate-500 */
  --color-text-light: #94a3b8;
  /* Slate-400 */
  --color-white: #ffffff;
  --color-border: #e2e8f0;
  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  /* Radius */
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-full: 9999px;
  /* Typography */
  --font-sans: 'Inter', sans-serif;
  /* Layout */
  --container-width: 1200px;
  --header-height: 80px;
}

.modal {
  --bs-modal-border-radius: 16px;
}

/*
*  BUTTON GENERATOR START
*/
.btn-secondary-sm {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 6px 10px;
  font-size: 16px;
  font-weight: 400;
  line-height: 22px;
  border-color: #D1D5DB !important;
  color: #191919 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-sm:hover {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-sm:active {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-sm:focus {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-secondary-white-sm {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 6px 10px;
  font-size: 16px;
  font-weight: 400;
  line-height: 22px;
  border-color: transparent !important;
  color: #8B5CF6 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-white-sm:hover {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-sm:active {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-sm:focus {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-pastel-sm {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 6px 10px;
  font-size: 16px;
  font-weight: 400;
  line-height: 22px;
  border-color: #A78BFA !important;
  color: #191919 !important;
  background: #A78BFA;
  display: inline-block;
}
.btn-primary-pastel-sm:hover {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-sm:active {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-sm:focus {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-white-sm {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 6px 10px;
  font-size: 16px;
  font-weight: 400;
  line-height: 22px;
  border-color: #FFFFFF !important;
  color: #191919 !important;
  background: #FFFFFF;
  display: inline-block;
}
.btn-primary-white-sm:hover {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-sm:active {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8) !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-sm:focus {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-brand-sm {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 6px 10px;
  font-size: 16px;
  font-weight: 400;
  line-height: 22px;
  border-color: #8B5CF6 !important;
  color: #FFFFFF !important;
  background: #8B5CF6;
  display: inline-block;
}
.btn-primary-brand-sm:hover {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-sm:active {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-sm:focus {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-secondary-m {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 12px 20px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #D1D5DB !important;
  color: #191919 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-m:hover {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-m:active {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-m:focus {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-secondary-white-m {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 12px 20px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: transparent !important;
  color: #8B5CF6 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-white-m:hover {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-m:active {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-m:focus {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-pastel-m {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 12px 20px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #A78BFA !important;
  color: #191919 !important;
  background: #A78BFA;
  display: inline-block;
}
.btn-primary-pastel-m:hover {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-m:active {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-m:focus {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-white-m {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 12px 20px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #FFFFFF !important;
  color: #191919 !important;
  background: #FFFFFF;
  display: inline-block;
}
.btn-primary-white-m:hover {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-m:active {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8) !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-m:focus {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-brand-m {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 12px 20px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #8B5CF6 !important;
  color: #FFFFFF !important;
  background: #8B5CF6;
  display: inline-block;
}
.btn-primary-brand-m:hover {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-m:active {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-m:focus {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-secondary-l {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 16px 26px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #D1D5DB !important;
  color: #191919 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-l:hover {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-l:active {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-l:focus {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-secondary-white-l {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 16px 26px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: transparent !important;
  color: #8B5CF6 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-white-l:hover {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-l:active {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-l:focus {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-pastel-l {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 16px 26px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #A78BFA !important;
  color: #191919 !important;
  background: #A78BFA;
  display: inline-block;
}
.btn-primary-pastel-l:hover {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-l:active {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-l:focus {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-white-l {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 16px 26px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #FFFFFF !important;
  color: #191919 !important;
  background: #FFFFFF;
  display: inline-block;
}
.btn-primary-white-l:hover {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-l:active {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8) !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-l:focus {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-brand-l {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 16px 26px;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  border-color: #8B5CF6 !important;
  color: #FFFFFF !important;
  background: #8B5CF6;
  display: inline-block;
}
.btn-primary-brand-l:hover {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-l:active {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-l:focus {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-secondary-xl {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 26px 30px;
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
  border-color: #D1D5DB !important;
  color: #191919 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-xl:hover {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-xl:active {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-xl:focus {
  border-color: #E5E7EB;
  color: #191919;
  background: #E5E7EB;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-secondary-white-xl {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 26px 30px;
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
  border-color: transparent !important;
  color: #8B5CF6 !important;
  background: transparent;
  display: inline-block;
}
.btn-secondary-white-xl:hover {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-xl:active {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-secondary-white-xl:focus {
  border-color: transparent;
  color: #D1D5DB;
  background: #ddd6fe;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-pastel-xl {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 26px 30px;
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
  border-color: #A78BFA !important;
  color: #191919 !important;
  background: #A78BFA;
  display: inline-block;
}
.btn-primary-pastel-xl:hover {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-xl:active {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-pastel-xl:focus {
  border-color: #7C3AED;
  color: #191919;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-white-xl {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 26px 30px;
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
  border-color: #FFFFFF !important;
  color: #191919 !important;
  background: #FFFFFF;
  display: inline-block;
}
.btn-primary-white-xl:hover {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-xl:active {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8) !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-white-xl:focus {
  border-color: rgba(255, 255, 255, 0.8);
  color: #191919;
  background: rgba(255, 255, 255, 0.8);
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

.btn-primary-brand-xl {
  -webkit-transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, -webkit-transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s;
  transition: background-color 0.3s, border-color 0.3s, transform 0.3s, -webkit-transform 0.3s;
  padding: 26px 30px;
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
  border-color: #8B5CF6 !important;
  color: #FFFFFF !important;
  background: #8B5CF6;
  display: inline-block;
}
.btn-primary-brand-xl:hover {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-xl:active {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED !important;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}
.btn-primary-brand-xl:focus {
  border-color: #7C3AED;
  color: #FFFFFF;
  background: #7C3AED;
  -webkit-box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
          box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3);
}

/*
*  BUTTON GENERATOR END
*/
/* ELEMENTS */
.fs-12-400-xs {
  font-size: 12px;
  font-weight: 400;
  line-height: 16px;
}

@media (min-width: 576px) {
  .fs-12-400-sm {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
  }
}

@media (min-width: 768px) {
  .fs-12-400-md {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
  }
}

@media (min-width: 992px) {
  .fs-12-400-lg {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
  }
}

@media (min-width: 1200px) {
  .fs-12-400-xl {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
  }
}

@media (min-width: 1400px) {
  .fs-12-400-xxl {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
  }
}

@media (min-width: 1520px) {
  .fs-12-400-xxxl {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
  }
}

@media (min-width: 1600px) {
  .fs-12-400-xxxxl {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
  }
}

.fs-12-600-xs {
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
}

@media (min-width: 576px) {
  .fs-12-600-sm {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
  }
}

@media (min-width: 768px) {
  .fs-12-600-md {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
  }
}

@media (min-width: 992px) {
  .fs-12-600-lg {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
  }
}

@media (min-width: 1200px) {
  .fs-12-600-xl {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
  }
}

@media (min-width: 1400px) {
  .fs-12-600-xxl {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
  }
}

@media (min-width: 1520px) {
  .fs-12-600-xxxl {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
  }
}

@media (min-width: 1600px) {
  .fs-12-600-xxxxl {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
  }
}

.fs-14-400-xs {
  font-size: 14px;
  font-weight: 400;
  line-height: 18px;
}

@media (min-width: 576px) {
  .fs-14-400-sm {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
  }
}

@media (min-width: 768px) {
  .fs-14-400-md {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
  }
}

@media (min-width: 992px) {
  .fs-14-400-lg {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
  }
}

@media (min-width: 1200px) {
  .fs-14-400-xl {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
  }
}

@media (min-width: 1400px) {
  .fs-14-400-xxl {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
  }
}

@media (min-width: 1520px) {
  .fs-14-400-xxxl {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
  }
}

@media (min-width: 1600px) {
  .fs-14-400-xxxxl {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
  }
}

.fs-14-600-xs {
  font-size: 14px;
  font-weight: 600;
  line-height: 18px;
}

@media (min-width: 576px) {
  .fs-14-600-sm {
    font-size: 14px;
    font-weight: 600;
    line-height: 18px;
  }
}

@media (min-width: 768px) {
  .fs-14-600-md {
    font-size: 14px;
    font-weight: 600;
    line-height: 18px;
  }
}

@media (min-width: 992px) {
  .fs-14-600-lg {
    font-size: 14px;
    font-weight: 600;
    line-height: 18px;
  }
}

@media (min-width: 1200px) {
  .fs-14-600-xl {
    font-size: 14px;
    font-weight: 600;
    line-height: 18px;
  }
}

@media (min-width: 1400px) {
  .fs-14-600-xxl {
    font-size: 14px;
    font-weight: 600;
    line-height: 18px;
  }
}

@media (min-width: 1520px) {
  .fs-14-600-xxxl {
    font-size: 14px;
    font-weight: 600;
    line-height: 18px;
  }
}

@media (min-width: 1600px) {
  .fs-14-600-xxxxl {
    font-size: 14px;
    font-weight: 600;
    line-height: 18px;
  }
}

.fs-16-400-xs {
  font-size: 16px;
  font-weight: 400;
  line-height: 20px;
}

@media (min-width: 576px) {
  .fs-16-400-sm {
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
  }
}

@media (min-width: 768px) {
  .fs-16-400-md {
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
  }
}

@media (min-width: 992px) {
  .fs-16-400-lg {
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
  }
}

@media (min-width: 1200px) {
  .fs-16-400-xl {
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
  }
}

@media (min-width: 1400px) {
  .fs-16-400-xxl {
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
  }
}

@media (min-width: 1520px) {
  .fs-16-400-xxxl {
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
  }
}

@media (min-width: 1600px) {
  .fs-16-400-xxxxl {
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
  }
}

.fs-16-600-xs {
  font-size: 16px;
  font-weight: 600;
  line-height: 20px;
}

@media (min-width: 576px) {
  .fs-16-600-sm {
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
  }
}

@media (min-width: 768px) {
  .fs-16-600-md {
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
  }
}

@media (min-width: 992px) {
  .fs-16-600-lg {
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
  }
}

@media (min-width: 1200px) {
  .fs-16-600-xl {
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
  }
}

@media (min-width: 1400px) {
  .fs-16-600-xxl {
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
  }
}

@media (min-width: 1520px) {
  .fs-16-600-xxxl {
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
  }
}

@media (min-width: 1600px) {
  .fs-16-600-xxxxl {
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
  }
}

.fs-18-400-xs {
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
}

@media (min-width: 576px) {
  .fs-18-400-sm {
    font-size: 18px;
    font-weight: 400;
    line-height: 24px;
  }
}

@media (min-width: 768px) {
  .fs-18-400-md {
    font-size: 18px;
    font-weight: 400;
    line-height: 24px;
  }
}

@media (min-width: 992px) {
  .fs-18-400-lg {
    font-size: 18px;
    font-weight: 400;
    line-height: 24px;
  }
}

@media (min-width: 1200px) {
  .fs-18-400-xl {
    font-size: 18px;
    font-weight: 400;
    line-height: 24px;
  }
}

@media (min-width: 1400px) {
  .fs-18-400-xxl {
    font-size: 18px;
    font-weight: 400;
    line-height: 24px;
  }
}

@media (min-width: 1520px) {
  .fs-18-400-xxxl {
    font-size: 18px;
    font-weight: 400;
    line-height: 24px;
  }
}

@media (min-width: 1600px) {
  .fs-18-400-xxxxl {
    font-size: 18px;
    font-weight: 400;
    line-height: 24px;
  }
}

.fs-18-600-xs {
  font-size: 18px;
  font-weight: 600;
  line-height: 24px;
}

@media (min-width: 576px) {
  .fs-18-600-sm {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
  }
}

@media (min-width: 768px) {
  .fs-18-600-md {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
  }
}

@media (min-width: 992px) {
  .fs-18-600-lg {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
  }
}

@media (min-width: 1200px) {
  .fs-18-600-xl {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
  }
}

@media (min-width: 1400px) {
  .fs-18-600-xxl {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
  }
}

@media (min-width: 1520px) {
  .fs-18-600-xxxl {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
  }
}

@media (min-width: 1600px) {
  .fs-18-600-xxxxl {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px;
  }
}

.fs-20-400-xs {
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
}

@media (min-width: 576px) {
  .fs-20-400-sm {
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
  }
}

@media (min-width: 768px) {
  .fs-20-400-md {
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
  }
}

@media (min-width: 992px) {
  .fs-20-400-lg {
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
  }
}

@media (min-width: 1200px) {
  .fs-20-400-xl {
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
  }
}

@media (min-width: 1400px) {
  .fs-20-400-xxl {
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
  }
}

@media (min-width: 1520px) {
  .fs-20-400-xxxl {
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
  }
}

@media (min-width: 1600px) {
  .fs-20-400-xxxxl {
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
  }
}

.fs-20-600-xs {
  font-size: 20px;
  font-weight: 600;
  line-height: 26px;
}

@media (min-width: 576px) {
  .fs-20-600-sm {
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
  }
}

@media (min-width: 768px) {
  .fs-20-600-md {
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
  }
}

@media (min-width: 992px) {
  .fs-20-600-lg {
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
  }
}

@media (min-width: 1200px) {
  .fs-20-600-xl {
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
  }
}

@media (min-width: 1400px) {
  .fs-20-600-xxl {
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
  }
}

@media (min-width: 1520px) {
  .fs-20-600-xxxl {
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
  }
}

@media (min-width: 1600px) {
  .fs-20-600-xxxxl {
    font-size: 20px;
    font-weight: 600;
    line-height: 26px;
  }
}

.fs-24-400-xs {
  font-size: 24px;
  font-weight: 400;
  line-height: 30px;
}

@media (min-width: 576px) {
  .fs-24-400-sm {
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
  }
}

@media (min-width: 768px) {
  .fs-24-400-md {
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
  }
}

@media (min-width: 992px) {
  .fs-24-400-lg {
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
  }
}

@media (min-width: 1200px) {
  .fs-24-400-xl {
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
  }
}

@media (min-width: 1400px) {
  .fs-24-400-xxl {
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
  }
}

@media (min-width: 1520px) {
  .fs-24-400-xxxl {
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
  }
}

@media (min-width: 1600px) {
  .fs-24-400-xxxxl {
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
  }
}

.fs-24-600-xs {
  font-size: 24px;
  font-weight: 600;
  line-height: 30px;
}

@media (min-width: 576px) {
  .fs-24-600-sm {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
  }
}

@media (min-width: 768px) {
  .fs-24-600-md {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
  }
}

@media (min-width: 992px) {
  .fs-24-600-lg {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
  }
}

@media (min-width: 1200px) {
  .fs-24-600-xl {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
  }
}

@media (min-width: 1400px) {
  .fs-24-600-xxl {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
  }
}

@media (min-width: 1520px) {
  .fs-24-600-xxxl {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
  }
}

@media (min-width: 1600px) {
  .fs-24-600-xxxxl {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
  }
}

.fs-26-400-xs {
  font-size: 26px;
  font-weight: 400;
  line-height: 32px;
}

@media (min-width: 576px) {
  .fs-26-400-sm {
    font-size: 26px;
    font-weight: 400;
    line-height: 32px;
  }
}

@media (min-width: 768px) {
  .fs-26-400-md {
    font-size: 26px;
    font-weight: 400;
    line-height: 32px;
  }
}

@media (min-width: 992px) {
  .fs-26-400-lg {
    font-size: 26px;
    font-weight: 400;
    line-height: 32px;
  }
}

@media (min-width: 1200px) {
  .fs-26-400-xl {
    font-size: 26px;
    font-weight: 400;
    line-height: 32px;
  }
}

@media (min-width: 1400px) {
  .fs-26-400-xxl {
    font-size: 26px;
    font-weight: 400;
    line-height: 32px;
  }
}

@media (min-width: 1520px) {
  .fs-26-400-xxxl {
    font-size: 26px;
    font-weight: 400;
    line-height: 32px;
  }
}

@media (min-width: 1600px) {
  .fs-26-400-xxxxl {
    font-size: 26px;
    font-weight: 400;
    line-height: 32px;
  }
}

.fs-26-600-xs {
  font-size: 26px;
  font-weight: 600;
  line-height: 32px;
}

@media (min-width: 576px) {
  .fs-26-600-sm {
    font-size: 26px;
    font-weight: 600;
    line-height: 32px;
  }
}

@media (min-width: 768px) {
  .fs-26-600-md {
    font-size: 26px;
    font-weight: 600;
    line-height: 32px;
  }
}

@media (min-width: 992px) {
  .fs-26-600-lg {
    font-size: 26px;
    font-weight: 600;
    line-height: 32px;
  }
}

@media (min-width: 1200px) {
  .fs-26-600-xl {
    font-size: 26px;
    font-weight: 600;
    line-height: 32px;
  }
}

@media (min-width: 1400px) {
  .fs-26-600-xxl {
    font-size: 26px;
    font-weight: 600;
    line-height: 32px;
  }
}

@media (min-width: 1520px) {
  .fs-26-600-xxxl {
    font-size: 26px;
    font-weight: 600;
    line-height: 32px;
  }
}

@media (min-width: 1600px) {
  .fs-26-600-xxxxl {
    font-size: 26px;
    font-weight: 600;
    line-height: 32px;
  }
}

.fs-28-400-xs {
  font-size: 28px;
  font-weight: 400;
  line-height: 34px;
}

@media (min-width: 576px) {
  .fs-28-400-sm {
    font-size: 28px;
    font-weight: 400;
    line-height: 34px;
  }
}

@media (min-width: 768px) {
  .fs-28-400-md {
    font-size: 28px;
    font-weight: 400;
    line-height: 34px;
  }
}

@media (min-width: 992px) {
  .fs-28-400-lg {
    font-size: 28px;
    font-weight: 400;
    line-height: 34px;
  }
}

@media (min-width: 1200px) {
  .fs-28-400-xl {
    font-size: 28px;
    font-weight: 400;
    line-height: 34px;
  }
}

@media (min-width: 1400px) {
  .fs-28-400-xxl {
    font-size: 28px;
    font-weight: 400;
    line-height: 34px;
  }
}

@media (min-width: 1520px) {
  .fs-28-400-xxxl {
    font-size: 28px;
    font-weight: 400;
    line-height: 34px;
  }
}

@media (min-width: 1600px) {
  .fs-28-400-xxxxl {
    font-size: 28px;
    font-weight: 400;
    line-height: 34px;
  }
}

.fs-28-600-xs {
  font-size: 28px;
  font-weight: 600;
  line-height: 34px;
}

@media (min-width: 576px) {
  .fs-28-600-sm {
    font-size: 28px;
    font-weight: 600;
    line-height: 34px;
  }
}

@media (min-width: 768px) {
  .fs-28-600-md {
    font-size: 28px;
    font-weight: 600;
    line-height: 34px;
  }
}

@media (min-width: 992px) {
  .fs-28-600-lg {
    font-size: 28px;
    font-weight: 600;
    line-height: 34px;
  }
}

@media (min-width: 1200px) {
  .fs-28-600-xl {
    font-size: 28px;
    font-weight: 600;
    line-height: 34px;
  }
}

@media (min-width: 1400px) {
  .fs-28-600-xxl {
    font-size: 28px;
    font-weight: 600;
    line-height: 34px;
  }
}

@media (min-width: 1520px) {
  .fs-28-600-xxxl {
    font-size: 28px;
    font-weight: 600;
    line-height: 34px;
  }
}

@media (min-width: 1600px) {
  .fs-28-600-xxxxl {
    font-size: 28px;
    font-weight: 600;
    line-height: 34px;
  }
}

.fs-30-400-xs {
  font-size: 30px;
  font-weight: 400;
  line-height: 36px;
}

@media (min-width: 576px) {
  .fs-30-400-sm {
    font-size: 30px;
    font-weight: 400;
    line-height: 36px;
  }
}

@media (min-width: 768px) {
  .fs-30-400-md {
    font-size: 30px;
    font-weight: 400;
    line-height: 36px;
  }
}

@media (min-width: 992px) {
  .fs-30-400-lg {
    font-size: 30px;
    font-weight: 400;
    line-height: 36px;
  }
}

@media (min-width: 1200px) {
  .fs-30-400-xl {
    font-size: 30px;
    font-weight: 400;
    line-height: 36px;
  }
}

@media (min-width: 1400px) {
  .fs-30-400-xxl {
    font-size: 30px;
    font-weight: 400;
    line-height: 36px;
  }
}

@media (min-width: 1520px) {
  .fs-30-400-xxxl {
    font-size: 30px;
    font-weight: 400;
    line-height: 36px;
  }
}

@media (min-width: 1600px) {
  .fs-30-400-xxxxl {
    font-size: 30px;
    font-weight: 400;
    line-height: 36px;
  }
}

.fs-30-600-xs {
  font-size: 30px;
  font-weight: 600;
  line-height: 36px;
}

@media (min-width: 576px) {
  .fs-30-600-sm {
    font-size: 30px;
    font-weight: 600;
    line-height: 36px;
  }
}

@media (min-width: 768px) {
  .fs-30-600-md {
    font-size: 30px;
    font-weight: 600;
    line-height: 36px;
  }
}

@media (min-width: 992px) {
  .fs-30-600-lg {
    font-size: 30px;
    font-weight: 600;
    line-height: 36px;
  }
}

@media (min-width: 1200px) {
  .fs-30-600-xl {
    font-size: 30px;
    font-weight: 600;
    line-height: 36px;
  }
}

@media (min-width: 1400px) {
  .fs-30-600-xxl {
    font-size: 30px;
    font-weight: 600;
    line-height: 36px;
  }
}

@media (min-width: 1520px) {
  .fs-30-600-xxxl {
    font-size: 30px;
    font-weight: 600;
    line-height: 36px;
  }
}

@media (min-width: 1600px) {
  .fs-30-600-xxxxl {
    font-size: 30px;
    font-weight: 600;
    line-height: 36px;
  }
}

.fs-36-400-xs {
  font-size: 36px;
  font-weight: 400;
  line-height: 42px;
}

@media (min-width: 576px) {
  .fs-36-400-sm {
    font-size: 36px;
    font-weight: 400;
    line-height: 42px;
  }
}

@media (min-width: 768px) {
  .fs-36-400-md {
    font-size: 36px;
    font-weight: 400;
    line-height: 42px;
  }
}

@media (min-width: 992px) {
  .fs-36-400-lg {
    font-size: 36px;
    font-weight: 400;
    line-height: 42px;
  }
}

@media (min-width: 1200px) {
  .fs-36-400-xl {
    font-size: 36px;
    font-weight: 400;
    line-height: 42px;
  }
}

@media (min-width: 1400px) {
  .fs-36-400-xxl {
    font-size: 36px;
    font-weight: 400;
    line-height: 42px;
  }
}

@media (min-width: 1520px) {
  .fs-36-400-xxxl {
    font-size: 36px;
    font-weight: 400;
    line-height: 42px;
  }
}

@media (min-width: 1600px) {
  .fs-36-400-xxxxl {
    font-size: 36px;
    font-weight: 400;
    line-height: 42px;
  }
}

.fs-36-600-xs {
  font-size: 36px;
  font-weight: 600;
  line-height: 42px;
}

@media (min-width: 576px) {
  .fs-36-600-sm {
    font-size: 36px;
    font-weight: 600;
    line-height: 42px;
  }
}

@media (min-width: 768px) {
  .fs-36-600-md {
    font-size: 36px;
    font-weight: 600;
    line-height: 42px;
  }
}

@media (min-width: 992px) {
  .fs-36-600-lg {
    font-size: 36px;
    font-weight: 600;
    line-height: 42px;
  }
}

@media (min-width: 1200px) {
  .fs-36-600-xl {
    font-size: 36px;
    font-weight: 600;
    line-height: 42px;
  }
}

@media (min-width: 1400px) {
  .fs-36-600-xxl {
    font-size: 36px;
    font-weight: 600;
    line-height: 42px;
  }
}

@media (min-width: 1520px) {
  .fs-36-600-xxxl {
    font-size: 36px;
    font-weight: 600;
    line-height: 42px;
  }
}

@media (min-width: 1600px) {
  .fs-36-600-xxxxl {
    font-size: 36px;
    font-weight: 600;
    line-height: 42px;
  }
}

.fs-40-400-xs {
  font-size: 40px;
  font-weight: 400;
  line-height: 46px;
}

@media (min-width: 576px) {
  .fs-40-400-sm {
    font-size: 40px;
    font-weight: 400;
    line-height: 46px;
  }
}

@media (min-width: 768px) {
  .fs-40-400-md {
    font-size: 40px;
    font-weight: 400;
    line-height: 46px;
  }
}

@media (min-width: 992px) {
  .fs-40-400-lg {
    font-size: 40px;
    font-weight: 400;
    line-height: 46px;
  }
}

@media (min-width: 1200px) {
  .fs-40-400-xl {
    font-size: 40px;
    font-weight: 400;
    line-height: 46px;
  }
}

@media (min-width: 1400px) {
  .fs-40-400-xxl {
    font-size: 40px;
    font-weight: 400;
    line-height: 46px;
  }
}

@media (min-width: 1520px) {
  .fs-40-400-xxxl {
    font-size: 40px;
    font-weight: 400;
    line-height: 46px;
  }
}

@media (min-width: 1600px) {
  .fs-40-400-xxxxl {
    font-size: 40px;
    font-weight: 400;
    line-height: 46px;
  }
}

.fs-40-600-xs {
  font-size: 40px;
  font-weight: 600;
  line-height: 46px;
}

@media (min-width: 576px) {
  .fs-40-600-sm {
    font-size: 40px;
    font-weight: 600;
    line-height: 46px;
  }
}

@media (min-width: 768px) {
  .fs-40-600-md {
    font-size: 40px;
    font-weight: 600;
    line-height: 46px;
  }
}

@media (min-width: 992px) {
  .fs-40-600-lg {
    font-size: 40px;
    font-weight: 600;
    line-height: 46px;
  }
}

@media (min-width: 1200px) {
  .fs-40-600-xl {
    font-size: 40px;
    font-weight: 600;
    line-height: 46px;
  }
}

@media (min-width: 1400px) {
  .fs-40-600-xxl {
    font-size: 40px;
    font-weight: 600;
    line-height: 46px;
  }
}

@media (min-width: 1520px) {
  .fs-40-600-xxxl {
    font-size: 40px;
    font-weight: 600;
    line-height: 46px;
  }
}

@media (min-width: 1600px) {
  .fs-40-600-xxxxl {
    font-size: 40px;
    font-weight: 600;
    line-height: 46px;
  }
}

.fs-48-400-xs {
  font-size: 48px;
  font-weight: 400;
  line-height: 56px;
}

@media (min-width: 576px) {
  .fs-48-400-sm {
    font-size: 48px;
    font-weight: 400;
    line-height: 56px;
  }
}

@media (min-width: 768px) {
  .fs-48-400-md {
    font-size: 48px;
    font-weight: 400;
    line-height: 56px;
  }
}

@media (min-width: 992px) {
  .fs-48-400-lg {
    font-size: 48px;
    font-weight: 400;
    line-height: 56px;
  }
}

@media (min-width: 1200px) {
  .fs-48-400-xl {
    font-size: 48px;
    font-weight: 400;
    line-height: 56px;
  }
}

@media (min-width: 1400px) {
  .fs-48-400-xxl {
    font-size: 48px;
    font-weight: 400;
    line-height: 56px;
  }
}

@media (min-width: 1520px) {
  .fs-48-400-xxxl {
    font-size: 48px;
    font-weight: 400;
    line-height: 56px;
  }
}

@media (min-width: 1600px) {
  .fs-48-400-xxxxl {
    font-size: 48px;
    font-weight: 400;
    line-height: 56px;
  }
}

.fs-48-600-xs {
  font-size: 48px;
  font-weight: 600;
  line-height: 56px;
}

@media (min-width: 576px) {
  .fs-48-600-sm {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
  }
}

@media (min-width: 768px) {
  .fs-48-600-md {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
  }
}

@media (min-width: 992px) {
  .fs-48-600-lg {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
  }
}

@media (min-width: 1200px) {
  .fs-48-600-xl {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
  }
}

@media (min-width: 1400px) {
  .fs-48-600-xxl {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
  }
}

@media (min-width: 1520px) {
  .fs-48-600-xxxl {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
  }
}

@media (min-width: 1600px) {
  .fs-48-600-xxxxl {
    font-size: 48px;
    font-weight: 600;
    line-height: 56px;
  }
}

.fs-60-400-xs {
  font-size: 60px;
  font-weight: 400;
  line-height: 68px;
}

@media (min-width: 576px) {
  .fs-60-400-sm {
    font-size: 60px;
    font-weight: 400;
    line-height: 68px;
  }
}

@media (min-width: 768px) {
  .fs-60-400-md {
    font-size: 60px;
    font-weight: 400;
    line-height: 68px;
  }
}

@media (min-width: 992px) {
  .fs-60-400-lg {
    font-size: 60px;
    font-weight: 400;
    line-height: 68px;
  }
}

@media (min-width: 1200px) {
  .fs-60-400-xl {
    font-size: 60px;
    font-weight: 400;
    line-height: 68px;
  }
}

@media (min-width: 1400px) {
  .fs-60-400-xxl {
    font-size: 60px;
    font-weight: 400;
    line-height: 68px;
  }
}

@media (min-width: 1520px) {
  .fs-60-400-xxxl {
    font-size: 60px;
    font-weight: 400;
    line-height: 68px;
  }
}

@media (min-width: 1600px) {
  .fs-60-400-xxxxl {
    font-size: 60px;
    font-weight: 400;
    line-height: 68px;
  }
}

.fs-60-600-xs {
  font-size: 60px;
  font-weight: 600;
  line-height: 68px;
}

@media (min-width: 576px) {
  .fs-60-600-sm {
    font-size: 60px;
    font-weight: 600;
    line-height: 68px;
  }
}

@media (min-width: 768px) {
  .fs-60-600-md {
    font-size: 60px;
    font-weight: 600;
    line-height: 68px;
  }
}

@media (min-width: 992px) {
  .fs-60-600-lg {
    font-size: 60px;
    font-weight: 600;
    line-height: 68px;
  }
}

@media (min-width: 1200px) {
  .fs-60-600-xl {
    font-size: 60px;
    font-weight: 600;
    line-height: 68px;
  }
}

@media (min-width: 1400px) {
  .fs-60-600-xxl {
    font-size: 60px;
    font-weight: 600;
    line-height: 68px;
  }
}

@media (min-width: 1520px) {
  .fs-60-600-xxxl {
    font-size: 60px;
    font-weight: 600;
    line-height: 68px;
  }
}

@media (min-width: 1600px) {
  .fs-60-600-xxxxl {
    font-size: 60px;
    font-weight: 600;
    line-height: 68px;
  }
}

.fs-72-400-xs {
  font-size: 72px;
  font-weight: 400;
  line-height: 80px;
}

@media (min-width: 576px) {
  .fs-72-400-sm {
    font-size: 72px;
    font-weight: 400;
    line-height: 80px;
  }
}

@media (min-width: 768px) {
  .fs-72-400-md {
    font-size: 72px;
    font-weight: 400;
    line-height: 80px;
  }
}

@media (min-width: 992px) {
  .fs-72-400-lg {
    font-size: 72px;
    font-weight: 400;
    line-height: 80px;
  }
}

@media (min-width: 1200px) {
  .fs-72-400-xl {
    font-size: 72px;
    font-weight: 400;
    line-height: 80px;
  }
}

@media (min-width: 1400px) {
  .fs-72-400-xxl {
    font-size: 72px;
    font-weight: 400;
    line-height: 80px;
  }
}

@media (min-width: 1520px) {
  .fs-72-400-xxxl {
    font-size: 72px;
    font-weight: 400;
    line-height: 80px;
  }
}

@media (min-width: 1600px) {
  .fs-72-400-xxxxl {
    font-size: 72px;
    font-weight: 400;
    line-height: 80px;
  }
}

.fs-72-600-xs {
  font-size: 72px;
  font-weight: 600;
  line-height: 80px;
}

@media (min-width: 576px) {
  .fs-72-600-sm {
    font-size: 72px;
    font-weight: 600;
    line-height: 80px;
  }
}

@media (min-width: 768px) {
  .fs-72-600-md {
    font-size: 72px;
    font-weight: 600;
    line-height: 80px;
  }
}

@media (min-width: 992px) {
  .fs-72-600-lg {
    font-size: 72px;
    font-weight: 600;
    line-height: 80px;
  }
}

@media (min-width: 1200px) {
  .fs-72-600-xl {
    font-size: 72px;
    font-weight: 600;
    line-height: 80px;
  }
}

@media (min-width: 1400px) {
  .fs-72-600-xxl {
    font-size: 72px;
    font-weight: 600;
    line-height: 80px;
  }
}

@media (min-width: 1520px) {
  .fs-72-600-xxxl {
    font-size: 72px;
    font-weight: 600;
    line-height: 80px;
  }
}

@media (min-width: 1600px) {
  .fs-72-600-xxxxl {
    font-size: 72px;
    font-weight: 600;
    line-height: 80px;
  }
}

.fs-80-400-xs {
  font-size: 80px;
  font-weight: 400;
  line-height: 88px;
}

@media (min-width: 576px) {
  .fs-80-400-sm {
    font-size: 80px;
    font-weight: 400;
    line-height: 88px;
  }
}

@media (min-width: 768px) {
  .fs-80-400-md {
    font-size: 80px;
    font-weight: 400;
    line-height: 88px;
  }
}

@media (min-width: 992px) {
  .fs-80-400-lg {
    font-size: 80px;
    font-weight: 400;
    line-height: 88px;
  }
}

@media (min-width: 1200px) {
  .fs-80-400-xl {
    font-size: 80px;
    font-weight: 400;
    line-height: 88px;
  }
}

@media (min-width: 1400px) {
  .fs-80-400-xxl {
    font-size: 80px;
    font-weight: 400;
    line-height: 88px;
  }
}

@media (min-width: 1520px) {
  .fs-80-400-xxxl {
    font-size: 80px;
    font-weight: 400;
    line-height: 88px;
  }
}

@media (min-width: 1600px) {
  .fs-80-400-xxxxl {
    font-size: 80px;
    font-weight: 400;
    line-height: 88px;
  }
}

.fs-80-600-xs {
  font-size: 80px;
  font-weight: 600;
  line-height: 88px;
}

@media (min-width: 576px) {
  .fs-80-600-sm {
    font-size: 80px;
    font-weight: 600;
    line-height: 88px;
  }
}

@media (min-width: 768px) {
  .fs-80-600-md {
    font-size: 80px;
    font-weight: 600;
    line-height: 88px;
  }
}

@media (min-width: 992px) {
  .fs-80-600-lg {
    font-size: 80px;
    font-weight: 600;
    line-height: 88px;
  }
}

@media (min-width: 1200px) {
  .fs-80-600-xl {
    font-size: 80px;
    font-weight: 600;
    line-height: 88px;
  }
}

@media (min-width: 1400px) {
  .fs-80-600-xxl {
    font-size: 80px;
    font-weight: 600;
    line-height: 88px;
  }
}

@media (min-width: 1520px) {
  .fs-80-600-xxxl {
    font-size: 80px;
    font-weight: 600;
    line-height: 88px;
  }
}

@media (min-width: 1600px) {
  .fs-80-600-xxxxl {
    font-size: 80px;
    font-weight: 600;
    line-height: 88px;
  }
}

.fs-120-400-xs {
  font-size: 120px;
  font-weight: 400;
  line-height: 96px;
}

@media (min-width: 576px) {
  .fs-120-400-sm {
    font-size: 120px;
    font-weight: 400;
    line-height: 96px;
  }
}

@media (min-width: 768px) {
  .fs-120-400-md {
    font-size: 120px;
    font-weight: 400;
    line-height: 96px;
  }
}

@media (min-width: 992px) {
  .fs-120-400-lg {
    font-size: 120px;
    font-weight: 400;
    line-height: 96px;
  }
}

@media (min-width: 1200px) {
  .fs-120-400-xl {
    font-size: 120px;
    font-weight: 400;
    line-height: 96px;
  }
}

@media (min-width: 1400px) {
  .fs-120-400-xxl {
    font-size: 120px;
    font-weight: 400;
    line-height: 96px;
  }
}

@media (min-width: 1520px) {
  .fs-120-400-xxxl {
    font-size: 120px;
    font-weight: 400;
    line-height: 96px;
  }
}

@media (min-width: 1600px) {
  .fs-120-400-xxxxl {
    font-size: 120px;
    font-weight: 400;
    line-height: 96px;
  }
}

.fs-120-600-xs {
  font-size: 120px;
  font-weight: 600;
  line-height: 96px;
}

@media (min-width: 576px) {
  .fs-120-600-sm {
    font-size: 120px;
    font-weight: 600;
    line-height: 96px;
  }
}

@media (min-width: 768px) {
  .fs-120-600-md {
    font-size: 120px;
    font-weight: 600;
    line-height: 96px;
  }
}

@media (min-width: 992px) {
  .fs-120-600-lg {
    font-size: 120px;
    font-weight: 600;
    line-height: 96px;
  }
}

@media (min-width: 1200px) {
  .fs-120-600-xl {
    font-size: 120px;
    font-weight: 600;
    line-height: 96px;
  }
}

@media (min-width: 1400px) {
  .fs-120-600-xxl {
    font-size: 120px;
    font-weight: 600;
    line-height: 96px;
  }
}

@media (min-width: 1520px) {
  .fs-120-600-xxxl {
    font-size: 120px;
    font-weight: 600;
    line-height: 96px;
  }
}

@media (min-width: 1600px) {
  .fs-120-600-xxxxl {
    font-size: 120px;
    font-weight: 600;
    line-height: 96px;
  }
}

/*
*  GLOBAL ELEMENTS&STYLES START
*/
html, body {
  font-family: "SF UI Text", serif;
  scroll-behavior: smooth;
  overflow-x: hidden;
  font-size: 16px;
  font-weight: 400;
  color: #191919;
}

a {
  color: #8B5CF6;
}
a:hover {
  color: #A78BFA;
}

.bg-primary {
  background-color: #8B5CF6;
}

#primary {
  min-height: 45vh;
}

.bg-primary-subtle {
  background-color: #ddd6fe !important;
}

.text-muted {
  color: #CDCFD2;
}

nav .nav li a {
  color: #191919;
  text-decoration: none;
}

input[type=checkbox]:focus, input[type=color]:focus, input[type=date]:focus, input[type=datetime-local]:focus, input[type=datetime]:focus, input[type=email]:focus, input[type=month]:focus, input[type=number]:focus, input[type=password]:focus, input[type=radio]:focus, input[type=search]:focus, input[type=tel]:focus, input[type=text]:focus, input[type=time]:focus, input[type=url]:focus, input[type=week]:focus, select:focus, textarea:focus {
  outline: none;
  border-color: #8B5CF6;
  -webkit-box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
          box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
}

.form-control:focus {
  outline: none;
  border-color: #8B5CF6;
  -webkit-box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
          box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
}

.wp-core-ui .button-group.button-large .button, .wp-core-ui .button.button-large {
  border: 0 !important;
  --bs-btn-padding-x: 0.75rem;
  --bs-btn-padding-y: 0.65rem;
  --bs-btn-font-family: SF UI Text;
  --bs-btn-font-size: 1rem;
  --bs-btn-font-weight: 400;
  --bs-btn-line-height: 1.5;
  --bs-btn-color: #212529;
  --bs-btn-bg: transparent;
  --bs-btn-border-width: 1px;
  --bs-btn-border-color: transparent;
  --bs-btn-border-radius: 0.75rem;
  --bs-btn-hover-border-color: transparent;
  --bs-btn-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);
  --bs-btn-disabled-opacity: 0.65;
  --bs-btn-focus-box-shadow: 0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);
  display: inline-block;
  padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
  font-family: var(--bs-btn-font-family);
  font-size: var(--bs-btn-font-size);
  font-weight: var(--bs-btn-font-weight);
  line-height: var(--bs-btn-line-height);
  color: #FFFFFF;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
  border-radius: var(--bs-btn-border-radius);
  background-color: #8B5CF6;
  -webkit-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  --bs-btn-color: #000;
  --bs-btn-bg: #5FB2B7;
  --bs-btn-border-color: #5FB2B7;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: rgb(119, 189.55, 193.8);
  --bs-btn-hover-border-color: rgb(111, 185.7, 190.2);
  --bs-btn-focus-shadow-rgb: 81, 151, 156;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: rgb(127, 193.4, 197.4);
  --bs-btn-active-border-color: rgb(111, 185.7, 190.2);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #000;
  --bs-btn-disabled-bg: #5FB2B7;
  --bs-btn-disabled-border-color: #5FB2B7;
}

.wp-core-ui .button-group.button-large .button, .wp-core-ui .button.button-large:hover {
  color: #FFFFFF;
  background-color: #A78BFA;
  border-color: #A78BFA;
}

.entry-title {
  padding-top: 30px;
  padding-bottom: 20px;
}

.page-title {
  padding-top: 30px;
  padding-bottom: 20px;
}
.page-title .text {
  max-width: 678px;
}
.page-title .entry-title {
  font-size: 46px;
  line-height: 48px;
  font-weight: 100;
}

.section-bordered {
  /*border: 8px solid #f8f8f8;*/
  border: 6px solid #f4f4f4;
  background: #fff !important;
  /*padding: 20px 22px;*/
  padding: 15px 20px 15px 20px;
  border-radius: 8px;
}

.SumoSelect {
  display: block;
  width: 100% !important;
  padding: 0.65rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 0.75rem;
  -webkit-transition: border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
}
.SumoSelect .CaptionCont {
  border: 0 !important;
  color: #191919 !important;
  padding: 0 !important;
  outline: none !important;
}
.SumoSelect .CaptionCont span {
  background: none !important;
}

.SumoSelect > .optWrapper.multiple > .options li.opt.selected span i {
  background-color: #00bbc1;
}

.form-group {
  margin-bottom: 1.5rem;
}
.form-group:last-child {
  margin-bottom: 0;
}

label {
  display: block;
  margin-bottom: 0.6rem;
  font-weight: 500;
  font-size: 0.95rem;
  color: var(--text-primary);
}

.label-hint {
  font-size: 0.85rem;
  color: var(--text-secondary);
  font-weight: 400;
  display: block;
  margin-top: 0.3rem;
}

textarea {
  border: 2px solid #E5E7EB !important;
}
textarea:focus {
  border-color: #8B5CF6 !important;
}

input[type=text],
input[type=email],
input[type=url],
textarea,
select {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid #E5E7EB;
  border-radius: 8px;
  font-size: 0.95rem;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  background-color: #FFFFFF;
  color: #222224;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=url]:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: #8B5CF6;
  -webkit-box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
          box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
}

.input-group {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.input-group-full {
  grid-column: 1/-1;
}

.file-input-wrapper {
  position: relative;
  overflow: hidden;
  display: inline-block;
}
.file-input-wrapper .file-input-label {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0.75rem 1.2rem;
  background: #8B5CF6;
  color: #FFFFFF;
  border-radius: 0.75rem;
  cursor: pointer;
  font-weight: 500;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.file-input-wrapper input[type=file] {
  position: absolute;
  left: -9999px;
}

.wpcf7 label {
  width: 100%;
  margin-bottom: 10px;
}

.link-with-arrow {
  color: #8B5CF6;
  text-decoration: none;
  font-weight: 400;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.link-with-arrow:hover svg {
  -webkit-transform: translateX(4px);
      -ms-transform: translateX(4px);
          transform: translateX(4px);
}
.link-with-arrow svg {
  margin-left: 6px;
  -webkit-transition: -webkit-transform 0.2s ease;
  transition: -webkit-transform 0.2s ease;
  transition: transform 0.2s ease;
  transition: transform 0.2s ease, -webkit-transform 0.2s ease;
}

.section {
  padding: 80px 0;
}
.section--light {
  background-color: var(--color-bg-alt);
}
.section__header {
  margin-bottom: 60px;
}
.section__title {
  font-size: 2.25rem;
  font-weight: 700;
  margin-bottom: 16px;
  color: var(--color-text);
}
.section__subtitle {
  font-size: 1.1rem;
  color: var(--color-text-muted);
}

/* --- Scroll Animation (Base) --- */
.reveal-on-scroll {
  opacity: 0;
  -webkit-transform: translateY(30px);
      -ms-transform: translateY(30px);
          transform: translateY(30px);
  -webkit-transition: opacity 0.6s ease-out, -webkit-transform 0.6s ease-out;
  transition: opacity 0.6s ease-out, -webkit-transform 0.6s ease-out;
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  transition: opacity 0.6s ease-out, transform 0.6s ease-out, -webkit-transform 0.6s ease-out;
  will-change: opacity, transform;
}
.reveal-on-scroll.is-visible {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}

/*
*  GLOBAL ELEMENTS END
*/
/*
*  ELEMENTS START
*/
.audience__item, .feature-card {
  background: var(--color-white);
  padding: 32px;
  border-radius: var(--radius-lg);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  height: 100%;
}
.audience__item:hover, .feature-card:hover {
  -webkit-transform: translateY(-8px);
      -ms-transform: translateY(-8px);
          transform: translateY(-8px);
  -webkit-box-shadow: 0 8px 24px rgba(124, 58, 237, 0.12);
          box-shadow: 0 8px 24px rgba(124, 58, 237, 0.12);
  border-color: transparent;
}

.audience__icon, .feature-card__icon {
  width: 64px;
  height: 64px;
  min-width: 64px;
  background-color: #f1f5f9;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: var(--color-primary);
  font-size: 32px;
  margin-bottom: 32px;
}

.docList .bcard .cover {
  max-width: 300px;
}
.docList .bcard .meta i {
  color: #8B5CF6;
  margin-right: 7px;
  font-size: 20px;
}
.docList .bcard .files table {
  max-width: 600px;
}

.docList .item {
  background: #f5f5f5;
  border-radius: 12px;
  padding: 10px;
}
.docList .item .card-title small {
  display: block;
  color: #CDCFD2;
  line-height: 100%;
}
.docList .item .meta .meta__item {
  line-height: 19px;
  margin-right: 20px;
}
.docList .item .initial {
  padding: 18px 0;
}
.docList .item .initial i {
  color: #414B5A;
  font-size: 1.7rem;
  margin-right: 0.6rem;
}
.docList .item .updates {
  max-width: 700px;
}

.bcard {
  background-color: #FFFFFF;
  border-radius: 12px;
  padding: 2rem;
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  border: 1px solid var(--border);
  -webkit-transition: -webkit-box-shadow 0.3s ease;
  transition: -webkit-box-shadow 0.3s ease;
  transition: box-shadow 0.3s ease;
  transition: box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
.bcard:hover {
  -webkit-box-shadow: 0 8px 24px rgba(124, 58, 237, 0.12);
          box-shadow: 0 8px 24px rgba(124, 58, 237, 0.12);
}
.bcard .bcard-title {
  font-size: 1.4rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
  color: #8B5CF6;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.8rem;
}
.bcard .bcard-title::before {
  content: "";
  width: 4px;
  height: 24px;
  background: -webkit-gradient(linear, left top, left bottom, from(#8B5CF6), to(#06B6D4));
  background: linear-gradient(180deg, #8B5CF6 0%, #06B6D4 100%);
  border-radius: 2px;
}

.gradient-block {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.05) 0%, rgba(6, 182, 212, 0.05) 100%);
  border-radius: 16px;
  padding: 1.5rem;
  border: 1px solid rgba(124, 58, 237, 0.0980392157);
}

/*
*  ELEMENTS END
*/
/*
*  LOGIN FORM START
*/
#login {
  width: 400px !important;
}

.login .message, .login .notice, .login .success {
  border-left: 4px solid #8B5CF6;
}

.login form .input, .login input[type=password], .login input[type=text] {
  display: block;
  width: 100%;
  padding: 0.65rem 0.75rem;
  font-family: "SF UI Text";
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #222224;
  background-color: #FFFFFF;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 0.75rem;
  -webkit-transition: border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
}

.login label {
  font-size: 1rem;
  line-height: 1.5rem;
}

.login form .forgetmenot {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

/*
*  LOGIN FORM END
*/
/*
*  HEADER START
*/
.site-header {
  background-color: #fff;
  border-bottom: 1px solid #CDCFD2;
}
.site-header .site-logo {
  z-index: 999999;
}
.site-header .site-logo img {
  max-height: 60px;
  width: auto;
}
.site-header .site-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: #333;
}
.site-header .site-description {
  font-size: 0.875rem;
  color: #222224;
}
.site-header .nav li {
  line-height: 100%;
  padding: 10px;
}
.site-header .nav li a {
  color: #4B5563;
  font-weight: 500;
  text-decoration: none;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: relative;
}
.site-header .nav li a:after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 0;
  height: 2px;
  background: #8B5CF6;
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}
.site-header .nav li a:hover, .site-header .nav li a.current-menu-item {
  color: #7C3AED;
}
.site-header .nav li a:hover:after, .site-header .nav li a.current-menu-item:after {
  width: 100%;
}
.site-header .nav li.menu-icon a::before {
  font-family: "Font Awesome 6 Pro";
  margin-right: 0.7rem;
  font-weight: 500;
  font-size: 1.5rem;
  color: #697888;
}
.site-header .nav li.menu-profile a::before {
  content: "\f2bd";
}
.site-header .nav li.menu-documents a::before {
  content: "\f5db";
}
.site-header .nav li.menu-logout a::before {
  content: "\e616";
}
.site-header .nav li.menu-sign-in a::before {
  content: "\e4b2";
}
.site-header .nav li.menu-docs a::before {
  content: "\f02d";
}
.site-header .nav li.menu-about a::before {
  content: "\f05a";
}
.site-header .nav li.menu-contacts a::before {
  content: "\f095";
}

/* Mobile Menu Styles */
/* Hamburger Icon Button */
.site-header .mobile-menu-toggle {
  display: none;
  background: transparent;
  border: none;
  font-size: 24px;
  color: var(--color-text);
  cursor: pointer;
  padding: 10px;
  z-index: 998;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.site-header .mobile-menu-toggle:hover {
  color: var(--color-primary);
}
.site-header .mobile-menu-toggle:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.site-header {
  /* Fullscreen Menu Overlay - Hidden by default */
}
.site-header .mobile-menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(139, 92, 246, 0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.4s ease, visibility 0.4s ease;
  transition: opacity 0.4s ease, visibility 0.4s ease;
  z-index: 999;
  overflow-y: auto;
  padding: 80px 20px 40px;
}
.site-header .mobile-menu-overlay.active {
  opacity: 1;
  visibility: visible;
}
.site-header {
  /* Close Button */
}
.site-header .mobile-menu-close {
  position: fixed;
  top: 65px;
  right: 10px;
  background: transparent;
  border: none;
  font-size: 32px;
  color: #FFFFFF;
  cursor: pointer;
  padding: 5px;
  z-index: 1000;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  width: 40px;
  height: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.site-header .mobile-menu-close:hover {
  color: #E5E7EB;
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
}
.site-header .mobile-menu-close:focus {
  outline: 2px solid #E5E7EB;
  outline-offset: 2px;
}
.site-header {
  /* Mobile Navigation Menu */
}
.site-header .mobile-menu-container {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.site-header .mobile-nav-menu {
  list-style: none;
  padding: 0;
  margin: 0;
}
.site-header .mobile-nav-menu > li {
  margin: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  padding: 0;
}
.site-header .mobile-nav-menu > li > a {
  display: block;
  padding: 16px 0;
  color: #FFFFFF;
  text-decoration: none;
  font-size: 18px;
  font-weight: 500;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.site-header .mobile-nav-menu > li > a:hover {
  color: #E5E7EB;
  padding-left: 10px;
}
.site-header .mobile-nav-menu > li > a:focus {
  outline: 2px solid #E5E7EB;
  outline-offset: 2px;
}
.site-header .mobile-nav-menu > li > a:after {
  display: none;
}
.site-header .mobile-nav-menu ul {
  list-style: none;
  padding: 0;
  margin: 10px 0;
  max-height: 0;
  overflow: hidden;
  -webkit-transition: max-height 0.3s ease;
  transition: max-height 0.3s ease;
}
.site-header .mobile-nav-menu ul li a {
  display: block;
  padding: 12px 0 12px 20px;
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  font-size: 16px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.site-header .mobile-nav-menu ul li a:hover {
  color: #E5E7EB;
  padding-left: 30px;
}
.site-header .mobile-nav-menu li.menu-item-has-children > a::after {
  content: "\f078";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  display: inline-block;
  margin-left: 8px;
  font-size: 12px;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.site-header .mobile-nav-menu li.menu-item-has-children.active > a::after {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
.site-header .mobile-nav-menu li.menu-item-has-children.active > ul {
  max-height: 500px;
}

/* Desktop View - Hide mobile menu elements */
@media (min-width: 768px) {
  .site-header .mobile-menu-toggle {
    display: none !important;
  }
  .site-header .mobile-menu-overlay {
    display: none !important;
  }
  .site-header .main-navigation {
    display: block !important;
  }
}
/* Mobile View - Show mobile menu elements */
@media (max-width: 767px) {
  .site-header .mobile-menu-toggle {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .site-header .main-navigation:not(.mobile-menu-container) {
    display: none;
  }
}
/* Prevent body scroll when menu is open */
body.menu-open {
  overflow: hidden;
}

/*
*  HEADER END
*/
/*
*  FOOTER START
*/
#footer {
  margin-top: 4rem;
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.05) 0%, rgba(6, 182, 212, 0.05) 100%);
}
#footer .footer-logo img {
  max-width: 350px;
  height: auto;
}
#footer .footer-contacts a {
  text-decoration: none;
}
#footer nav .nav li {
  margin-bottom: 0.5rem;
}
/*
*  FOOTER END
*/
/*
*  ELEMENTS START
*/
.ImageInfoBox p {
  margin-bottom: 16px;
}
.ImageInfoBox .image-wrapper .image {
  margin: 0;
}
.ImageInfoBox .title {
  margin-bottom: 30px;
}
.ImageInfoBox button {
  margin-top: 48px;
}

.featureBox {
  margin-bottom: 48px;
  text-align: center;
}
.featureBox:hover .image {
  -webkit-transition: top 0.3s ease;
  transition: top 0.3s ease;
  top: -10px;
}
.featureBox .image {
  position: relative;
  top: 0;
  margin: 0 auto 12px;
  -webkit-transition: top 0.3s ease;
  transition: top 0.3s ease;
  width: 90px;
  height: 90px;
  background: #F7F7F8;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 32px;
}
.featureBox .image i {
  font-size: 40px;
  color: #8B5CF6;
}
.featureBox .title {
  margin-bottom: 12px;
  font-family: "SF UI Display", serif !important;
}
#primary a {
  text-decoration: none;
}

/*
*  ELEMENTS END
*/
/*
*  FRONT PAGE
*/
/* --- Hero Section --- */
.hero {
  position: relative;
  padding-top: calc(var(--header-height) + 40px);
  padding-bottom: 60px;
  overflow: hidden;
}
.hero__bg-blob {
  position: absolute;
  top: -10%;
  right: -5%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(124, 58, 237, 0.1) 0%, rgba(255, 255, 255, 0) 70%);
  z-index: -1;
  pointer-events: none;
}
.hero__slogan {
  font-size: 1.5rem;
  font-weight: 500;
  margin-bottom: 24px;
  color: #475569;
  /* Slate-600 - Dark Gray */
  letter-spacing: -0.01em;
  line-height: 1.4;
}
@media (min-width: 992px) {
  .hero__slogan {
    font-size: 1.75rem;
  }
}
.hero__title {
  font-size: 3.5rem;
  line-height: 1.1;
  font-weight: 800;
  margin-bottom: 24px;
  color: var(--color-text);
}
.hero__description {
  font-size: 1.125rem;
  color: var(--color-text-muted);
  margin-bottom: 32px;
  max-width: 480px;
}
.hero__actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
}
.hero__visual {
  position: relative;
  height: 460px;
  background-color: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-perspective: 1000px;
          perspective: 1000px;
}

/* Dashboard Card (Main) */
.dashboard-card {
  position: relative;
  width: 360px;
  height: 280px;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  -webkit-box-shadow: 0 20px 40px -10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 20px 40px -10px rgba(0, 0, 0, 0.15);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 20px;
  z-index: 2;
  -webkit-transform: rotateY(-5deg) rotateX(5deg);
          transform: rotateY(-5deg) rotateX(5deg);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  border: 1px solid var(--color-border);
}
.dashboard-card:hover {
  -webkit-transform: rotateY(0) rotateX(0);
          transform: rotateY(0) rotateX(0);
}

.dashboard-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 20px;
}

.traffic-light {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 6px;
}
.traffic-light span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #e2e8f0;
}
.traffic-light span:nth-child(1) {
  background-color: #ef4444;
}
.traffic-light span:nth-child(2) {
  background-color: #f59e0b;
}
.traffic-light span:nth-child(3) {
  background-color: #10b981;
}

.dashboard-title {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text-muted);
}

.chart-container {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 0 10px;
  margin-bottom: 20px;
}

.chart-bars {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 0 10px;
  opacity: 0.1;
  z-index: 0;
}

.bar {
  width: 8px;
  background-color: var(--color-primary);
  border-radius: 4px 4px 0 0;
}

.chart-line {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  overflow: visible;
}

.dashboard-stats {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-top: 15px;
  border-top: 1px solid var(--color-border);
}

.stat-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.stat-label {
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

.stat-value {
  font-size: 1.1rem;
  font-weight: 700;
}

.text-green {
  color: #10b981;
}

/* Floating Elements */
.visual-card {
  position: absolute;
  background: var(--color-white);
  border-radius: var(--radius-md);
  -webkit-box-shadow: var(--shadow-lg);
          box-shadow: var(--shadow-lg);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  -webkit-animation: float 6s ease-in-out infinite;
          animation: float 6s ease-in-out infinite;
  padding: 12px 16px;
  border: 1px solid rgba(255, 255, 255, 0.5);
}
.visual-card--2 {
  right: 20px;
  top: 60px;
  z-index: 3;
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}
.visual-card--2 .icon-box {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: #ecfdf5;
  color: #10b981;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 20px;
}
.visual-card--3 {
  left: 30px;
  bottom: 80px;
  z-index: 3;
  -webkit-animation-delay: 3s;
          animation-delay: 3s;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding: 16px;
  width: 160px;
  opacity: 0.9;
}
.visual-card--3 .top-icon {
  position: absolute;
  top: -10px;
  right: -10px;
  font-size: 24px;
  background: white;
  border-radius: 50%;
}

.text-xs {
  font-size: 0.75rem;
}

.font-bold {
  font-weight: 700;
}

.d-block {
  display: block;
}

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

.user-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  width: 100%;
}

.avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: #e2e8f0;
}

.user-lines {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 6px;
}

.line {
  height: 6px;
  background-color: #f1f5f9;
  border-radius: 3px;
}

.w-80 {
  width: 80%;
}

.w-50 {
  width: 50%;
}

@-webkit-keyframes float {
  0% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
  50% {
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  100% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}

@keyframes float {
  0% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
  50% {
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  100% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
/* --- Features --- */
.features {
  position: relative;
  background-color: #f8fafc;
  background-image: radial-gradient(#e2e8f0 1.5px, transparent 1.5px);
  background-size: 24px 24px;
}

.feature-card__title {
  font-size: 1.25rem;
  margin-bottom: 12px;
  font-weight: 600;
}
.feature-card__text {
  color: var(--color-text-muted);
  font-size: 0.95rem;
}

/* --- Audience --- */
.audience__description {
  color: var(--color-text-muted);
  font-size: 1.1rem;
  margin-bottom: 32px;
}
.audience__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

/* --- Benefits --- */
.benefit-card {
  background-color: var(--color-white);
  border-radius: var(--radius-md);
  -webkit-box-shadow: var(--shadow-sm);
          box-shadow: var(--shadow-sm);
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
}
.benefit-card:hover {
  -webkit-transform: translateY(-4px);
      -ms-transform: translateY(-4px);
          transform: translateY(-4px);
}
.benefit-card__icon-wrap {
  width: 60px;
  height: 60px;
  margin: 0 auto 20px;
  background-color: var(--color-bg-alt);
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 28px;
  color: var(--color-primary);
}
.benefit-card__title {
  font-size: 1.1rem;
  margin-bottom: 8px;
}
.benefit-card__text {
  font-size: 0.9rem;
  color: var(--color-text-muted);
}

/*
*  END FRONT PAGE
*/
/*
*  SINGLE PRODUCT PAGE
*/
.product-cover-placeholder {
  width: 100%;
  aspect-ratio: 1/1.414;
  background: linear-gradient(135deg, #8B5CF6 0%, #ddd6fe 100%);
  border-radius: var(--radius-lg);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-shadow: var(--shadow-lg);
          box-shadow: var(--shadow-lg);
}
.product-cover-placeholder i {
  font-size: 180px;
  color: #E5E7EB;
}

.product-cover {
  border: 1px solid var(--color-border);
}

.additional-services strong {
  color: #4B5563;
}

.pricing-card {
  -webkit-transition: -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  transition: transform 0.3s ease, box-shadow 0.3s ease, -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  border: 1px solid var(--color-border);
}
.pricing-card:hover {
  -webkit-transform: translateY(-8px);
      -ms-transform: translateY(-8px);
          transform: translateY(-8px);
  -webkit-box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1);
          box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1);
  border-color: var(--color-primary-light);
}
.pricing-card--popular {
  border: 2px solid var(--color-primary);
  -webkit-box-shadow: 0 8px 24px rgba(124, 58, 237, 0.15);
          box-shadow: 0 8px 24px rgba(124, 58, 237, 0.15);
}
.pricing-card--popular:hover {
  -webkit-box-shadow: 0 16px 32px rgba(124, 58, 237, 0.2);
          box-shadow: 0 16px 32px rgba(124, 58, 237, 0.2);
}

.price {
  font-weight: 700;
  color: var(--color-text);
}
.price .currency {
  font-size: 1.5rem;
  vertical-align: top;
}
.price .amount {
  font-size: 3rem;
  line-height: 1;
}
.price .period {
  font-size: 1rem;
  color: var(--color-text-muted);
  font-weight: 400;
}

/*
*  END SINGLE PRODUCT PAGE
*/
/*
*  CATALOG PAGE
*/
/* --- Catalog Filters --- */
.btn-filter {
  background-color: transparent;
  color: #8B5CF6;
  border: 1px solid #8B5CF6;
  font-weight: 500;
}
.btn-filter:hover {
  background-color: #ddd6fe;
  color: #8B5CF6;
  border-color: #8B5CF6;
}
.btn-filter.active, .btn-filter:active {
  background-color: #8B5CF6;
  color: #ffffff;
  border-color: #8B5CF6;
}

/* --- Catalog & Product Cards --- */
.product-card {
  -webkit-transition: -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  transition: transform 0.3s ease, box-shadow 0.3s ease, -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  border: 1px solid var(--color-border) !important;
}
.product-card:hover {
  -webkit-transform: translateY(-8px);
      -ms-transform: translateY(-8px);
          transform: translateY(-8px);
  -webkit-box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1) !important;
          box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1) !important;
  border-color: var(--color-primary-light) !important;
}

.card-img-top {
  background: var(--color-bg-alt);
  height: 595px;
  overflow: hidden;
  padding: 0;
}
.card-img-top img,
.card-img-top i {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.card-img-top i {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #f1f5f9;
  font-size: 80px;
}

.transition-delay-100 {
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}

.transition-delay-200 {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

/* --- Pagination Customization --- */
.pagination .page-item {
  margin: 0 4px;
}
.pagination .page-item.active .page-link {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}
.pagination .page-item.disabled .page-link {
  color: var(--color-text-light);
  background-color: transparent;
  border-color: var(--color-border);
}
.pagination .page-link {
  border-radius: var(--radius-md);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  padding: 8px 16px;
  font-weight: 500;
}
.pagination .page-link:hover:not(.active) {
  background-color: var(--color-primary-light);
  color: var(--color-primary-dark);
  border-color: var(--color-primary-light);
}
.pagination .page-link:focus {
  -webkit-box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.25);
          box-shadow: 0 0 0 0.2rem rgba(124, 58, 237, 0.25);
}

/*
*  END CATALOG PAGE
*/
/*
*  CONTACTS PAGE
*/
.contacts-main {
  padding-bottom: 60px;
}
.contacts-main .contacts-list {
  margin-bottom: 80px;
  padding-left: 60px;
}
.contacts-main .contacts-list .item {
  margin-bottom: 12px;
}
.contacts-main .contacts-list .item a {
  border-bottom: 0 !important;
}
.contacts-main .contacts-list .item .js-popup-cf {
  cursor: pointer;
  -webkit-transition: 0.4s color ease;
  transition: 0.4s color ease;
}
.contacts-main .contacts-list .item .js-popup-cf:hover {
  color: #697888;
}

/*
*  PROFILE PAGE
*/
.contact-info-title {
  font-weight: 600;
  color: #4B5563;
  margin-bottom: 1rem;
}
.contact-info-title i {
  font-weight: 500;
  color: #8B5CF6;
}
.contact-info .contact-item {
  margin-bottom: 1rem;
}
.contact-info .contact-label {
  font-size: 0.85rem;
  color: #4B5563;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.contact-info .contact-value {
  font-size: 1.1rem;
  color: #8B5CF6;
  font-weight: 500;
  text-decoration: none;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
.contact-info .contact-value:hover {
  color: #A78BFA;
}

/*
*  MEDIA QUERIES START
*/
@media (max-width: 992px) {
  .featureBox {
    text-align: center;
  }
  .featureBox .image {
    margin-bottom: 8px;
  }
  .featureBox .description {
    max-width: 340px;
    margin: 0 auto;
  }
}
@media (max-width: 576px) {
  .featureBox {
    margin-bottom: 24px;
  }
}