@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: var(--container-padding);
  padding-left: var(--container-padding);
}

@media (min-width: 450px) {
  .container {
    max-width: 640px;
  }
}

@media (min-width: 769px) {
  .container {
    max-width: 768px;
  }
}

@media (min-width: 1025px) {
  .container {
    max-width: 1024px;
  }
}

@media (min-width: 1281px) {
  .container {
    max-width: 1280px;
  }
}

@media (min-width: 1537px) {
  .container {
    max-width: calc(1536px - 2rem);
  }
}

:root {
  --color-primary: #3257ff;
  --color-primary-gradient-start: #3257ff;
  --color-primary-gradient-end: #6814f1;
  --color-primary-hover: #3423e0;
  --color-white: #ffffff;
  --neutral-01: #f8f8f8;
  --neutral-02: #eeeeee;
  --neutral-03: #e7e5e5;
  --neutral-04: #f5f4fe;
  --neutral-05: #dad9e6;
  --neutral-06: #555555;
  --color-black: #000000;
  --color-placeholder: #717072;
  --color-border-light: var(--neutral-02);
  --color-border: #dadada;
  --color-success: #34d399;
  --color-warning: #fbbf24;
  --color-error: #ef4444;
  --color-info: #60a5fa;
  --color-success-hover: #059669;
  --color-warning-hover: #d97706;
  --color-error-hover: #dc2626;
  --color-info-hover: #2563eb;
  --space-16: 1.6rem;
  --space-32: 3.2rem;
  --spacing-page: 1.6rem;
  --sidebar-spacing: 2.4rem;
  --unified-spacing: 1.2rem;
  --container-padding: var(--space-16);
  --content-width: calc(100% - var(--space-32));
  --text-body: var(--color-black);
  --text-secondary: var(--neutral-06);
  --gradient-primary: linear-gradient(90deg,
      var(--color-primary-gradient-start) 0%,
      var(--color-primary-gradient-end) 100%);
  --gradient-primary-hover: linear-gradient(90.58deg,
      color-mix(in srgb, var(--color-primary-gradient-start) 90%, black) 0%,
      color-mix(in srgb, var(--color-primary-gradient-end) 90%, black) 100%);
  --radius-xs: 0.4rem;
  --radius-sm: 0.8rem;
  --radius-md: 1.2rem;
  --radius-lg: 1.8rem;
  --radius-xl: 2.4rem;
  --radius-xxl: 3.2rem;
  --radius-full: 100px;
  --depth-0: none;
  --depth-1: 0 0.2rem 0.3rem rgba(0, 0, 0, 0.1);
  --depth-2: 0 0.4rem 0.6rem rgba(0, 0, 0, 0.1);
  --depth-3: 0 0.6rem 1.2rem rgba(0, 0, 0, 0.1);
  --depth-4: 0 1.2rem 2.4rem rgba(0, 0, 0, 0.1);
  --depth-5: 0 2.4rem 4.8rem rgba(0, 0, 0, 0.1);
  --path-images: "../img";
  --logo-path: var(--path-images) + "/logo.svg";
  --spacing-page: 1.6rem;
  --transition: 0.2s;
}

@media (min-width: 1281px) {
  :root {
    --unified-spacing: 2.4rem;
  }
}

[data-theme=dark] {
  --color-white: #1C1F23;
  --neutral-01: #18181b;
  --neutral-02: #25282d;
  --neutral-03: #2f3238;
  --neutral-04: #18181b;
  --neutral-05: #3b3c42;
  --neutral-06: #e1e1e1;
  --color-black: #f5f5f5;
  --color-placeholder: #aaaaac;
  --color-border-light: #2c2c30;
  --color-border: #18181b;
  --color-success: #2ebd8e;
  --color-warning: #f0a732;
  --color-error: #e05252;
  --color-info: #457efa;
  --text-body: #ffffff;
  --text-secondary: #8e8e93;
  --depth-1: 0px 2px 3px rgba(0, 0, 0, 0.2);
  --depth-2: 0px 4px 6px rgba(0, 0, 0, 0.2);
  --depth-3: 0px 6px 12px rgba(0, 0, 0, 0.2);
  --depth-4: 0px 12px 24px rgba(0, 0, 0, 0.2);
  --depth-5: 0px 24px 48px rgba(0, 0, 0, 0.2);
}

/* Reset */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
  touch-action: manipulation;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  touch-action: manipulation;
  color: var(--text-body);
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

img {
  user-drag: none;
  /* Safari */
  -webkit-user-drag: none;
  /* Chrome, Safari */
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  /* Prevents text selection drag */
}

