:root {
  --tikpink: #ec4899;
  --tikpink-50: #fdf2f8;
  --tikpink-100: #fce7f3;
  --tikpink-200: #fbcfe8;
  --tikpink-300: #f9a8d4;
  --tikpink-400: #f472b6;
  --tikpink-500: #ec4899;
  --tikpink-600: #db2777;
  --tikpink-700: #be185d;
  --tikpink-800: #9d174d;
  --tikpink-900: #831843;

  --tikcyan: #22d3ee;
  --tikcyan-50: #f0fdfa;
  --tikcyan-100: #ccfbf1;
  --tikcyan-200: #99f6e4;
  --tikcyan-300: #5eead4;
  --tikcyan-400: #2dd4bf;
  --tikcyan-500: #22d3ee;
  --tikcyan-600: #0891b2;
  --tikcyan-700: #0e7490;
  --tikcyan-800: #155e75;
  --tikcyan-900: #164e63;
}

.gradient-text {
  background: linear-gradient(to right, var(--tikpink), var(--tikcyan));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.glass-card {
  background: rgba(255, 255, 255, 0.8);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-radius: 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.dark .glass-card {
  background: rgba(17, 24, 39, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.glass-card:hover {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  transform: translateY(-2px);
}

.btn-primary {
  background: linear-gradient(to right, var(--tikpink), var(--tikcyan));
  color: #fff;
  padding: 0.625rem 1.25rem;
  border-radius: 0.75rem;
  font-weight: 500;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
  border: none;
  text-decoration: none;
  cursor: pointer;
}

.btn-primary:hover {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  transform: translateY(-2px);
}

.btn-secondary {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  padding: 0.625rem 1.25rem;
  border-radius: 0.75rem;
  font-weight: 500;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  transition: background 0.3s ease, transform 0.3s ease;
  text-decoration: none;
  cursor: pointer;
}

.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: translateY(-2px);
}

header.transparent {
  background-color: transparent;
}

header.scrolled {
  background-color: rgba(255, 255, 255, 0.8);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.dark header.scrolled {
  background-color: rgba(17, 24, 39, 0.8);
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-fade-in {
  animation: fadeIn 0.5s ease forwards;
}

#theme-toggle-button {
  width: auto;
  padding: 0.75rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 0.75rem;
  background: linear-gradient(to right, rgba(236, 72, 153, 0.1), rgba(34, 211, 238, 0.1));
  color: var(--tikpink);
  font-weight: 500;
  transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
  border: 1px solid rgba(236, 72, 153, 0.2);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
  cursor: pointer;
}

.dark #theme-toggle-button {
  background: linear-gradient(to right, rgba(236, 72, 153, 0.2), rgba(34, 211, 238, 0.2));
  color: var(--tikcyan);
  border: 1px solid rgba(34, 211, 238, 0.2);
}

#theme-toggle-button:hover {
  background: linear-gradient(to right, rgba(236, 72, 153, 0.2), rgba(34, 211, 238, 0.2));
  transform: translateY(-2px);
  box-shadow: 0 6px 10px -2px rgba(0, 0, 0, 0.1);
}

.dark #theme-toggle-button:hover {
  background: linear-gradient(to right, rgba(236, 72, 153, 0.3), rgba(34, 211, 238, 0.3));
}

#theme-toggle-button svg {
  width: 1.5rem;
  height: 1.5rem;
  fill: currentColor;
}

@media (max-width: 768px) {
  .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .grid-cols-1 {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 768px) {
  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.dark {
  color-scheme: dark;
}

.dark body {
  background-color: #111827;
  color: #f9fafb;
}

.swal2-html-container .captcha-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  width: clamp(260px, 90vw, 304px);
  min-height: 78px;
  position: relative;
  overflow: hidden;
  margin: 1em auto;
}

.swal2-html-container .captcha-wrapper>div {
  transform-origin: center center !important;
  transform: scale(calc(clamp(0.7, 100% / 304, 1))) !important;
  display: inline-block;
}

@media (max-width: 320px) {
  .swal2-html-container .captcha-wrapper>div {
    transform: scale(0.75) !important;
  }
}

@media (min-width: 321px) and (max-width: 380px) {
  .swal2-html-container .captcha-wrapper>div {
    transform: scale(0.85) !important;
  }
}

#svgLoaderContainerEl {
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.accordion-collapse {
  display: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.accordion-collapse.show {
  display: block;
}

.accordion-button {
  cursor: pointer;
  background-color: transparent;
  border: none;
  padding: 0.5rem 1rem;
  width: 100%;
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.accordion-button svg {
  transition: transform 0.3s ease;
  width: 1rem;
  height: 1rem;
}

.accordion-button.collapsed svg {
  transform: rotate(0deg);
}

.accordion-button:not(.collapsed) svg {
  transform: rotate(180deg);
}

.collapse {
  visibility: visible !important;
}

.accordion-collapse {
  display: none;
  transition: all 0.3s ease;
  visibility: visible !important;
}

.accordion-collapse.show {
  display: block;
}

.accordion-button {
  cursor: pointer;
}

.accordion-button svg {
  transition: transform 0.3s ease;
}

.accordion-button.collapsed svg {
  transform: rotate(0deg);
}

.accordion-button:not(.collapsed) svg {
  transform: rotate(180deg);
}

.collapse {
  visibility: visible !important;
}