:root {
  --klaro-neon-yellow: #DFFF00;
  --klaro-neon-pink: #FF10F0;
  --klaro-black: #000000;
  --klaro-white: #FFFFFF;
  --klaro-pink-glow: rgba(255, 16, 240, 0.3);
  --klaro-yellow-glow: rgba(223, 255, 0, 0.3);
}

#klaro * {
  font-family: var(--font-geist-sans, 'Geist', 'Inter', 'Helvetica Neue', Arial, sans-serif);
}

/* Modal Styling */
#klaro .cm-modal {
  max-width: 420px;
  border-radius: 16px;
  background: var(--klaro-black);
  border: 2px solid var(--klaro-neon-pink);
  box-shadow: 0 0 30px var(--klaro-pink-glow), 0 20px 45px rgba(0, 0, 0, 0.8);
  color: var(--klaro-white);
}

#klaro .cm-header h1 {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--klaro-neon-yellow);
  text-shadow: 0 0 10px var(--klaro-yellow-glow);
}

#klaro .cm-intro {
  color: var(--klaro-white);
  font-size: 0.9rem;
  opacity: 0.9;
}

#klaro .cm-list-title {
  font-weight: 600;
  color: var(--klaro-neon-yellow);
}

#klaro .cm-list-description {
  color: var(--klaro-white);
  font-size: 0.85rem;
  opacity: 0.8;
}

#klaro .cm-footer {
  border-top: 1px solid var(--klaro-neon-pink);
}

/* Toggle Switches */
#klaro .cm-switch:not(.cm-required) input:checked + .cm-slider {
  background-color: var(--klaro-neon-pink);
  box-shadow: 0 0 10px var(--klaro-pink-glow);
}

#klaro .cm-switch:not(.cm-required) input:focus-visible + .cm-slider {
  box-shadow: 0 0 0 3px var(--klaro-pink-glow);
}

#klaro .cm-switch .cm-slider {
  background-color: rgba(255, 255, 255, 0.2);
}

/* Cookie Notice (Bottom Banner) */
#klaro .cookie-notice {
  border-radius: 16px;
  background: var(--klaro-black);
  max-width: 380px;
  box-shadow: 0 0 30px var(--klaro-pink-glow), 0 18px 40px rgba(0, 0, 0, 0.8);
  border: 2px solid var(--klaro-neon-pink);
  color: var(--klaro-white);
}

#klaro .cookie-notice-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--klaro-neon-yellow);
  text-shadow: 0 0 10px var(--klaro-yellow-glow);
}

#klaro .cookie-notice-description {
  color: var(--klaro-white);
  font-size: 0.88rem;
  opacity: 0.9;
}

/* Button Container - Vertical Stack */
#klaro .cm-footer-buttons,
#klaro .cookie-notice-buttons {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.75rem !important;
  width: 100%;
}

/* Buttons */
#klaro .cm-btn {
  border-radius: 9999px;
  font-weight: 600;
  padding: 0.65rem 1.5rem !important;
  transition: all 0.3s ease;
  border: 2px solid;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  width: 100% !important;
  display: block !important;
  text-align: center;
}

/* Accept Button - Neon Yellow */
#klaro .cm-btn.cm-btn-success,
#klaro .cm-btn.cm-btn-accept {
  background-color: var(--klaro-neon-yellow);
  border-color: var(--klaro-neon-yellow);
  color: var(--klaro-black);
  box-shadow: 0 0 15px var(--klaro-yellow-glow);
}

#klaro .cm-btn.cm-btn-success:hover,
#klaro .cm-btn.cm-btn-accept:hover {
  background-color: var(--klaro-neon-yellow);
  border-color: var(--klaro-neon-yellow);
  box-shadow: 0 0 25px var(--klaro-yellow-glow), 0 5px 20px rgba(223, 255, 0, 0.4);
  transform: translateY(-2px);
}

/* Decline Button - Neon Pink */
#klaro .cm-btn.cm-btn-decline {
  background-color: transparent;
  color: var(--klaro-neon-pink);
  border-color: var(--klaro-neon-pink);
  box-shadow: 0 0 15px var(--klaro-pink-glow);
}

#klaro .cm-btn.cm-btn-decline:hover {
  background-color: var(--klaro-neon-pink);
  color: var(--klaro-black);
  box-shadow: 0 0 25px var(--klaro-pink-glow), 0 5px 20px rgba(255, 16, 240, 0.4);
  transform: translateY(-2px);
}

/* Info/Learn More Button - White outline */
#klaro .cm-btn.cm-btn-info {
  background-color: transparent;
  color: var(--klaro-white);
  border-color: var(--klaro-white);
}

#klaro .cm-btn.cm-btn-info:hover {
  background-color: var(--klaro-white);
  color: var(--klaro-black);
  transform: translateY(-2px);
}

/* Links */
#klaro a {
  color: var(--klaro-neon-pink);
  text-decoration: none;
  transition: color 0.2s ease;
}

#klaro a:hover {
  color: var(--klaro-neon-yellow);
  text-shadow: 0 0 10px var(--klaro-yellow-glow);
}

/* Button Spacing - Override default horizontal spacing */
#klaro .cm-footer-buttons .cm-btn + .cm-btn,
#klaro .cookie-notice-buttons .cm-btn + .cm-btn {
  margin-left: 0 !important;
  margin-top: 0 !important;
}

/* Mobile Responsive */
@media (max-width: 640px) {
  #klaro .cm-modal {
    margin: 1.5rem;
    max-width: calc(100% - 3rem);
  }

  #klaro .cookie-notice {
    margin: 1.5rem;
    max-width: calc(100% - 3rem);
  }

  #klaro .cm-btn {
    font-size: 0.8rem;
    padding: 0.6rem 1.2rem !important;
  }
}

/* Scrollbar Styling */
#klaro .cm-modal ::-webkit-scrollbar {
  width: 8px;
}

#klaro .cm-modal ::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}

#klaro .cm-modal ::-webkit-scrollbar-thumb {
  background: var(--klaro-neon-pink);
  border-radius: 10px;
  box-shadow: 0 0 10px var(--klaro-pink-glow);
}

#klaro .cm-modal ::-webkit-scrollbar-thumb:hover {
  background: var(--klaro-neon-yellow);
  box-shadow: 0 0 10px var(--klaro-yellow-glow);
}