input,
button,
textarea,
select {
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

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

/* Button Reset */
button {
  display: flex;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  align-items: center;
  justify-content: center;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  text-align: inherit;
  font: inherit;
  color: inherit;
  cursor: pointer;
  outline: none;
}

button:focus {
  outline: none;
}

button:disabled {
  cursor: not-allowed;
}

/* Additional reset for button within a form to prevent iOS Safari styling */
[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

span {
  display: inline-block;
}

ul {
  list-style: none;
}

:root {
  --font-primary: "Inter", sans-serif;
  --font-size-h1: 5.6rem;
  --font-size-h2: 2.1rem;
  --font-size-h3: 1.8rem;
  --font-size-h4: 1.5rem;
  --font-size-h5: 1.4rem;
  --font-size-h6: 1.3rem;
  --font-size-p: 1.4rem;
  --font-size-xs: 1.2rem;
  --font-size-sm: 1.3rem;
  --font-size-base: 1.4rem;
  --font-size-md: 1.5rem;
  --font-size-lg: 1.6rem;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --line-height-tight: 1.2;
  --line-height-base: 1.5;
  --line-height-relaxed: 1.75;
}

body {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  font-weight: var(--font-weight-regular);
  font-feature-settings: "cv02", "cv03", "cv04", "cv11";
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
  color: var(--color-black);
}

p {
  color: var(--text-secondary);
  line-height: var(--line-height-relaxed);
}

h1,
.h1 {
  font-size: var(--font-size-h1);
  line-height: var(--line-height-tight);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.02em;
}

h2,
.h2 {
  font-size: var(--font-size-h2);
  line-height: var(--line-height-tight);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.015em;
}

h3,
.h3 {
  font-size: var(--font-size-h3);
  line-height: var(--line-height-tight);
  font-weight: var(--font-weight-semibold);
  letter-spacing: -0.012em;
}

h4,
.h4 {
  font-size: var(--font-size-h4);
  line-height: var(--line-height-base);
  font-weight: var(--font-weight-semibold);
}

h5,
.h5 {
  font-size: var(--font-size-h5);
  line-height: var(--line-height-base);
  font-weight: var(--font-weight-medium);
}

h6,
.h6 {
  font-size: var(--font-size-h6);
  line-height: var(--line-height-base);
  font-weight: var(--font-weight-medium);
}

p {
  font-size: var(--font-size-p);
  margin-bottom: 1em;
}

p:last-child {
  margin-bottom: 0;
}

.text-xs {
  font-size: var(--font-size-xs);
}

.text-sm {
  font-size: var(--font-size-sm);
}

.text-base {
  font-size: var(--font-size-base);
}

.text-md {
  font-size: var(--font-size-md);
}

.text-lg {
  font-size: var(--font-size-lg);
}

.font-regular {
  font-weight: var(--font-weight-regular);
}

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

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

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

.text-light {
  letter-spacing: -0.01em;
  font-weight: 300;
}

.text-regular {
  letter-spacing: -0.011em;
  font-weight: 400;
}

.text-medium {
  letter-spacing: -0.0125em;
  font-weight: 500;
}

.text-semibold {
  letter-spacing: -0.015em;
  font-weight: 600;
}

.text-bold {
  letter-spacing: -0.018em;
  font-weight: 700;
}

p,
.body-text {
  letter-spacing: -0.011em;
}

small,
.text-small {
  letter-spacing: -0.008em;
  font-size: var(--font-size-sm);
}


/*--------------------------------

decor-ai icon font
Generated using nucleoapp.com

-------------------------------- */
@font-face {
  font-family: "decor-ai";
  src: url("../fonts/decor-ai.eot");
  src: url("../fonts/decor-ai.eot") format("embedded-opentype"), url("../fonts/decor-ai.woff2") format("woff2"), url("../fonts/decor-ai.woff") format("woff"), url("../fonts/decor-ai.ttf") format("truetype"), url("../fonts/decor-ai.svg") format("svg");
}

/* base class */
.icon {
  display: inline-block;
  font: normal normal normal 1em/1 "decor-ai";
  color: inherit;
  flex-shrink: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* size examples - relative units */
.icon-sm {
  font-size: 0.8em;
}

.icon-lg {
  font-size: 1.2em;
}

/* size examples - absolute units */
.icon-16 {
  font-size: 16px;
}

.icon-32 {
  font-size: 32px;
}

/* rotate the icon infinitely */
.icon-is-spinning {
  animation: icon-spin 1s infinite linear;
}

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

  100% {
    transform: rotate(360deg);
  }
}

/* transform */
.icon-rotate-90 {
  transform: rotate(90deg);
}

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

.icon-rotate-270 {
  transform: rotate(270deg);
}

.icon-flip-y {
  transform: scaleY(-1);
}

.icon-flip-x {
  transform: scaleX(-1);
}

/* icons */
.icon-artboard-2::before {
  content: "\ea04";
}

.icon-artboard-1::before {
  content: "\ea05";
}

.icon-settings-gear-2::before {
  content: "\ea06";
}

.icon-settings-gear-1::before {
  content: "\ea07";
}

.icon-house-2::before {
  content: "\ea08";
}

.icon-house-1::before {
  content: "\ea09";
}

.icon-settings-2::before {
  content: "\ea0a";
}

.icon-settings-1::before {
  content: "\ea0b";
}

.icon-bulb-63-2::before {
  content: "\ea0c";
}

.icon-bulb-63-1::before {
  content: "\ea0d";
}

.icon-folder-image-2::before {
  content: "\ea0e";
}

.icon-folder-image-1::before {
  content: "\ea0f";
}

.icon-customer-support-2::before {
  content: "\ea12";
}

.icon-customer-support-1::before {
  content: "\ea13";
}

.icon-sidebar::before {
  content: "\ea14";
}

.icon-zoom::before {
  content: "\ea15";
}

.icon-table::before {
  content: "\ea16";
}

.icon-theater-curtains::before {
  content: "\ea17";
}

.icon-grid-layout::before {
  content: "\ea18";
}

.icon-pencil-47::before {
  content: "\ea19";
}

.icon-watering-plants::before {
  content: "\ea1a";
}

.icon-land::before {
  content: "\ea1b";
}

.icon-single-bed::before {
  content: "\ea1c";
}

.icon-ai-generated-img::before {
  content: "\ea1d";
}

.icon-paint-brush::before {
  content: "\ea1e";
}

.icon-eraser-33::before {
  content: "\ea1f";
}

.icon-tablet::before {
  content: "\ea20";
}

.icon-sun-cloud-fog::before {
  content: "\ea21";
}

.icon-floor::before {
  content: "\ea22";
}

.icon-paint-16::before {
  content: "\ea23";
}

.icon-clear-data::before {
  content: "\ea24";
}

.icon-link-6::before {
  content: "\ea26";
}

.icon-upload-4::before {
  content: "\ea27";
}

.icon-wand-sparkle::before {
  content: "\ea29";
}

.icon-chevron-down::before {
  content: "\ea2a";
}

.icon-sofa::before {
  content: "\ea2b";
}

.icon-sparkle-3::before {
  content: "\ea2c";
}

.icon-download-4::before {
  content: "\ea2d";
}

.icon-edit-polygon::before {
  content: "\ea2f";
}

.icon-paintbrush::before {
  content: "\ea30";
}

.icon-grid-layout-2::before {
  content: "\ea31";
}

.icon-undo::before {
  content: "\ea32";
}

.icon-refresh::before {
  content: "\ea33";
}

.icon-boolean-exclude::before {
  content: "\ea35";
}

.icon-search-zoom-in::before {
  content: "\ea36";
}

.icon-search-zoom-out::before {
  content: "\ea37";
}

.icon-tool-hand::before {
  content: "\ea38";
}

.icon-alert-question::before {
  content: "\ea39";
}

.icon-camera-flashlight::before {
  content: "\ea3a";
}

.icon-down-arrow::before {
  content: "\ea40";
}

.icon-right-arrow::before {
  content: "\ea41";
}

.icon-left-arrow::before {
  content: "\ea42";
}

.icon-up-arrow::before {
  content: "\ea43";
}

.icon-image-sparkle::before {
  content: "\ea44";
}

.icon-clone-3::before {
  content: "\ea46";
}

.icon-flip-horizontal::before {
  content: "\ea47";
}

.icon-flip-vertical::before {
  content: "\ea48";
}

.icon-transparent::before {
  content: "\ea49";
}

.icon-rotate-image-anticlockwise::before {
  content: "\ea4a";
}

.icon-trash::before {
  content: "\ea4b";
}

.icon-rotation-360::before {
  content: "\ea4c";
}

.icon-focus-2::before {
  content: "\ea4d";
}

.icon-input-search::before {
  content: "\ea4e";
}

.icon-plus::before {
  content: "\ea4f";
}

.icon-i-add::before {
  content: "\ea50";
}

.icon-camera::before {
  content: "\ea51";
}

.icon-video-play::before {
  content: "\ea53";
}

.icon-circle-question::before {
  content: "\ea55";
}

.icon-coins-plus::before {
  content: "\ea56";
}

.icon-hearts-suit-2::before {
  content: "\ea57";
}

.icon-hearts-suit-1::before {
  content: "\ea58";
}

.icon-crown::before {
  content: "\ea59";
}

.icon-house-search::before {
  content: "\ea5a";
}

.icon-file-replace::before {
  content: "\ea5b";
}

.icon-expand::before {
  content: "\ea5c";
}

.icon-texture::before {
  content: "\ea5d";
}

.icon-scale-from-bottom-left::before {
  content: "\ea5e";
}

.icon-text-prompt::before {
  content: "\ea60";
}

.icon-xmark::before {
  content: "\ea61";
}

.icon-wand-sparkle-1::before {
  content: "\ea62";
}

.icon-a-tag-add::before {
  content: "\ea63";
}

.icon-folder-history::before {
  content: "\ea64";
}

.icon-image::before {
  content: "\ea65";
}

.icon-image-fill::before {
  content: "\ea66";
}

.icon-compose-4::before {
  content: "\ea67";
}

.icon-reload::before {
  content: "\ea68";
}

.icon-pin-tack::before {
  content: "\ea69";
}

.icon-sparkle::before {
  content: "\ea6a";
}

.icon-magnifier::before {
  content: "\ea6b";
}

.icon-discord::before {
  content: "\ea6c";
}

.icon-subtitles::before {
  content: "\ea6d";
}

.icon-api::before {
  content: "\ea6e";
}

.icon-open-rect-arrow-out::before {
  content: "\ea6f";
}

.icon-gift::before {
  content: "\ea70";
}

.icon-sun::before {
  content: "\ea71";
}

.icon-moon::before {
  content: "\ea72";
}

.icon-laptop-2::before {
  content: "\ea74";
}

.icon-youtube::before {
  content: "\ea75";
}

.icon-tiktok::before {
  content: "\ea76";
}

.icon-logo-pinterest::before {
  content: "\ea77";
}

.icon-logo-instagram::before {
  content: "\ea78";
}

.icon-logo-x::before {
  content: "\ea79";
}

.icon-copies::before {
  content: "\ea7a";
}

.icon-bars-filter::before {
  content: "\ea7b";
}

.icon-dots::before {
  content: "\ea7c";
}

.icon-circle-check-2::before {
  content: "\ea7d";
}

.icon-circle-check-1::before {
  content: "\ea7e";
}

.icon-box-archive::before {
  content: "\ea7f";
}

@font-face {
  font-family: "icons";
  src: url("../fonts/decor-ai.eot");
  src: url("../fonts/decor-ai.eot?#iefix") format("embedded-opentype"), url("../fonts/decor-ai.woff2") format("woff2"), url("../fonts/decor-ai.woff") format("woff"), url("../fonts/decor-ai.ttf") format("truetype"), url("../fonts/decor-ai.svg#icons") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

[class^=icon-],
[class*=" icon-"] {
  font-family: "icons" !important;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon--sm {
  font-size: 1rem;
}

.icon--md {
  font-size: 1.5rem;
}

.icon--lg {
  font-size: 2rem;
}

.icon--xl {
  font-size: 3rem;
}

.container {
  width: 100%;
  max-width: var(--content-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

.m-0 {
  margin: 0rem !important;
}

.mt-0 {
  margin-top: 0rem !important;
}

.mb-0 {
  margin-bottom: 0rem !important;
}

.p-0 {
  padding: 0rem !important;
}

.m-4 {
  margin: 0.4rem !important;
}

.mt-4 {
  margin-top: 0.4rem !important;
}

.mb-4 {
  margin-bottom: 0.4rem !important;
}

.p-4 {
  padding: 0.4rem !important;
}

.m-6 {
  margin: 0.6rem !important;
}

.mt-6 {
  margin-top: 0.6rem !important;
}

.mb-6 {
  margin-bottom: 0.6rem !important;
}

.p-6 {
  padding: 0.6rem !important;
}

.m-8 {
  margin: 0.8rem !important;
}

.mt-8 {
  margin-top: 0.8rem !important;
}

.mb-8 {
  margin-bottom: 0.8rem !important;
}

.p-8 {
  padding: 0.8rem !important;
}

.m-10 {
  margin: 1rem !important;
}

.mt-10 {
  margin-top: 1rem !important;
}

.mb-10 {
  margin-bottom: 1rem !important;
}

.p-10 {
  padding: 1rem !important;
}

.m-12 {
  margin: 1.2rem !important;
}

.mt-12 {
  margin-top: 1.2rem !important;
}

.mb-12 {
  margin-bottom: 1.2rem !important;
}

.p-12 {
  padding: 1.2rem !important;
}

.m-16 {
  margin: 1.6rem !important;
}

.mt-16 {
  margin-top: 1.6rem !important;
}

.mb-16 {
  margin-bottom: 1.6rem !important;
}

.p-16 {
  padding: 1.6rem !important;
}

.m-20 {
  margin: 2rem !important;
}

.mt-20 {
  margin-top: 2rem !important;
}

.mb-20 {
  margin-bottom: 2rem !important;
}

.p-20 {
  padding: 2rem !important;
}

.m-24 {
  margin: 2.4rem !important;
}

.mt-24 {
  margin-top: 2.4rem !important;
}

.mb-24 {
  margin-bottom: 2.4rem !important;
}

.p-24 {
  padding: 2.4rem !important;
}

.m-32 {
  margin: 3.2rem !important;
}

.mt-32 {
  margin-top: 3.2rem !important;
}

.mb-32 {
  margin-bottom: 3.2rem !important;
}

.p-32 {
  padding: 3.2rem !important;
}

.m-36 {
  margin: 3.6rem !important;
}

.mt-36 {
  margin-top: 3.6rem !important;
}

.mb-36 {
  margin-bottom: 3.6rem !important;
}

.p-36 {
  padding: 3.6rem !important;
}

.position-sticky {
  height: calc(100vh - 100px);
  position: relative;
  overflow: auto;
  scrollbar-width: none;
  /* Firefox */
  -ms-overflow-style: none;
  /* IE 10+ */
}

.position-sticky::-webkit-scrollbar {
  display: none;
  /* Chrome, Safari */
}

@media (max-width: 768px) {
  .page-deshboard .position-sticky {
    overflow: inherit;
  }
}

.sticky-top {
  position: sticky;
  top: 0;
  z-index: 3;
  background: var(--neutral-01);
}

.no-scroll {
  overflow: hidden;
}

.overlay {
  content: "";
  position: fixed;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 98;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
}

.overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.close-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 1.9rem;
  opacity: 0.5;
  z-index: 99;
  padding: 0 1rem 1rem 1rem;
}

@media (min-width: 1025px) {
  .close-btn {
    font-size: 2.2rem;
  }
}

.close-btn--regular {
  position: relative;
  top: 0;
  right: 0;
  z-index: 1;
  padding: 0.1rem;
}

.tooltip {
  position: absolute;
  background: #ffffff;
  color: #000;
  padding: 0.4rem 0.6rem;
  font-size: 1.2rem;
  white-space: nowrap;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

/* Show tooltip */
.tooltip.visible {
  opacity: 1;
}

/* Arrow base */
.tooltip::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  background: inherit;
  transform: rotate(45deg);
  z-index: -1;
}

/* Arrow directions */
.tooltip[data-pos*=top]::after {
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
}

.tooltip[data-pos*=bottom]::after {
  top: -5px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
}

.tooltip[data-pos*=left]::after {
  right: -5px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.tooltip[data-pos*=right]::after {
  left: -5px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
  transition: var(--transition);
  cursor: pointer;
  gap: 0.5rem;
}

.button--icon {
  gap: 0.8rem;
}

@media (min-width: 1537px) {
  .button--icon {
    gap: 1rem;
  }
}

.button .icon {
  position: relative;
  top: 0.5px;
}

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

.button--md {
  gap: 0.8rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  border-radius: 12px;
  padding: 1rem 1.4rem;
}

@media (min-width: 769px) {
  .button--md {
    padding: 1.45rem 2rem;
    gap: 1rem;
  }
}

.button--md .icon {
  font-size: calc(var(--font-size-sm) + 0.2rem);
}

.button--lg {
  padding: 16px 21px;
  gap: 10px;
  font-size: 1.6rem;
  font-weight: var(--font-weight-semibold);
  border-radius: 12px;
}

.button--lg .icon {
  font-size: calc(var(--font-size-sm) + 0.6rem);
}

.button--primary {
  background: var(--gradient-primary);
  color: white;
}

.button--primary:hover {
  background: var(--gradient-primary-hover);
}

.button--dark {
  background: var(--color-black);
  color: #ffffff;
}

.button--dark:hover {
  background: var(--color-primary);
}

.button--gray {
  background: var(--neutral-03);
  color: var(--color-black);
}

.button--gray:hover {
  background: var(--color-primary);
  color: var(--neutral-01);
}

.button--light-outline {
  background-color: var(--color-white);
  color: var(--color-black);
  box-shadow: 0 0 0 1px var(--color-border-light);
}

.button--light-outline:hover {
  background-color: var(--neutral-02);
}

.button--danger {
  background-color: var(--color-error);
  color: white;
}

.button--disabled {
  font-weight: 400;
  opacity: 1;
  cursor: not-allowed;
  pointer-events: none;
  color: var(--neutral-06);
  background-color: var(--neutral-03);
}

.button--disabled.is-active {
  background: var(--color-black);
  color: white;
  font-weight: 600;
  cursor: pointer;
  pointer-events: initial;
}

.button--full {
  width: 100%;
}

.button--group {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.form-control {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  border: 1px solid var(--color-border-light);
  background-color: var(--color-white);
  border-radius: 12px;
  width: 100%;
  transition: var(--transition);
  font-size: 16px;
  font-weight: var(--font-weight-regular);
  padding: 16px;
  color: var(--color-black);
  display: flex;
  align-items: center;
}

.form-control:focus {
  border-color: var(--neutral-05);
  box-shadow: 0 0 0 1px var(--neutral-05);
}

.form-control::-moz-placeholder {
  color: var(--color-placeholder);
  font-size: 1.4rem;
  font-weight: 400;
}

.form-control::placeholder {
  color: var(--color-placeholder);
  font-size: 1.4rem;
  font-weight: 400;
}

.form-control:disabled {
  background-color: var(--neutral-01);
  cursor: not-allowed;
}

.form-control.is-invalid {
  border-color: var(--color-error);
}

.form-control.is-invalid:focus {
  box-shadow: 0 0 0 1px var(--color-error);
}

.input-group {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.input-group .form-control--with-icon {
  padding-right: 48px;
}

.input-group__icon {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  color: var(--text-secondary);
  pointer-events: none;
}

select.form-control {
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23555555' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 48px;
}

select.form-control::-ms-expand {
  display: none;
}

textarea {
  min-height: 10.3rem;
  resize: vertical;
}

textarea::-moz-placeholder {
  color: var(--color-placeholder);
}

textarea::placeholder {
  color: var(--color-placeholder);
}

.input-search {
  margin-bottom: 1.2rem;
  position: relative;
}

.input-search input {
  height: auto;
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 3.5rem;
  font-weight: 500;
}

.input-search .icon {
  position: absolute;
  font-size: 2rem;
  color: var(--color-placeholder);
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
}

.dropdown {
  position: relative;
}

.dropdown ul {
  list-style: none;
}

.dropdown .dropdown__toggle:not(.dropdown-user-nav__toggle) {
  padding: 1.2rem 1.4rem;
  font-size: 1.4rem;
  background: var(--color-white);
  width: 100%;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-light);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
}

.dropdown .dropdown__toggle:not(.dropdown-user-nav__toggle) .icon {
  transition: var(--transition);
}

.dropdown__menu {
  position: absolute;
  top: calc(100% + 0.2rem);
  left: 0;
  right: 0;
  z-index: 10;
  padding: 1.2rem;
  overflow-y: auto;
  transition: var(--transition);
  box-shadow: var(--depth-1);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  background: var(--color-white);
  overscroll-behavior-x: contain;
  max-height: 309px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-2px) scale(0.95);
}

.dropdown.dropdown--up .dropdown__menu {
  top: auto;
  bottom: calc(100% + 0.2rem);
}

.dropdown__menu--icon .dropdown__item,
.dropdown__menu--icon .dropdown__item--nav {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.dropdown.is-active .dropdown__menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px) scale(1);
}

.dropdown.is-active .icon-chevron-down {
  transform: rotate(180deg);
}

.dropdown.is-active.dropdown--up .icon-chevron-down {
  transform: rotate(0deg);
}

.dropdown__item,
.dropdown__item--nav {
  cursor: pointer;
  padding: 1rem 1.2rem;
  margin-top: 0.2rem;
  margin-bottom: 0.2rem;
  transition: var(--transition);
  border-radius: var(--radius-sm);
}

.dropdown__item:hover:not(.dropdown__item--active),
.dropdown__item--nav:hover:not(.dropdown__item--active) {
  background: var(--neutral-01);
}

.dropdown__item--active,
.dropdown__item--nav--active {
  background: var(--color-primary);
  color: white;
}

.dropdown .dropdown__clear-all {
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
}

.dropdown.has-selections .dropdown__toggle {
  padding: 1rem 0.6rem;
}

.dropdown.has-selections .dropdown__clear-all {
  opacity: 0.5;
  visibility: visible;
}

.dropdown.has-selections .dropdown__clear-all:hover {
  opacity: 1;
}

.dropdown[data-multi-select] {
  display: flex;
}

.dropdown[data-multi-select] .dropdown__label {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0.2rem;
}

.dropdown[data-multi-select] .dropdown__item,
.dropdown[data-multi-select] .dropdown__item--nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.dropdown[data-multi-select] .dropdown__item--active:after {
  content: "\ea61";
  float: right;
  font-family: icons;
}

.dropdown .selection-tag {
  display: flex;
  align-items: center;
  background: var(--color-primary);
  color: white;
  padding: 0.2rem 0.8rem;
  border-radius: var(--radius-sm);
}

.dropdown .selection-tag .icon {
  border-left: 1px solid white;
  padding-left: 0.46rem;
  margin-left: 0.6rem;
  color: white;
  font-size: 1.2rem;
  opacity: 0.8;
  transition: var(--transition);
}

.dropdown .selection-tag .icon:hover {
  opacity: 1;
}

.dropdown [data-selectable-content] {
  display: none;
}

.dropdown [data-selectable-content].is-visible {
  display: block;
}

.dropdown__menu--portal {
  left: auto;
  right: 0;
  top: 0;
  will-change: top, left, width;
  visibility: visible;
  opacity: 1;
  transition: opacity 0.3s, visibility 0.3s;
  min-width: 250px;
  width: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
}

.dropdown-user-nav .dropdown__menu {
  max-height: inherit;
  box-shadow: var(--depth-4);
}

.dropdown-user-nav__toggle {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.dropdown-user-nav-info {
  display: flex;
  flex-direction: column;
}

.dropdown-user-nav__name {
  font-weight: 500;
}

.dropdown-user-nav__email {
  font-size: 1.2rem;
  color: var(--neutral-06);
}

.dropdown-user-nav .appearance-switcher {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--neutral-02);
  border-radius: 0.9rem;
  padding: 0.4rem;
  box-shadow: rgba(9, 9, 11, 0.05) 0px 2px 4px 0px inset;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.dropdown-user-nav .appearance-switcher button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.8rem 1rem;
  border-radius: 0.5rem;
  flex: 1;
  transition: var(--transition);
}

.dropdown-user-nav .appearance-switcher button.is-active {
  background: var(--color-white);
}

.dropdown-user-nav .appearance-switcher button:hover {
  background: var(--neutral-03);
}

.dropdown-user-nav .social {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.3rem;
  flex-wrap: wrap;
}

.dropdown-user-nav .social a {
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--neutral-02);
  padding: 1rem;
  border-radius: var(--radius-sm);
  transition: var(--transition);
  font-size: 1.6rem;
}

.dropdown-user-nav .social a:hover {
  background: var(--color-primary);
  color: white;
}

.sidebar--large .dropdown-user-nav .dropdown__menu-top {
  display: none;
}

@media (max-width: 768px) {
  .sidebar--large .dropdown-user-nav .dropdown__menu-top {
    display: block;
  }
}

.dropdown-user-nav__avatar {
  height: 36px;
  width: 36px;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: var(--radius-full);
}

.header .dropdown-user-nav-info:not(.dropdown__menu-top .dropdown-user-nav-info) {
  display: none;
}

.header .dropdown-user-nav .dropdown__menu {
  min-width: 270px;
  right: 0;
  margin-top: 0.8rem;
  left: auto;
}

.header .dropdown--filter {
  min-width: 28rem;
}

.header .dropdown--filter .dropdown__item {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.header .dropdown--filter .dropdown__menu {
  max-height: 50rem;
}

.header .dropdown__menu-top {
  padding-top: 0.8rem;
  padding-bottom: 1.2rem;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-border-light);
}

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

.tab {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 1.2rem;
  padding: 0.3rem;
  background: var(--neutral-01);
  border-radius: var(--radius-md);
  flex-wrap: wrap;
}

@media (min-width: 769px) {
  .tab {
    gap: 0.6rem;
  }
}

@media (min-width: 1537px) {
  .tab {
    gap: 0.8rem;
  }
}

.tab button {
  display: flex;
  justify-content: center;
  align-items: center;
  flex: 1;
  border-radius: 10px;
  font-weight: 500;
  transition: var(--transition);
  text-align: center;
  color: var(--text-secondary);
  padding: 1rem 0.8rem;
  font-size: 1.2rem;
}

@media (min-width: 769px) {
  .tab button {
    border-radius: var(--radius-md);
    font-size: 1.4rem;
    padding: 0.8rem 1rem;
  }
}

@media (min-width: 769px) and (max-width: 1280px) {
  .tab button {
    font-size: 1.4rem;
    padding: 0.8rem 1rem;
  }
}

.tab button.is-active {
  background: var(--color-primary);
  box-shadow: var(--depth-1);
  color: #ffffff;
}

.tab button:hover:not(.is-active) {
  background: var(--neutral-03);
  color: var(--text-body);
}

.tab--outer {
  margin-bottom: 1.8rem;
}

@media (max-width: 1024px) {
  .tab--outer {
    gap: 0.6rem;
  }
}

.tab--outer button {
  background: var(--color-white);
  color: var(--text-body);
  box-shadow: inset 0 0 0 1.5px var(--color-border);
  flex: initial;
  padding: 1.4rem 2rem;
}

@media (min-width: 769px) {
  .tab--outer button {
    padding: 1.4rem 1.4rem;
    font-size: 13px;
  }
}

@media (min-width: 1025px) and (max-width: 1280px) {
  .tab--outer button .icon {
    display: none;
  }
}

@media (min-width: 1281px) {
  .tab--outer button {
    padding: 1.4rem 1.5rem;
  }
}

@media (min-width: 1537px) {
  .tab--outer button {
    padding: 1.4rem 2rem;
  }
}

.tab--outer button .icon {
  font-size: 1.6rem;
}

.tab-group {
  display: none;
}

.tab-group.is-active {
  display: block;
}

/*----------------------------------
    Base Style
-----------------------------------*/
.sidebar {
  --sidebar-width: 38rem;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  /*----------------------------------
      Sidebar Large/ navigation Menu main and Mobile
  -----------------------------------*/
}

@media (min-width: 769px) {
  .sidebar {
    --sidebar-width: 40rem;
  }
}

@media (min-width: 1025px) {
  .sidebar {
    --sidebar-width: 36rem;
  }
}

@media (min-width: 1281px) {
  .sidebar {
    --sidebar-width: 42rem;
  }
}

@media (min-width: 1537px) {
  .sidebar {
    --sidebar-width: 46rem;
  }
}

.sidebar--tool {
  padding: 1.4rem;
}

.sidebar--small {
  max-width: var(--sidebar-sm-width);
}

@media (min-width: 769px) {
  .sidebar--small {
    --sidebar-sm-width: 8rem;
  }
}

@media (max-width: 768px) {
  .sidebar--small {
    height: auto;
    background: transparent;
    border: none;
    padding: 0;
  }
}

.sidebar--small .sidebar__menu {
  list-style: none;
  display: flex;
  gap: 0.5rem;
}

@media (min-width: 769px) {
  .sidebar--small .sidebar__menu {
    gap: 1.3rem;
    flex-direction: column;
  }
}

.sidebar--small .sidebar__link {
  display: flex;
  text-align: center;
  gap: 0.6rem;
}

@media (max-width: 768px) {
  .sidebar--small .sidebar__link {
    text-align: left;
    background: white;
    border: 1px solid #ddd;
    border-radius: 100px;
    padding: 8px 16px;
    align-items: center;
  }
}

@media (min-width: 769px) {
  .sidebar--small .sidebar__link {
    padding-bottom: 1.1rem;
    align-items: center;
    flex-direction: column;
    color: var(--neutral-06);
    border-bottom: 1px dashed var(--color-border);
  }
}

.sidebar--small .sidebar__link:hover,
.sidebar--small .sidebar__link--active {
  color: var(--color-white);
  background: var(--color-black);
}

@media (min-width: 769px) {

  .sidebar--small .sidebar__link:hover,
  .sidebar--small .sidebar__link--active {
    background: var(--color-white);
  }
}

@media (min-width: 769px) {

  .sidebar--small .sidebar__link:hover,
  .sidebar--small .sidebar__link--active {
    color: var(--color-primary);
  }
}

.sidebar--small .sidebar__link:hover .sidebar__icon,
.sidebar--small .sidebar__link--active .sidebar__icon {
  color: var(--color-white);
}

@media (min-width: 769px) {

  .sidebar--small .sidebar__link:hover .sidebar__icon,
  .sidebar--small .sidebar__link--active .sidebar__icon {
    color: var(--color-primary);
  }
}

@media (min-width: 769px) {
  .sidebar--small .sidebar__item:first-child .sidebar__link {
    padding-top: 1.1rem;
  }
}

.sidebar--small .sidebar__item:last-child .sidebar__link {
  border-bottom: 0;
}

.sidebar--small .sidebar__text {
  font-size: 1.1rem;
  line-height: 1.2rem;
  transition: var(--transition);
}

@media (max-width: 768px) {
  .sidebar--small .sidebar__text {
    white-space: nowrap;
  }
}

@media (min-width: 769px) {
  .sidebar--small .sidebar__text {
    line-height: 1.5rem;
  }
}

.sidebar--small .sidebar__icon {
  color: var(--color-black);
  font-size: 1.8rem;
  transition: var(--transition);
}

@media (min-width: 769px) {
  .sidebar--small .sidebar__icon {
    font-size: 2rem;
  }
}

.sidebar--large {
  height: calc(100vh - 18rem);
  padding: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
  /*----------------------------------
  Mobile Menu Style
  -----------------------------------*/
  --mobile-menu-size: 66px;
}

@media (min-width: 769px) {
  .sidebar--large {
    height: calc(100vh - 3.2rem);
  }
}

.sidebar--large .sidebar-top,
.sidebar--large .sidebar-bottom {
  position: sticky;
  background: var(--color-white);
  padding: 2rem;
  z-index: 4;
}

.sidebar--large .sidebar-top {
  top: 0;
  padding-bottom: 1rem;
}

.sidebar--large .sidebar__logo {
  display: inline-block;
}

.sidebar--large .input-search input {
  background: var(--neutral-01);
}

.sidebar--large .sidebar__nav {
  margin-top: 1rem;
  padding: 0 2rem;
  flex: 1;
}

.sidebar--large .sidebar__text {
  font-size: 1.4rem;
  font-weight: 500;
  padding: 1.2rem 0;
}

.sidebar--large .sidebar__icon {
  font-size: 1.6rem;
}

.sidebar--large .sidebar__link {
  display: flex;
  align-items: center;
  gap: 1rem;
  border-radius: var(--radius-sm);
  transition: var(--transition);
}

.sidebar--large .sidebar__link--active {
  background: var(--neutral-04);
  color: var(--color-primary);
  padding: 0 1rem;
}

.sidebar--large .sidebar__link:hover {
  color: var(--color-primary);
}

.sidebar--large button.sidebar__link {
  width: 100%;
  justify-content: space-between;
}

.sidebar--large button.sidebar__link.is-active .sidebar__icon-down {
  transform: rotate(180deg);
}

.sidebar--large button.sidebar__link .sidebar__icon-down {
  font-size: 13px;
  font-weight: 400;
  color: var(--neutral-06);
  transition: var(--transition);
}

.sidebar--large .sidebar__submenu {
  display: none;
  border-radius: var(--radius-md);
}

.sidebar--large .sidebar__submenu .sidebar__text {
  font-size: 1.3rem;
  font-weight: 400;
  padding: 1rem 0;
}

.sidebar--large .sidebar__submenu .sidebar__item {
  background: var(--neutral-01);
}

.sidebar--large .sidebar__submenu .sidebar__item a {
  padding: 0 1.2rem;
}

.sidebar--large .sidebar__submenu.is-open {
  display: block;
  overflow: scroll;
  max-height: calc(100vh - 432px);
}

@media (min-width: 769px) {

  .sidebar--large .sidebar__item--group1:not(.sidebar__item--group1 + .sidebar__item--group1),
  .sidebar--large .sidebar__item--group2:not(.sidebar__item--group2 + .sidebar__item--group2),
  .sidebar--large .sidebar__item--group3:not(.sidebar__item--group3 + .sidebar__item--group3),
  .sidebar--large .sidebar__item--group4:not(.sidebar__item--group4 + .sidebar__item--group4) {
    border-top-right-radius: var(--radius-sm);
    border-top-left-radius: var(--radius-sm);
  }

  .sidebar--large .sidebar__item--group1:has(+ :not(.sidebar__item--group1)),
  .sidebar--large .sidebar__item--group2:has(+ :not(.sidebar__item--group2)),
  .sidebar--large .sidebar__item--group3:has(+ :not(.sidebar__item--group3)),
  .sidebar--large .sidebar__item--group4:last-child {
    margin-bottom: 0.4rem;
    border-bottom-right-radius: var(--radius-sm);
    border-bottom-left-radius: var(--radius-sm);
  }
}

.sidebar--large .sidebar-bottom {
  padding-top: 1.5rem;
  bottom: 0;
}

.sidebar--large .sidebar-bottom .button-cta {
  width: 100%;
}

@media (min-width: 769px) {
  .sidebar--large .sidebar-bottom .button-cta {
    margin-top: 1rem;
  }
}

@media (min-width: 769px) {

  .sidebar--large .sidebar__icon--mobile,
  .sidebar--large .sidebar__item--avatar {
    display: none;
  }
}

@media (max-width: 768px) {
  .sidebar--large {
    position: fixed;
    z-index: 10;
    width: 100%;
    bottom: 0;
    height: auto;
    flex-direction: row;
    left: 0;
    right: 0;
    border-radius: 0;
    overflow: inherit;
    padding: 0.5rem;
    height: var(--mobile-menu-size);
    border-top: 1px solid var(--color-border);
    align-items: center;
  }

  .sidebar--large .sidebar-top,
  .sidebar--large .input-search,
  .sidebar--large .sidebar__icon-down,
  .sidebar--large .sidebar__icon--desktop,
  .sidebar--large .dropdown .dropdown-user-nav__toggle,
  .sidebar--large .sidebar__item--discord,
  .sidebar--large .sidebar__text:not(.sidebar__submenu .sidebar__text),
  .sidebar--large .dropdown-user-nav-info:not(.dropdown__menu-top .dropdown-user-nav-info),
  .sidebar--large .button-cta:not(.dropdown__menu-top .button-cta) {
    display: none;
  }

  .sidebar--large .sidebar__nav {
    margin: 0;
  }

  .sidebar--large .sidebar__menu {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .sidebar--large .sidebar__menu .sidebar__link--active {
    padding: 1rem;
  }

  .sidebar--large .sidebar__menu .sidebar__icon {
    font-size: 2.2rem;
  }

  .sidebar--large .sidebar__menu button.sidebar__link-mobile {
    height: 4.6rem;
    width: 4.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-black);
    border-radius: var(--radius-full);
    box-shadow: rgba(0, 0, 0, 0.2) 0px 3px 3px -2px, rgba(0, 0, 0, 0.14) 0px 3px 4px 0px, rgba(0, 0, 0, 0.12) 0px 1px 8px 0px;
  }

  .sidebar--large .sidebar__menu button.sidebar__link-mobile .sidebar__icon--mobile {
    color: var(--color-white);
    transition: var(--transition);
  }

  .sidebar--large .sidebar__menu button.sidebar__link-mobile.is-active {
    transform: scale(1.1);
  }

  .sidebar--large .sidebar__menu button.sidebar__link-mobile.is-active .sidebar__icon--mobile {
    transform: rotate(45deg);
  }

  .sidebar--large .sidebar-bottom {
    padding: 0;
  }

  .sidebar--large .dropdown-user-nav__avatar {
    height: 2.6rem;
    width: 2.6rem;
  }

  .sidebar--large .dropdown__menu,
  .sidebar--large .sidebar__submenu {
    position: fixed;
    bottom: var(--mobile-menu-size) !important;
    max-height: 71.5vh !important;
    width: calc(100% - 20px);
    left: 50%;
    right: 0;
    z-index: 9;
    transform: translateX(-50%);
    box-shadow: 0 0 40px 10px rgba(0, 0, 0, 0.2);
  }

  .sidebar--large .sidebar__submenu {
    padding: 1rem;
    background: var(--color-white);
  }

  .sidebar--large .sidebar__submenu .sidebar__item {
    background: transparent;
  }

  .sidebar--large .sidebar__submenu .sidebar__item .sidebar__link {
    gap: 2rem;
  }

  .sidebar--large .sidebar__submenu .sidebar__item .sidebar__text {
    padding: 1.3rem 0;
  }

  .sidebar--large .dropdown__menu {
    transform: translateY(3px) scale(0.9) translateX(-50%);
    top: auto;
  }

  .sidebar--large .dropdown__menu.is-open {
    opacity: 1;
    visibility: visible;
    transform: inherit;
    transform: translateY(0px) scale(1) translateX(-50%);
  }
}

/*----------------------------------
    Control Panel
-----------------------------------*/
.sidebar--control {
  max-width: var(--sidebar-width);
  width: 100%;
  padding: var(--unified-spacing);
}

@media (max-width: 768px) {
  .sidebar--control {
    border: none;
    padding: 1.6rem;
    padding-bottom: 8rem;
    position: fixed;
    top: 0;
    max-width: 100%;
    height: 100%;
    right: 0;
    z-index: 10;
    transition: var(--transition);
    left: 100%;
    opacity: 0;
    visibility: hidden;
  }

  .sidebar--control.is-open {
    visibility: visible;
    opacity: 100;
    left: 0;
  }
}

.sidebar--control__header {
  margin-bottom: 2.4rem;
}

.sidebar--control__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 0.4rem;
}

.sidebar--control__title-right {
  display: flex;
  align-items: center;
}

.sidebar--control__help {
  background: var(--color-info);
  font-size: 1.8rem;
  padding: 0.4rem;
  border-radius: var(--radius-full);
}

.sidebar--control .button-sidebar-lock {
  font-size: 1.8rem;
  margin-bottom: 1rem;
  transition: var(--transition);
  display: none;
  opacity: 0.45;
}

.sidebar--control .button-sidebar-lock.is-active {
  transform: rotate(-45deg);
  opacity: 1;
}

@media (min-width: 769px) and (max-width: 1020px) {
  .sidebar--control {
    position: relative;
    margin-left: -22rem;
    right: -22rem;
    transition: 0.3s;
    z-index: 4;
  }

  .sidebar--control:hover,
  .sidebar--control.is-open {
    right: 0;
  }

  .sidebar--control.is-open {
    margin-left: 0;
  }

  .sidebar--control .button-sidebar-lock {
    display: flex;
  }
}

@media (max-width: 768px) {
  .sidebar--control .sidebar--control__header {
    margin-bottom: 0 !important;
  }

  .sidebar--control .sidebar--control__title,
  .sidebar--control .sidebar--control__help,
  .sidebar--control .sidebar--control__description {
    display: none;
  }

  .sidebar--control .sidebar--control__top {
    justify-content: flex-end;
    margin-bottom: 1rem !important;
  }
}

@media (max-width: 1280px) {
  .sidebar--control .sidebar--control__title {
    font-size: 1.6rem;
  }
}

.sidebar--control__title-right {
  gap: 1rem;
}

@media (min-width: 769px) {
  .sidebar--control__title-right .close-btn {
    display: none;
  }
}

.sidebar--control__reset {
  border-right: 1px solid var(--color-border);
  padding-right: 1rem;
  transition: var(--transition);
  display: none;
}

.sidebar--control__reset:hover {
  color: var(--color-primary);
}

.sidebar--control__help {
  color: white;
}

.sidebar--control__body .control-group {
  background: var(--neutral-01);
  border-radius: var(--radius-md);
  padding: 1.7rem 1.6rem 2rem 1.6rem;
}

.sidebar--control__body .control-group--row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.sidebar--control__body .control-group--row .control-label {
  margin-bottom: 0;
}

.sidebar--control__body .control-group:not(:last-child) {
  margin-bottom: 1rem;
}

@media (max-width: 768px) {
  .sidebar--control__body .control-group {
    padding: 1.6rem 1rem;
  }
}

.sidebar--control__body .control-group .card--upload {
  box-shadow: none;
  border: 0;
  padding: 2.4rem;
}

.sidebar--control__body .control-group .card--upload .card__icon {
  height: 4.8rem;
  width: 4.8rem;
  background: var(--neutral-01);
  border-radius: var(--radius-md);
  font-size: 2.4rem;
  margin-bottom: 0;
  border: 0;
}

.sidebar--control__body .control-group .card--upload .card__title {
  font-size: var(--font-size-md);
}

.sidebar--control__body .control-group .card--upload .card__description {
  font-size: var(--font-size-sm);
}

.sidebar--control__body .control-group .card--upload:hover .card__icon {
  background: var(--color-primary);
}

.sidebar--control__body .image-wrapper {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 120px));
  gap: 0.8rem;
  margin-bottom: 1.8rem;
}

.sidebar--control__body .image-wrapper img {
  aspect-ratio: 3/2;
  border-radius: var(--radius-sm);
  -o-object-fit: cover;
  object-fit: cover;
  cursor: pointer;
}

.sidebar--control .control-label-main,
.sidebar--control .control-label {
  font-weight: var(--font-weight-semibold);
  margin-bottom: 1.4rem;
}

.sidebar--control .control-label-main {
  font-size: var(--font-size-lg);
}

.sidebar--control .control-label {
  font-size: 1.4rem;
}

.sidebar--control .control-row:not(:last-child) {
  margin-bottom: 2rem;
}

.sidebar--control .is-close {
  display: none;
}

.sidebar--control .asset {
  margin-bottom: 1rem;
}

.sidebar--control .asset__browser {
  display: none;
  background: var(--neutral-01);
  padding: 2rem 1.6rem;
  border-radius: var(--radius-lg);
}

.sidebar--control .asset__browser--user-uploaded,
.sidebar--control .asset__browser--decor {
  display: none;
}

.sidebar--control .asset__browser--user-uploaded.is-active,
.sidebar--control .asset__browser--decor.is-active {
  display: block;
}

.sidebar--control .asset__browser.is-active {
  display: block;
}

.sidebar--control .asset .back-button {
  font-size: var(--font-size-md);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 2rem;
}

.sidebar--control .asset .back-button .icon {
  font-size: calc(var(--font-size-md) - 1px);
}

.sidebar--control .asset .tab--outer {
  margin-bottom: 1.4rem;
}

.sidebar--control .asset .tab--outer button {
  flex: 1;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.sidebar--control .asset .accordion-toggler {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  transition: var(--transition);
}

.sidebar--control .asset .accordion-toggler .icon {
  transition: var(--transition);
}

.sidebar--control .asset .accordion-toggler:hover {
  color: var(--color-primary);
}

.sidebar--control .asset .accordion-group:not(:last-child) {
  padding-bottom: 0.8rem;
  margin-bottom: 1.6rem;
  border-bottom: 1px solid var(--color-border-light);
}

.sidebar--control .asset .accordion-group:not(:last-child) .accordion-toggler {
  padding-bottom: 0.8rem;
}

.sidebar--control .asset .accordion .is-active .accordion-toggler .icon {
  transform: rotate(180deg);
}

.sidebar--control .asset .accordion .image-wrapper {
  margin-bottom: 0;
  margin-top: 1.6rem;
}

.sidebar--control .asset .accordion .input-search {
  margin-bottom: 1.8rem;
}

.sidebar--control .asset__upload {
  position: relative;
  display: flex;
  flex-direction: column;
  text-align: center;
  width: 100%;
  background: var(--color-white);
  padding: 2.4rem;
  border-radius: var(--radius-md);
  border: 1px dashed var(--color-border);
}

.sidebar--control .asset__upload .upload-icon {
  font-size: 2.4rem;
  margin-bottom: 1.6rem;
}

.sidebar--control .asset__upload input {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0;
  cursor: pointer;
}

.sidebar--control .asset__upload .content .title {
  margin-bottom: 0.5rem;
  font-weight: 500;
  font-size: 1.5rem;
}

.sidebar--control .asset__upload .content .description {
  font-size: 1.3rem;
}

.sidebar--control .button--generate {
  position: sticky;
  bottom: 0;
  z-index: 8;
  padding: 19px 21px;
}

.sidebar--control .button--generate:after {
  content: "";
  position: absolute;
  background: var(--color-white);
  bottom: -25px;
  height: 25px;
  width: 100%;
}

@media (max-width: 768px) {
  .sidebar--control .button--generate {
    width: calc(100% - 32px);
    position: fixed;
    z-index: 9;
    bottom: 16px;
    right: 0;
    left: 16px;
  }
}

/*----------------------------------
    Control Info
-----------------------------------*/
.sidebar--info {
  padding: 2.4rem;
}

@media (min-width: 1281px) {
  .sidebar--info {
    max-width: 36rem;
  }
}

@media (max-width: 768px) {
  .sidebar--info {
    padding-top: 3.6rem;
  }
}

.sidebar--info .single-item:not(:last-child) {
  border-bottom: 1px solid var(--color-border-light);
  padding-bottom: 1.6rem;
  margin-bottom: 1.6rem;
}

.sidebar--info .title {
  font-weight: 600;
}

.sidebar--info .prompt {
  margin-top: 1rem;
  display: flex;
  align-items: flex-end;
}

.sidebar--info .read-more {
  margin: 0;
}

.sidebar--info .read-more-toggle {
  white-space: nowrap;
  text-decoration: underline;
  color: var(--neutral-06);
  position: relative;
  top: -2px;
}

.sidebar--info .close-btn {
  position: absolute;
  margin: 1.5rem;
}

@media (min-width: 769px) {
  .sidebar--info .close-btn {
    display: none;
  }
}

.switch {
  position: relative;
  width: 48px;
  height: 26px;
  overflow: hidden;
  border-radius: 100px;
}

.checkbox {
  position: relative;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 3;
}

.knob,
.switch-bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.knob {
  z-index: 2;
}

.switch-bg {
  width: 100%;
  background-color: var(--neutral-05);
  transition: 0.3s ease all;
  z-index: 1;
}

.knob::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  background-color: var(--color-white);
  border-radius: 50%;
  transition: 0.3s ease all, left 0.3s cubic-bezier(0.18, 0.89, 0.35, 1.15);
}

.checkbox:active+.knob::before {
  width: 42px;
  border-radius: 100px;
}

.checkbox:checked:active+.knob::before {
  margin-left: -22px;
}

.checkbox:checked+.knob::before {
  left: 25px;
  background-color: white;
}

.checkbox:checked~.switch-bg {
  background-color: var(--color-primary);
}

.switch--sm {
  width: 36px;
  height: 20px;
}

.switch--sm .checkbox:checked+.knob::before {
  left: 18px;
  background-color: white;
}

.switch--sm .knob::before {
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
}

.switch--sm .checkbox:active+.knob::before {
  width: 32px;
}

.switch--sm .checkbox:checked:active+.knob::before {
  margin-left: -16px;
}

.modal {
  --modal-width: 60rem;
  position: fixed;
  top: 0;
  right: calc(-1 * var(--modal-width));
  height: 100%;
  border: 1px solid var(--color-border);
  width: 100%;
  max-width: var(--modal-width);
  z-index: 99;
  transition: var(--transition);
}

.modal.is-open {
  right: 0;
}

.modal__wrapper {
  background: var(--color-white);
  height: 100%;
  width: 100%;
  padding: 4rem 1.6rem;
}

@media (min-width: 769px) {
  .modal__wrapper {
    padding: 4rem var(--sidebar-spacing) var(--sidebar-spacing) var(--sidebar-spacing);
  }
}

.modal__header {
  margin-bottom: 3rem;
}

.modal__title {
  font-size: 2rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

@media (max-width: 768px) {
  .modal#historyModal .modal__header {
    display: none;
  }
}

.modal .upload-url {
  display: flex;
  flex-direction: row;
}

.modal .upload-url input {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
}

.modal .upload-url .button {
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
}

.modal .tab-group {
  height: calc(100vh - 21rem);
  overflow: auto;
  scrollbar-width: none;
  /* Firefox */
  -ms-overflow-style: none;
  /* IE 10+ */
}

@media (min-width: 769px) {
  .modal .tab-group {
    height: calc(100vh - 19.8rem);
  }
}

.modal .tab-group::-webkit-scrollbar {
  display: none;
  /* Chrome, Safari */
}

.modal__img-group {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  padding: 0.6rem;
}

@media (min-width: 769px) {
  .modal__img-group {
    gap: 1rem;
    grid-template-columns: repeat(3, 1fr);
  }
}

.modal__img-group img {
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: var(--radius-md);
  width: 100%;
  cursor: pointer;
  transition: var(--transition);
  aspect-ratio: 9/6;
}

.modal__img-group img:hover {
  box-shadow: 0 0 0 5px var(--color-primary);
}

/*----------------------------------
    Index:
	# Body
	# App Layout
	# Control Panel
	# Canvas
-----------------------------------*/
body {
  padding: var(--spacing-page);
  min-height: 100vh;
  background: var(--neutral-01);
}

@media (min-width: 769px) {
  body {
    overflow: hidden;
  }
}

body.img-generated main {
  overflow: hidden;
}

.app-layout {
  display: flex;
  gap: 2rem;
  flex-direction: column;
}

@media (min-width: 769px) {
  .app-layout {
    flex-direction: row;
  }
}

.main-body {
  flex: 1;
  z-index: 3;
}

/*----------------------------------
    Homepage
-----------------------------------*/
@media (min-width: 769px) {
  .page-deshboard {
    padding-right: 0;
  }
}

.page-deshboard .app-layout {
  gap: 0;
}

@media (max-width: 768px) {
  .page-deshboard .app-layout {
    margin-bottom: 6rem;
  }
}

.page-deshboard .main-body {
  height: calc(100vh - 3.6rem);
  padding-left: var(--spacing-page);
  padding-right: var(--spacing-page);
}

@media (max-width: 768px) {
  .page-deshboard .main-body {
    padding: 0;
  }
}

.gallery-masonry {
  position: relative;
  margin: 0 auto;
  min-height: 400px;
  will-change: transform, opacity;
  transform: translateZ(0);
}

.gallery-masonry .card {
  will-change: transform, opacity;
  transform: translateZ(0);
}

.gallery-masonry.masonry-single-col .card {
  margin-bottom: 12px;
  display: block;
  position: static !important;
  left: auto !important;
  top: auto !important;
  width: 100% !important;
}

.card {
  position: absolute;
  background: black;
  border-radius: var(--radius-sm);
  transition: var(--transition);
  opacity: 0;
  transform: translateY(20px);
}

.card img {
  transition: var(--transition);
  border-radius: var(--radius-sm);
}

.card.loaded {
  opacity: 1;
  transform: translateY(0);
}

.card:hover {
  transform: translateY(-2px) scale(1.02);
}

.card:hover img {
  opacity: 0.5;
}

.card.hidden {
  opacity: 0;
  transform: scale(0.8);
  pointer-events: none;
}

.card-options {
  position: absolute;
  z-index: 5;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: 1rem;
  border-radius: var(--radius-sm);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.3) 60%, rgba(0, 0, 0, 0.75) 100%);
}

.card-options .top {
  flex: 1;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.card-options .top .favorited,
.card-options .top .select-icon--selected {
  display: none;
}

.card-options .top button,
.card-options .top .dropdown__toggle {
  border-radius: var(--radius-sm);
  font-size: 1.8rem;
  transition: var(--transition);
  color: white;
  background: hsla(0, 0%, 0%, 0.3);
  padding: 0.6rem;
}

.card-options .top button:hover,
.card-options .top .dropdown__toggle:hover {
  background: hsla(0, 0%, 0%, 0.6);
}

.card-options .top .dropdown__toggle {
  border: none;
}

.card-options .top .button-select.is-active .select-icon {
  display: none;
}

.card-options .top .button-select.is-active .select-icon--selected {
  display: block;
}

.card-options .top .button-favorite.is-active .no-fav {
  display: none;
}

.card-options .top .button-favorite.is-active .favorited {
  display: block;
}

.card-options .top .left,
.card-options .top .right {
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.card .title {
  color: white;
}

@media (min-width: 769px) {
  .card .title {
    font-size: 1.5rem;
  }
}

.card .dropdown--custom-width .dropdown__menu {
  min-width: 250px;
  z-index: 9999;
}

/*----------------------------------
    Single Gallery
-----------------------------------*/
@media (min-width: 769px) {
  .page-single-gallery .image-details span {
    display: none;
  }
}

.page-single-gallery .before-after-container {
  width: auto;
  margin-right: auto;
  margin-left: auto;
}

.page-single-gallery .navigation {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  width: 88%;
  overflow: hidden;
  border-radius: var(--radius-sm);
}

.page-single-gallery .navigation .navigation-item {
  flex: 0 0 64px;
  height: 64px;
  aspect-ratio: 5/4;
  opacity: 0.7;
  cursor: pointer;
  transition: var(--transition);
  padding: 3px;
}

.page-single-gallery .navigation .navigation-item img {
  border-radius: var(--radius-sm);
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.page-single-gallery .navigation .navigation-item.active,
.page-single-gallery .navigation .navigation-item:hover {
  opacity: 1;
}

.page-single-gallery .navigation .navigation-item.active img,
.page-single-gallery .navigation .navigation-item:hover img {
  box-shadow: 0 0 0 2px var(--color-black);
}

/*----------------------------------
    Canvas
-----------------------------------*/
.canvas {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--unified-spacing);
}

@media (min-width: 769px) {
  .canvas {
    border: 1px solid var(--color-border);
  }
}

@media (max-width: 768px) {
  .canvas {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }
}

.canvas__header {
  margin-bottom: 1.6rem;
  text-align: center;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.canvas__header .left,
.canvas__header .right,
.canvas__header .middle,
.canvas__header .button--upload {
  display: flex;
  align-items: center;
}

@media (max-width: 1280px) {

  .canvas__header .left,
  .canvas__header .right,
  .canvas__header .middle,
  .canvas__header .button--upload {
    font-size: 1.3rem;
  }
}

@media (max-width: 449px) {

  .canvas__header .left,
  .canvas__header .right,
  .canvas__header .middle,
  .canvas__header .button--upload {
    font-size: 1.2rem;
  }
}

.canvas__header .left button,
.canvas__header .right button,
.canvas__header .middle button,
.canvas__header .button--upload button {
  gap: 0.8rem;
  font-weight: 500;
  color: var(--color-black);
  transition: var(--transition);
}

.canvas__header .left button:hover,
.canvas__header .right button:hover,
.canvas__header .middle button:hover,
.canvas__header .button--upload button:hover {
  color: var(--color-primary);
}

@media (max-width: 1280px) {

  .canvas__header .left button,
  .canvas__header .right button,
  .canvas__header .middle button,
  .canvas__header .button--upload button {
    gap: 0.5rem;
  }
}

.canvas__header .left .icon,
.canvas__header .right .icon,
.canvas__header .middle .icon,
.canvas__header .button--upload .icon {
  font-size: 1.6rem;
}

.canvas__header .left button:not(:last-child) {
  border-right: 1px solid var(--color-border);
  margin-right: 1rem;
  padding-right: 1rem;
}

@media (min-width: 1025px) {
  .canvas__header .left button:not(:last-child) {
    margin-right: 1.5rem;
    padding-right: 1.5rem;
  }
}

.canvas__header .middle {
  gap: 0.8rem;
}

.canvas__header .middle label {
  cursor: pointer;
  font-weight: 500;
}

@media (max-width: 449px) {
  .canvas__header .middle {
    display: none;
  }
}

.canvas__header .right {
  position: relative;
}

.canvas__header .right .upload-top {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  opacity: 0;
}

.canvas__header .button--upload {
  gap: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  position: relative;
  z-index: 1;
  transition: var(--transition);
}

.canvas__header .button--upload:hover {
  color: var(--color-primary);
}

.canvas__header .button--upload .icon {
  background: var(--neutral-02);
  padding: 0.6rem 0.7rem;
  border-radius: var(--radius-xs);
}

@media (min-width: 769px) {
  .canvas__header .button--upload .icon {
    padding: 0.6rem 0.8rem;
    border-radius: var(--radius-sm);
  }
}

.canvas__title {
  font-size: 2.4rem;
  font-weight: var(--font-weight-medium);
  margin-bottom: 0.5rem;
}

@media (min-width: 769px) {
  .canvas__title {
    font-size: 3rem;
    margin-bottom: 1rem;
  }
}

.canvas__subtitle {
  font-size: var(--font-size-s);
}

@media (min-width: 769px) {
  .canvas__subtitle {
    font-size: var(--font-size-lg);
  }
}

.canvas__render {
  display: flex;
}

.button-continue {
  width: calc(100% - 32px);
  position: fixed;
  z-index: 3;
  bottom: 16px;
  right: 0;
  left: 16px;
}

@media (min-width: 769px) {
  .button-continue {
    display: none;
  }
}

.img-generated .button-continue {
  position: relative;
  margin: 1.6rem 0;
  bottom: 0;
  left: auto;
  right: auto;
  width: 100%;
}

/*----------------------------------
    Start Screen
-----------------------------------*/
.canvas--start-screen {
  padding: var(--unified-spacing);
}

@media (min-width: 1025px) {
  .canvas--start-screen {
    padding: 10rem var(--unified-spacing);
  }
}

.canvas--start-screen .canvas__header {
  display: flex;
  flex-direction: column;
  margin-bottom: 3.6rem;
}

@media (max-width: 768px) {
  .canvas--start-screen .canvas__header {
    display: none;
  }
}

.canvas--start-screen .canvas__alert {
  text-align: center;
}

.no-subscription .button-continue {
  display: none;
}

@media (max-width: 1024px) {
  .no-subscription .canvas--start-screen {
    padding-top: 3rem;
    padding-bottom: 3.5rem;
  }
}

.upload-options {
  max-width: 85rem;
  margin: 0 auto;
  display: flex;
  gap: 1.6rem;
  justify-content: center;
  flex-wrap: wrap;
}

@media (min-width: 450px) and (max-width: 768px) {
  .upload-options {
    flex-wrap: nowrap;
  }
}

.upload-options .upload-card {
  padding: 3.2rem 1.6rem 3rem;
  border-radius: var(--radius-lg);
  width: 100%;
  gap: 1.6rem;
  transition: var(--transition);
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
  text-align: center;
  background: var(--color-white);
  border: 1px dashed var(--color-border);
  box-shadow: var(--depth-1);
  width: 100%;
  cursor: pointer;
}

.upload-options .upload-card:hover {
  box-shadow: var(--depth-4);
}

.upload-options .upload-card:hover .card__icon {
  background: var(--color-primary);
  color: var(--color-white);
}

@media (min-width: 769px) {
  .upload-options .upload-card {
    box-shadow: var(--depth-2);
    border: 1px solid var(--color-border);
  }
}

@media (min-width: 1025px) {
  .upload-options .upload-card {
    flex-wrap: nowrap;
    width: 100%;
    width: calc(50% - 1.6rem);
  }
}

.upload-options .upload-card__icon {
  font-size: 2.8rem;
  border-radius: var(--radius-lg);
  height: 7.2rem;
  width: 7.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  margin-bottom: 0.5rem;
  transition: var(--transition);
}

.upload-options .upload-card__title {
  margin-bottom: 0.8rem;
  font-size: var(--font-size-lg);
  font-weight: 500;
}

@media (min-width: 769px) {
  .upload-options .upload-card__title {
    font-weight: 700;
  }
}

@media (max-width: 768px) {
  .upload-options .upload-card__description {
    display: none;
  }
}

.upload-options .upload-card input[type=file] {
  cursor: pointer;
}

@media (max-width: 768px) {
  .upload-options .upload-card--url {
    display: none;
  }
}

.upload-options .upload-card--upload input {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0;
  cursor: pointer;
}

@media (min-width: 1281px) {
  .upload-options {
    flex-wrap: nowrap;
    width: 100%;
  }
}

/*----------------------------------
    Generate Screen
-----------------------------------*/
.render-area {
  flex: 1;
}

.canvas--generate .canvas__header {
  flex-wrap: wrap;
  gap: 0.6rem 1rem;
}

@media (max-width: 1024px) {
  .canvas--generate .canvas__header {
    margin-bottom: 1rem;
  }
}

.thumbnails {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  flex-wrap: wrap;
}

.thumbnails .thumbnail-wrapper {
  height: 6.6rem;
  width: 100%;
  max-width: 10rem;
}

.thumbnails .thumbnail-wrapper .icon {
  font-size: 24px;
  color: var(--neutral-06);
  opacity: 0.5;
  box-shadow: 0 0 0 0.1rem var(--color-border);
  background: var(--neutral-02);
  width: 100%;
  height: 100%;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 769px) {
  .thumbnails .thumbnail-wrapper {
    border-radius: var(--radius-md);
  }
}

.thumbnails .thumbnail {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  cursor: pointer;
  transition: var(--transition);
  border-radius: var(--radius-sm);
}

@media (min-width: 769px) {
  .thumbnails .thumbnail {
    border-radius: var(--radius-md);
  }
}

.thumbnails .thumbnail:hover,
.thumbnails .thumbnail.is-active {
  padding: 0.2rem;
  opacity: 1;
  box-shadow: 0 0 0 0.3rem var(--color-primary);
  transform: scale(0.92);
}

/* ----------------------------------
 Before After Slider
 ----------------------------------*/
.before-after-container {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  touch-action: none;
  margin-bottom: 1.6rem;
  border-radius: var(--radius-lg);
  max-height: 50vh;
  background: var(--neutral-01);
}

.before-after-container.drag-anywhere:not(.inactive) {
  cursor: ew-resize;
}

.before-after-container .inactive[data-lightbox=false] img {
  cursor: default !important;
}

.before-after-container img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

.before-after-container .before {
  z-index: 1;
}

.before-after-container .after {
  z-index: 2;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 0s;
  will-change: clip-path;
}

.before-after-container .handle {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 15px;
  height: 40px;
  margin-left: -7.5px;
  margin-top: -20px;
  border: 3px solid white;
  border-radius: 1000px;
  background-color: transparent;
  box-shadow: 0 0 12px rgba(51, 51, 51, 0.5);
  z-index: 3;
  cursor: ew-resize;
}

.before-after-container .handle::before,
.before-after-container .handle::after {
  content: "";
  position: absolute;
  width: 3px;
  height: 9999px;
  left: 50%;
  margin-left: -1.5px;
  background: white;
  box-shadow: 0 0 12px rgba(51, 51, 51, 0.5);
  z-index: 30;
}

.before-after-container .handle::before {
  bottom: 50%;
  margin-bottom: 22px;
  box-shadow: 0 3px 0 white, 0 0 12px rgba(51, 51, 51, 0.5);
}

.before-after-container .handle::after {
  top: 50%;
  margin-top: 22px;
  box-shadow: 0 -3px 0 white, 0 0 12px rgba(51, 51, 51, 0.5);
}

.before-after-container .handle .handle-left-arrow,
.before-after-container .handle .handle-right-arrow {
  position: absolute;
  top: 50%;
  width: 0;
  height: 0;
  margin-top: -6px;
  border: 6px inset transparent;
}

.before-after-container .handle .handle-left-arrow {
  left: -2rem;
  border-right: 6px solid white;
}

.before-after-container .handle .handle-right-arrow {
  right: -2rem;
  border-left: 6px solid white;
}

/* ----------------------------------
 Lightbox styles
 ----------------------------------*/
.decor-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 110;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}

.decor-lightbox.visible {
  opacity: 1;
  pointer-events: auto;
}

.decor-lightbox.visible .decor-lightbox-content {
  transform: scale(1);
  opacity: 1;
}

.decor-lightbox .decor-lightbox-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  transform: scale(0.95);
  opacity: 0;
  transition: transform 0.4s ease, opacity 0.4s ease;
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-main {
  max-width: 90vw;
  max-height: 70vh;
  border-radius: 8px;
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.6);
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: zoom-out;
}

@media (min-width: 1025px) {
  .decor-lightbox .decor-lightbox-content .decor-lightbox-main {
    max-height: 77vh;
  }
}

.decor-lightbox .decor-lightbox-content button {
  position: absolute;
  background: none;
  border: none;
  color: white;
  font-size: 2rem;
  cursor: pointer;
}

.decor-lightbox .decor-lightbox-content button i {
  pointer-events: none;
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-close {
  top: -25px;
  right: 0;
  color: rgba(255, 255, 255, 0.5);
  transition: var(--transition);
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-close:hover {
  color: white;
}

@media (min-width: 769px) {
  .decor-lightbox .decor-lightbox-content .decor-lightbox-close {
    right: -30px;
  }
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-prev,
.decor-lightbox .decor-lightbox-content .decor-lightbox-next {
  top: calc(50% - 18px);
  transform: translateY(calc(50% - 55px));
  padding: 0 0.6rem;
  background: rgba(0, 0, 0, 0.4);
  border-radius: 100px;
  height: 36px;
  width: 36px;
  font-size: 18px;
  border: 2px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.5);
  transition: var(--transition);
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-prev:hover,
.decor-lightbox .decor-lightbox-content .decor-lightbox-next:hover {
  color: white;
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-prev {
  left: 5px;
}

@media (min-width: 1025px) {
  .decor-lightbox .decor-lightbox-content .decor-lightbox-prev {
    left: -40px;
  }
}

@media (min-width: 1281px) {
  .decor-lightbox .decor-lightbox-content .decor-lightbox-prev {
    left: -50px;
  }
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-next {
  right: 5px;
}

@media (min-width: 1025px) {
  .decor-lightbox .decor-lightbox-content .decor-lightbox-next {
    right: -40px;
  }
}

@media (min-width: 1281px) {
  .decor-lightbox .decor-lightbox-content .decor-lightbox-next {
    right: -50px;
  }
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-thumbnails {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 8px;
  max-width: 100%;
  overflow-x: auto;
  padding: 5px;
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-thumbnails .decor-lightbox-thumb {
  max-height: 60px;
  border-radius: 4px;
  opacity: 0.5;
  cursor: pointer;
  transition: opacity 0.3s;
  padding: 0.2rem;
}

.decor-lightbox .decor-lightbox-content .decor-lightbox-thumbnails .decor-lightbox-thumb.active,
.decor-lightbox .decor-lightbox-content .decor-lightbox-thumbnails .decor-lightbox-thumb:hover {
  opacity: 1;
  box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.7);
}

.decor-lightbox.scale-out {
  opacity: 0;
  pointer-events: none;
}

.decor-lightbox.scale-out .decor-lightbox-content {
  transform: scale(0.85);
  opacity: 0;
}

/* ----------------------------------
 Video Player
 ----------------------------------*/
/* ----------------------------------------------------
   Decor Player — SCSS using CSS custom properties
   Override at runtime:
   .decor-player { --decor-accent: #ff6b6b; --decor-fs-object-fit: cover; }
----------------------------------------------------- */
.decor-player {
  --decor-bg: #121214;
  --decor-text: #e8e8ea;
  --decor-muted: #a3a3ad;
  --decor-track: #34343486;
  --decor-accent: #8b7dff;
  --decor-radius: 14px;
  --decor-ctrl-h: 3rem;
  --decor-pad-x: 12px;
  --decor-pad-y: 10px;
  --decor-fs-object-fit: contain;
}

/* ---- Mixins (still SCSS) */
/* ---- Player */
.decor-player {
  position: relative;
  background: var(--decor-bg);
  color: var(--decor-text);
  border-radius: var(--decor-radius);
  overflow: hidden;
  max-width: 960px;
  margin: 0 auto 1.6rem auto;
  /* ---- Fullscreen (container) */
}

.decor-player__video {
  width: 100%;
  height: auto;
  display: block;
  background: #000;
}

.decor-player .decor-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: var(--decor-pad-y) var(--decor-pad-x);
  background: var(--decor-bg);
}

.decor-player .dp-btn {
  display: inline-grid;
  place-items: center;
  width: var(--decor-ctrl-h);
  height: var(--decor-ctrl-h);
  padding: 0;
  border: 0;
  border-radius: var(--radius-sm, 8px);
  background: transparent;
  color: var(--decor-text);
  cursor: pointer;
  transition: var(--transition, 160ms ease);
}

.decor-player .dp-btn:hover {
  background: color-mix(in srgb, var(--decor-bg) 92%, white 8%);
}

.decor-player .dp-time {
  min-width: 90px;
  text-align: center;
  font: 12px/1.2 system-ui, sans-serif;
  color: var(--decor-muted);
}

.decor-player .dp-progress {
  position: relative;
  flex: 1;
  height: 18px;
  display: flex;
  align-items: center;
}

.decor-player .dp-progress .dp-track {
  position: absolute;
  inset-inline: 0;
  height: 6px;
  background: var(--decor-track);
  border-radius: 999px;
  pointer-events: none;
}

.decor-player .dp-progress .dp-fill {
  height: 6px;
  width: 0%;
  background: var(--decor-accent);
  border-radius: 999px;
}

.decor-player .dp-progress .dp-seek {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 18px;
  margin: 0;
  background: transparent;
  z-index: 1;
}

.decor-player .dp-progress .dp-seek::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #ffffff;
  border: 0;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.15);
}

.decor-player .dp-progress .dp-seek::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #ffffff;
  border: 0;
}

.decor-player .dp-volume {
  width: 90px;
}

.decor-player.is-muted .dp-mute {
  opacity: 0.7;
}

.decor-player:fullscreen .decor-controls,
.decor-player:-webkit-full-screen .decor-controls {
  position: absolute;
  inset-inline: 0;
  bottom: 0;
  padding: var(--decor-pad-y) var(--decor-pad-x);
  background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
  box-sizing: border-box;
  z-index: 2;
}

/* ---- Fullscreen when the <video> itself is fullscreen (Safari/iOS/native) */
.decor-player__video:fullscreen,
.decor-player__video:-webkit-full-screen,
.decor-player:fullscreen>.decor-player__video,
.decor-player:-webkit-full-screen>.decor-player__video {
  width: 100% !important;
  height: 100% !important;
  max-height: none !important;
  object-fit: var(--decor-fs-object-fit);
  background: #000;
}

/* Optional: keep controls visible even when <video> is the fullscreen element */
.decor-player__video:fullscreen~.decor-controls,
.decor-player__video:-webkit-full-screen~.decor-controls {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding: var(--decor-pad-y) var(--decor-pad-x);
  background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
  box-sizing: border-box;
  z-index: 2147483647;
}

/* ----------------------------------
 Edit Toolset
 ----------------------------------*/
.edit-toolset {
  margin-right: 2rem;
}

.edit-toolset__wrapper {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

@media (min-width: 769px) {
  .edit-toolset__wrapper {
    gap: 1rem;
  }
}

.edit-toolset__tool {
  position: relative;
}

.edit-toolset__tool .tooltip,
.edit-toolset__tool .tooltip-control {
  position: absolute;
  left: calc(100% + 0.3rem);
  top: 50%;
  transform: translateY(-50%);
  white-space: nowrap;
  background: var(--neutral-04);
  font-size: 1.3rem;
  padding: 0.5rem 0.7rem;
  border-radius: var(--radius-sm);
  box-shadow: var(--depth-1);
  transition: var(--transition);
  visibility: hidden;
  opacity: 0;
  z-index: 15;
}

.edit-toolset__tool:not(.is-active):hover .tooltip {
  visibility: visible;
  opacity: 1;
  transition-delay: 0.7s;
}

.edit-toolset__tool.is-active .tooltip-control {
  visibility: visible;
  opacity: 1;
}

.edit-toolset__tool button {
  font-size: 1.5rem;
  padding: 0.6rem;
  border-radius: var(--radius-sm);
  transition: var(--transition);
}

.edit-toolset__tool button .icon-undo {
  font-size: 1.6rem;
}

.edit-toolset__tool button .icon-reload {
  font-size: 1.3rem;
}

.edit-toolset__tool button .icon-edit-polygon,
.edit-toolset__tool button .icon-boolean-exclude {
  font-size: 1.4rem;
}

.edit-toolset__tool button:hover,
.edit-toolset__tool button.is-active {
  color: var(--color-primary);
  background: var(--neutral-04);
}

.edit-toolset .tooltip-control {
  display: flex;
  flex-direction: column;
  width: 130px;
  gap: 0.8rem;
}

.edit-toolset .tooltip-control span {
  font-weight: 600;
}

.edit-toolset .decor-slider {
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  background: linear-gradient(to right, var(--color-primary) 50%, var(--neutral-05) 0);
  border-radius: 100px;
  transition: background 0.2s ease;
  margin-bottom: 0.5rem;
}

.edit-toolset .decor-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1.8rem;
  height: 1.8rem;
  background: var(--color-primary);
  border: 3px solid var(--color-white);
  border-radius: 50%;
  cursor: pointer;
  -webkit-transition: background 0.2s ease;
  transition: background 0.2s ease;
  position: relative;
  z-index: 2;
}

.edit-toolset .decor-slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  background: var(--color-primary);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  -moz-transition: background 0.2s ease;
  transition: background 0.2s ease;
}

.edit-toolset .divider {
  border-bottom: 1px solid var(--color-border);
}

/* ----------------------------------
 Purchase Options
 ----------------------------------*/
.furniture-finder .button--generate {
  margin-bottom: 1rem;
}

@media (max-width: 768px) {
  .furniture-finder .button--generate {
    display: none;
  }
}

.furniture-finder .button--generate:after {
  display: none;
}

.purchase-options-wrapper .img-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}

.purchase-options-wrapper .img-wrapper a {
  display: flex;
  gap: 1rem;
}

.purchase-options-wrapper .img-wrapper a img {
  max-width: 66px;
  aspect-ratio: 3/2;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: var(--radius-sm);
}

.purchase-options-wrapper .img-wrapper a .link {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-all;
  color: var(--neutral-06);
  transition: var(--transition);
}

.purchase-options-wrapper .img-wrapper a:hover .link {
  color: var(--color-primary);
}

/* ----------------------------------
 Recent Generations Card
 ----------------------------------*/
.recent-generation {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  margin-top: 1.6rem;
  padding: var(--unified-spacing);
}

@media (min-width: 769px) {
  .recent-generation {
    border: 1px solid var(--color-border);
  }
}

.recent-generation .section-title {
  font-size: var(--font-size-h4);
  font-weight: 600;
  margin-bottom: 1.6rem;
}

@media (min-width: 769px) {
  .recent-generation .section-title {
    margin-bottom: 2rem;
    font-size: var(--font-size-h3);
  }
}

.recent-generation .wrapper {
  display: grid;
  gap: 1.2rem;
  grid-template-columns: repeat(1, minmax(0, 400px));
}

@media (min-width: 450px) {
  .recent-generation .wrapper {
    grid-template-columns: repeat(2, minmax(0, 400px));
  }
}

@media (min-width: 1025px) {
  .recent-generation .wrapper {
    grid-template-columns: repeat(3, minmax(0, 400px));
  }
}

@media (min-width: 1537px) {
  .recent-generation .wrapper {
    grid-template-columns: repeat(4, minmax(0, 400px));
  }
}

.recent-generation .recent-card {
  position: relative;
  border-radius: var(--radius-sm);
  overflow: hidden;
  z-index: 1;
  background: black;
}

.recent-generation .recent-card__image {
  aspect-ratio: 3/2;
  transition: var(--transition);
  -o-object-fit: cover;
  object-fit: cover;
}

.recent-generation .recent-card__action {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: var(--transition);
  visibility: hidden;
  opacity: 0;
}

.recent-generation .recent-card__action .row {
  display: flex;
  gap: 0.6rem;
}

.recent-generation .recent-card__button {
  background: white;
  color: #000000;
  padding: 1rem;
  border-radius: var(--radius-sm);
  font-size: 2rem;
  transition: var(--transition);
}

.recent-generation .recent-card__button:hover {
  background: var(--color-primary);
  color: white;
}

.recent-generation .recent-card__button .icon {
  transition: var(--transition);
}

.recent-generation .recent-card__button .favorited {
  display: none;
}

.recent-generation .recent-card__button.is-active .favorited {
  display: block;
  color: var(--color-error);
}

.recent-generation .recent-card__button.is-active .no-fav {
  display: none;
}

.recent-generation .recent-card:hover .recent-card__action {
  opacity: 1;
  visibility: visible;
}

.recent-generation .recent-card:hover .recent-card__image {
  opacity: 0.4;
}

/*----------------------------------
    Color Picker
-----------------------------------*/
.colorpicker {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}

.colorpicker__canvas {
  width: 100%;
  height: 200px;
  border-radius: var(--radius-md);
  background: #ff0000;
  position: relative;
  cursor: crosshair;
  overflow: hidden;
  touch-action: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

.colorpicker__canvas::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, #ffffff 0%, transparent 100%);
  pointer-events: none;
}

.colorpicker__canvas::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 0%, #000000 100%);
  pointer-events: none;
}

@media (max-width: 449px) {
  .colorpicker__canvas {
    height: 180px;
  }
}

.colorpicker__hue-bar {
  width: 100%;
  height: 2.4rem;
  border-radius: var(--radius-md);
  background: linear-gradient(to right, hsl(0, 100%, 50%) 0%, hsl(60, 100%, 50%) 16.666%, hsl(120, 100%, 50%) 33.333%, hsl(180, 100%, 50%) 50%, hsl(240, 100%, 50%) 66.666%, hsl(300, 100%, 50%) 83.333%, hsl(0, 100%, 50%) 100%);
  position: relative;
  cursor: pointer;
  touch-action: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

.colorpicker__picker {
  width: 20px;
  height: 20px;
  border: 3px solid white;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  pointer-events: none;
  z-index: 10;
}

.colorpicker__canvas .colorpicker__picker {
  right: 20px;
  top: 50%;
}

.colorpicker__hue-bar .colorpicker__picker {
  right: 60px;
}

.colorpicker__input-section {
  display: flex;
  align-items: center;
  gap: 12px;
  height: 4rem;
}

@media (max-width: 449px) {
  .colorpicker__input-section {
    gap: 8px;
  }
}

.colorpicker__input-label,
.colorpicker__input {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 14px;
  color: var(--neutral-06);
}

.colorpicker__input-label {
  position: relative;
  font-weight: 500;
  min-width: 80px;
  cursor: pointer;
  transition: all 0.2s ease;
  height: 100%;
}

.colorpicker__input-label:hover {
  background: #e9ecef;
}

.colorpicker__input-label::after {
  content: "\ea2a";
  font-family: "icons" !important;
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 10px;
  pointer-events: none;
}

.colorpicker__format-select {
  width: 100%;
  height: 100%;
  padding: 8px 12px;
  border: none;
  background: transparent;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  color: var(--neutral-06);
}

.colorpicker__format-select:focus {
  outline: none;
}

.colorpicker__input {
  flex: 1;
  border: 1px solid var(--color-border);
  padding: 8px 12px;
  height: 100%;
  transition: var(--transition);
}

.colorpicker__input:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.colorpicker__saved-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.colorpicker__saved-title {
  color: var(--neutral-06);
  font-weight: 500;
  padding-bottom: 1rem;
}

.colorpicker__add-btn {
  color: var(--neutral-06);
  cursor: pointer;
  padding-bottom: 1rem;
  transition: var(--transition);
  touch-action: manipulation;
  font-weight: 500;
}

.colorpicker__add-btn:hover {
  color: var(--color-primary);
}

.colorpicker__add-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  color: var(--neutral-06);
}

.colorpicker__saved-colors {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.colorpicker__saved-color {
  width: 3.6rem;
  height: 3.6rem;
  border-radius: 50%;
  cursor: pointer;
  transition: all var(--transition);
  border: 2px solid transparent;
  position: relative;
  touch-action: manipulation;
  box-shadow: 0px 10px 15px rgba(31, 41, 55, 0.1), 0px 4px 6px rgba(31, 41, 55, 0.05);
}

.colorpicker__saved-color:hover {
  transform: scale(1.1);
}

.colorpicker__saved-color--active {
  border: 2px solid #ffffff;
  box-shadow: 0px 0px 0px 2px rgba(0, 0, 0, 0.25), 0px 10px 15px rgba(31, 41, 55, 0.1), 0px 4px 6px rgba(31, 41, 55, 0.05);
  border-radius: 100px;
}

.colorpicker__saved-color .colorpicker__remove-btn {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 20px;
  height: 20px;
  background: #dc3545;
  color: var(--color-white);
  border: none;
  border-radius: 50%;
  font-size: 12px;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
  z-index: 5;
  touch-action: manipulation;
}

.colorpicker__saved-color .colorpicker__remove-btn:hover {
  background: #c82333;
}

.colorpicker__saved-color:hover .colorpicker__remove-btn {
  display: flex;
}

@media (hover: none) {
  .colorpicker__saved-color .colorpicker__remove-btn {
    display: flex;
    opacity: 0.7;
  }

  .colorpicker__saved-color:active .colorpicker__remove-btn {
    opacity: 1;
  }
}

[data-theme=dark] .logo {
  filter: contrast(0) brightness(1.8);
}

.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.6rem;
}

@media (min-width: 769px) {
  .header {
    padding: 0 23px;
    margin-bottom: 2rem;
  }
}

.header.sticky-top {
  padding-bottom: 1.2rem;
}

.header .header-cta {
  display: flex;
  align-items: center;
  gap: 1rem;
}

@media (min-width: 769px) {
  .header .header-cta {
    gap: 1.6rem;
  }
}

@media (max-width: 768px) {

  .header .user-menu__profile,
  .header__logo {
    display: none;
  }
}

.header__title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.header__title span {
  font-size: 1.4rem;
}

@media (min-width: 769px) {
  .header__title {
    display: none;
  }
}

@media (max-width: 360px) {
  .header .header__title {
    gap: 0.3rem;
  }

  .header .header__title a {
    padding: 0.4rem;
  }

  .header .header__title span {
    font-size: 1.2rem;
  }

  .header .button-cta {
    gap: 0.6rem;
  }

  .header .button {
    font-size: 1.2rem;
  }
}

@media (min-width: 769px) {
  .header .sidebar--control__help {
    display: none;
  }
}

.button-back {
  display: flex;
  padding: 0.8rem;
  background: var(--color-white);
  border-radius: var(--radius-sm);
  align-items: center;
  gap: 0.6rem;
}

@media (max-width: 360px) {
  .button-back {
    padding: 0.4rem;
  }
}

.canvas-mode-switcher {
  padding: 0.4rem;
  text-align: center;
  background: var(--color-white);
  border-radius: var(--radius-lg);
}

.main-body .canvas-mode-switcher {
  border-bottom: 1px solid var(--color-border-light);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

@media (min-width: 769px) {
  .main-body .canvas-mode-switcher {
    display: none;
  }
}

@media (max-width: 768px) {
  .header .canvas-mode-switcher {
    display: none;
  }
}

.canvas-mode-switcher .button {
  font-weight: 500;
}

@media (max-width: 449px) {
  .canvas-mode-switcher .button {
    font-size: 1.2rem;
    padding-right: 1rem;
    padding-left: 1rem;
  }
}

.canvas-mode-switcher .button.is-active {
  background: var(--neutral-02);
}

.page-deshboard .header {
  margin-bottom: 1rem;
}

@media (min-width: 769px) {
  .page-deshboard .header {
    padding: 0 1rem 1rem 1rem;
  }
}

@media (max-width: 1024px) {
  .page-deshboard .header {
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.6rem;
  }
}

.page-deshboard .header__title {
  display: block;
  font-size: 2.4rem;
  font-weight: 600;
  letter-spacing: -1.5px;
}

@media (max-width: 1024px) {
  .page-deshboard .header__title {
    font-size: 2rem;
    flex: 0 0 100%;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .page-deshboard .header .button-start-new {
    display: none;
  }

  .page-deshboard .header .dropdown {
    width: 100%;
  }
}

.page-deshboard .header .sorting {
  display: flex;
  gap: 0.2rem;
}

.page-deshboard .header .sorting button {
  padding: 0.6rem 1.2rem;
  border-radius: var(--radius-sm);
  transition: var(--transition);
}

.page-deshboard .header .sorting button:hover,
.page-deshboard .header .sorting button.is-active {
  background: var(--neutral-03);
}

.page-deshboard .header .more-action {
  display: flex;
  gap: 0.4rem;
}

.page-deshboard .header .more-action .button {
  padding: 1rem 1.2rem;
  border-radius: var(--radius-sm);
  transition: var(--transition);
  border: 1px solid var(--color-border);
}

.page-deshboard .header .more-action .button:hover {
  background: var(--neutral-03);
}

.page-deshboard .header .more-action .dropdown__toggle {
  padding: 1rem 1.2rem;
}

.page-single-gallery .canvas__header .middle {
  display: flex;
}

/*----------------------------------
    Index:
	# User Settings Pages
-----------------------------------*/
.user-settings {
  /* ----- Table ---- */
}

.user-settings .main-body .api table,
.user-settings .main-body .api .api-top,
.user-settings .main-body .refer .referral-link-box,
.user-settings .main-body .manage-subscription table,
.user-settings .main-body .manage-subscription .current-subscription,
.user-settings .main-body .danger-zone .inner,
.user-settings .main-body .profile-form {
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
  padding: 2.4rem;
  background: var(--color-white);
}

.user-settings .header__title {
  text-align: center;
  font-size: var(--font-size-h1);
  margin-bottom: 2.4rem;
}

.user-settings .title {
  font-size: var(--font-size-h4);
  font-weight: 600;
  margin-bottom: 1.6rem;
}

.user-settings .main-body .tab {
  text-align: center;
  justify-content: center;
  margin-bottom: 4rem;
}

.user-settings .main-body .tab button {
  padding: 1.2rem 2rem;
}

.user-settings .main-body .tab button .icon {
  display: flex;
}

.user-settings .main-body .content-wrapper {
  max-width: 55rem;
  margin: 0 auto;
}

.user-settings .main-body .profile-form {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.user-settings .main-body .profile-picture-label {
  display: flex;
  align-items: center;
  gap: 1rem;
  cursor: pointer;
}

.user-settings .main-body .profile-picture-label .avatar {
  width: 4.8rem;
  height: 4.8rem;
  margin-right: 0.125rem;
  border-radius: var(--radius-full);
  box-shadow: 0 0 0 2px var(--color-border);
  background: var(--neutral-01);
  aspect-ratio: 1/1;
  -o-object-fit: cover;
  object-fit: cover;
}

.user-settings .main-body .form-group {
  gap: 0.8rem;
  display: flex;
  flex-direction: column;
}

.user-settings .main-body .form-group label {
  font-weight: 500;
}

.user-settings .main-body .danger-zone {
  background: var(--neutral-01);
  margin-top: 3rem;
  border-radius: var(--radius-md);
}

.user-settings .main-body .danger-zone .title {
  margin-bottom: 1.6rem;
}

.user-settings .main-body .danger-zone h6 {
  margin-bottom: 1.2rem;
  color: var(--color-error);
}

.user-settings .main-body .danger-zone .inner {
  display: flex;
  align-items: center;
  gap: 1.6rem;
}

@media (max-width: 768px) {
  .user-settings .main-body .danger-zone .inner {
    flex-wrap: wrap;
  }
}

.user-settings .main-body .danger-zone .inner button {
  white-space: nowrap;
}

.user-settings .main-body .manage-subscription .current-subscription {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: 3.6rem;
}

.user-settings .main-body .manage-subscription .current-subscription .plan-name {
  margin-bottom: 1.6rem;
  font-weight: 600;
  font-size: 1.6rem;
}

.user-settings .main-body .manage-subscription .current-subscription .plan-price {
  margin-bottom: 0.6rem;
}

.user-settings .main-body .manage-subscription .current-subscription .button-group {
  padding: 0;
  margin-top: 1.6rem;
  gap: 1.2rem;
  display: flex;
  flex-wrap: wrap;
}

.user-settings .main-body .manage-subscription .current-subscription .button-group .button--cancel {
  color: var(--neutral-06);
}

.user-settings .main-body .manage-subscription .current-subscription .button-group .button--cancel:hover {
  color: white;
}

.user-settings .main-body .refer .referral-info,
.user-settings .main-body .refer h2 {
  margin-bottom: 2rem;
  font-size: 3.6rem;
}

.user-settings .main-body .refer .referral-link-box {
  display: flex;
  gap: 0.8rem;
  margin-bottom: 1.2rem;
  padding: 1.2rem;
}

@media (min-width: 450px) {
  .user-settings .main-body .refer .referral-link-box {
    padding: 2.4rem;
  }
}

.user-settings .main-body .refer .referral-link-box button {
  white-space: nowrap;
}

.user-settings .main-body .api .api-title {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid var(--color-border-light);
  margin-bottom: 3.2rem;
  padding-bottom: 2rem;
  gap: 1.6rem;
}

.user-settings .main-body .api .api-title a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--color-primary);
}

.user-settings .main-body .api .api-title a .icon {
  font-size: 13px;
}

.user-settings .main-body .api .api-balance .balance {
  display: flex;
  justify-content: space-between;
  margin-bottom: 2.4rem;
}

.user-settings .main-body .api .api-balance .balance span {
  display: block;
  font-weight: 600;
  font-size: 1.8rem;
}

.user-settings .main-body .api .api-balance .balance-deposit {
  display: flex;
  gap: 1.6rem;
  flex-direction: column;
}

.user-settings .main-body .api .api-key .input-wrapper {
  display: flex;
  gap: 0.8rem;
}

.user-settings .main-body .api .api-key .input-wrapper button {
  white-space: nowrap;
}

.user-settings .main-body .api .api-top {
  margin-bottom: 3.6rem;
}

.user-settings .main-body .api table td:last-child {
  color: var(--neutral-07);
}

.user-settings table {
  width: 100%;
  border-bottom: 1px solid var(--color-border-light);
  border-spacing: 0;
  overflow: hidden;
  border-collapse: separate;
}

.user-settings table th,
.user-settings table td {
  text-align: left;
  border-bottom: 1px solid var(--color-border-light);
  padding: 1.2rem 0;
}

.user-settings table th {
  font-size: 1.4rem;
  color: var(--neutral-06);
}

.user-settings table td {
  font-size: 1.4rem;
  color: var(--neutral-07);
}

.user-settings table td:last-child {
  color: var(--neutral-06);
}

.user-settings table tr:last-child td {
  border-bottom: none;
}

.user-settings table tr.disabled {
  opacity: 0.5;
  pointer-events: none;
}

[data-theme=dark] .header .button-start-new {
  background: var(--color-white);
}

[data-theme=dark] .header .button-start-new:hover {
  background: var(--color-primary);
}

/*# sourceMappingURL=app.min.css.map */
/* Item-wise Loading Styles */
.thumbnail-wrapper.is-loading {
  position: relative;
  cursor: pointer;
}

.thumbnail-loading-spinner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  border-radius: inherit;
}

.spinner-sm {
  width: 20px;
  height: 20px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.thumbnail-wrapper.is-loading.is-active {
  border: 2px solid var(--color-primary);
}

.thumbnail-wrapper.is-loading .icon-image-fill {
  opacity: 0.5;
}