* {
  border-color: hsl(var(--border))
}

*,
:before,
:after {
  --tw-ring-color: rgb(59 130 246 / .5);
  --tw-ring-inset: ;
  --tw-ring-offset-color: #fff;
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-offset-width: 0px;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
      --tw-shadow-colored: 0 0 #0000;
}

.bg-background {
  background-color: hsl(var(--background))
}

.bg-background\/50 {
  background-color: hsl(var(--background) / .5)
}

.bg-background\/80 {
  background-color: hsl(var(--background) / .8)
}

.bg-card\/50 {
  background-color: hsl(var(--card) / .5)
}

.bg-cyber-pink {
  background-color: hsl(var(--cyber-pink))
}

.bg-electric-blue {
  background-color: hsl(var(--electric-blue))
}

.bg-gradient-cyber {
  background-image: var(--gradient-cyber)
}

.bg-electric-purple {
  background-color: hsl(var(--electric-purple))
}

.bg-gradient-primary {
  background-image: var(--gradient-primary)
}

.bg-gradient-secondary {
  background-image: var(--gradient-secondary)
}

.bg-muted {
  background-color: hsl(var(--muted))
}

.bg-neon-green {
  background-color: hsl(var(--neon-green))
}

.bg-secondary {
  background-color: hsl(var(--secondary))
}

.border-border {
  border-color: hsl(var(--border))
}

.border-border\/30 {
  border-color: hsl(var(--border) / .3)
}

.border-electric-blue {
  border-color: hsl(var(--electric-blue))
}

.border-electric-blue\/30 {
  border-color: hsl(var(--electric-blue) / 0.3)
}

.border-cyber-pink {
  border-color: hsl(var(--cyber-pink))
}

.border-cyber-pink\/30 {
  border-color: hsl(var(--cyber-pink) / 0.3)
}

.border-electric-purple {
  border-color: hsl(var(--electric-purple))
}

.border-electric-purple\/30 {
  border-color: hsl(var(--electric-purple) / .3)
}

.border-neon-green {
  border-color: hsl(var(--neon-green))
}

.border-neon-green\/30 {
  border-color: hsl(var(--neon-green) / .3)
}

.border-transparent {
  border-color: transparent
}

.circuit-line {
  position: relative;
  overflow: hidden
}

.circuit-line:before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, hsl(var(--electric-blue)), transparent);
  animation: circuit-flow 3s linear infinite
}

.data-\[state\=active\]\:bg-background[data-state="active"] {
  background-color: hsl(var(--background));
}

.data-\[state\=active\]\:shadow-sm[data-state="active"] {
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.data-\[state\=active\]\:text-foreground[data-state="active"] {
  color: hsl(var(--foreground));
}

.disabled\:opacity-50:disabled {
  opacity: .5
}

.disabled\:pointer-events-none:disabled {
  pointer-events: none
}

.focus\:outline-none:focus {
  outline: 2px solid transparent;
  outline-offset: 2px
}

.focus\:ring-2:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)
}

.focus\:ring-ring:focus {
  --tw-ring-color: hsl(var(--ring))
}

.focus\:ring-offset-2:focus {
  --tw-ring-offset-width: 2px
}

.focus-visible\:ring-2:focus-visible {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)
}

.focus-visible\:ring-offset-2:focus-visible {
  --tw-ring-offset-width: 2px
}

.focus-visible\:ring-ring:focus-visible {
  --tw-ring-color: hsl(var(--ring))
}

.font-mono {
  font-family: JetBrains Mono, Monaco, Cascadia Code, Roboto Mono, monospace
}

.font-tech {
  font-family: Orbitron, Exo 2, Rajdhani, sans-serif
}

.glow-text {
  text-shadow: var(--glow-text)
}

.group:hover .group-hover\:opacity-100 {
  opacity: 1
}

.group:hover .group-hover\:scale-110 {
  --tw-scale-x: 1.1;
  --tw-scale-y: 1.1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.group:hover .group-hover\:text-electric-blue {
  color: hsl(var(--electric-blue))
}

.highlight-button {
  background-color: hsl(var(--electric-blue));
  color: hsl(var(--background));
  border: none;
  border-radius: 0.5rem;
  font-size: 1rem;
  font-weight: bold;
  box-shadow: 0 0 10px hsl(var(--electric-blue) / .6);
  cursor: pointer;
  transition: background 0.2s, box-shadow 0.2s, transform 0.1s;
}

.highlight-button:hover,
.highlight-button:focus {
  background-color: hsl(var(--neon-green));
  color: hsl(var(--background));
  box-shadow: 0 0 20px hsl(var(--neon-green) / .8), 0 0 30px hsl(var(--electric-blue) / .4);
  transform: scale(1.05);
  outline: none;
}

.hover\:bg-cyber-pink:hover {
  background-color: hsl(var(--cyber-pink))
}

.hover\:bg-cyber-pink\/10:hover {
  background-color: hsl(var(--cyber-pink) / 0.1)
}

.hover\:bg-electric-blue:hover {
  background-color: hsl(var(--electric-blue))
}

.hover\:bg-electric-blue\/10:hover {
  background-color: hsl(var(--electric-blue) / 0.1)
}

.hover\:bg-electric-purple:hover {
  background-color: hsl(var(--electric-purple))
}

.hover\:bg-electric-purple\/10:hover {
  background-color: hsl(var(--electric-purple) / .1)
}

.hover\:bg-neon-green:hover {
  background-color: hsl(var(--neon-green))
}

.hover\:bg-neon-green\/10:hover {
  background-color: hsl(var(--neon-green) / 0.1)
}

.hover\:bg-primary\/90:hover {
  background-color: hsl(var(--primary) / .9)
}

.hover\:bg-secondary\/10:hover {
  background-color: hsl(var(--secondary) / .1)
}

.hover\:bg-secondary\/80:hover {
  background-color: hsl(var(--secondary) / .8)
}

.hover\:border-electric-blue:hover {
  border-color: hsl(var(--electric-blue))
}

.hover\:border-neon-green:hover {
  border-color: hsl(var(--neon-green))
}

.hover\:shadow-glow-primary:hover {
  --tw-shadow: var(--glow-primary);
  --tw-shadow-colored: var(--glow-primary);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.hover\:shadow-glow-secondary:hover {
  --tw-shadow: var(--glow-secondary);
  --tw-shadow-colored: var(--glow-secondary);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.hover\:text-background:hover {
  color: hsl(var(--background))
}

.hover\:text-background:hover {
  color: hsl(var(--background))
}

.leading-relaxed {
  line-height: 1.625
}

.modal {
  display: none;
  position: fixed;
  z-index: 1000;
  padding-top: 100px;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgb(0,0,0);
  background-color: rgba(0,0,0,0.9);
}

.modal-caption {
  margin: auto;
  display: block;
  width: 80%;
  max-width: 700px;
  text-align: center;
  color: #ccc;
  padding: 10px 0;
  height: 150px;
}

.modal-close {
  position: absolute;
  top: 15px;
  right: 35px;
  color: #f1f1f1;
  font-size: 40px;
  font-weight: bold;
  transition: 0.3s;
}

.modal-close:hover,
.modal-close:focus {
  color: #bbb;
  text-decoration: none;
  cursor: pointer;
}

.modal-content {
  margin: auto;
  display: block;
  width: 80%;
  max-width: 700px;
  animation-name: zoom;
  animation-duration: 0.6s;
}

.opacity-60 {
  opacity: .6
}

.placeholder\:text-muted-foreground::-moz-placeholder {
  color: hsl(var(--muted-foreground))
}

.placeholder\:text-muted-foreground::placeholder {
  color: hsl(var(--muted-foreground))
}

.pulse-glow {
  animation: pulse-glow 2s ease-in-out infinite alternate
}

.ring-offset-background {
  --tw-ring-offset-color: hsl(var(--background))
}

.space-y-6>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse))
}

.space-y-8>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(2rem * var(--tw-space-y-reverse))
}

.text-card-foreground {
  color: hsl(var(--card-foreground))
}

.text-cyber-pink {
  color: hsl(var(--cyber-pink))
}

.text-electric-blue {
  color: hsl(var(--electric-blue))
}

.text-electric-purple {
  color: hsl(var(--electric-purple))
}

.text-foreground {
  color: hsl(var(--foreground))
}

.text-foreground\/70 {
  color: hsl(var(--foreground) / .7)
}

.text-foreground\/90 {
  color: hsl(var(--foreground) / .9)
}

.text-muted-foreground {
  color: hsl(var(--muted-foreground))
}

.text-neon-green {
  color: hsl(var(--neon-green))
}

.text-primary-foreground {
  color: hsl(var(--primary-foreground))
}

.text-secondary-foreground {
  color: hsl(var(--secondary-foreground))
}

.text-stroke {
  text-shadow: -1px -1px 0 rgba(0, 0, 0, .8),
    1px -1px 0 rgba(0, 0, 0, .8),
    -1px 1px 0 rgba(0, 0, 0, .8),
    1px 1px 0 rgba(0, 0, 0, .8),
    -1px 0 0 rgba(0, 0, 0, .8),
    1px 0 0 rgba(0, 0, 0, .8),
    0 -1px 0 rgba(0, 0, 0, .8),
    0 1px 0 rgba(0, 0, 0, .8)
}

.text-transparent {
  color: transparent
}

.tracking-tight {
  letter-spacing: -.025em
}

.tracking-wider {
  letter-spacing: .05em
}

.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-duration: .15s
}

.transition-opacity {
  transition-property: opacity;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-duration: .15s
}

:root {
  --background: 222 84% 4.9%;
  --border: 225 25% 15%;
  --card-foreground: 0 0% 98%;
  --card: 225 25% 8%;
  --cyber-pink: 320 100% 70%;
  --electric-blue: 195 100% 50%;
  --electric-purple: 270 100% 70%;
  --foreground: 0 0% 98%;
  --glow-primary: 0 0 20px hsl(var(--electric-blue) / .5);
  --glow-secondary: 0 0 20px hsl(var(--neon-green) / .5);
  --glow-text: 0 0 10px hsl(var(--electric-blue) / .8);
  --gradient-cyber: linear-gradient(45deg, hsl(var(--electric-blue)), hsl(var(--neon-green)), hsl(var(--electric-purple)));
  --gradient-primary: linear-gradient(135deg, hsl(var(--electric-blue)), hsl(var(--electric-purple)));
  --gradient-secondary: linear-gradient(135deg, hsl(var(--neon-green)), hsl(var(--electric-blue)));
  --muted-foreground: 215 20.2% 65.1%;
  --muted: 225 25% 12%;
  --neon-green: 120 100% 55%;
  --primary-foreground: 222 84% 4.9%;
  --ring: 195 100% 50%;
  --secondary-foreground: 222 84% 4.9%;
  --secondary: 120 100% 55%;
}

@keyframes circuit-flow {
  0% {
    left: -100%
  }

  to {
    left: 100%
  }
}

@keyframes pulse-glow {
  0% {
    box-shadow: 0 0 5px hsl(var(--electric-blue) / .5)
  }

  to {
    box-shadow: 0 0 20px hsl(var(--electric-blue) / .8), 0 0 30px hsl(var(--electric-blue) / .4)
  }
}

@keyframes zoom {
  from {transform:scale(0)}
  to {transform:scale(1)}
}

body {
  margin: 0;
  background-color: hsl(var(--background));
  font-family: JetBrains Mono, Monaco, Cascadia Code, Roboto Mono, monospace;
  color: hsl(var(--foreground));
}

body.withbackground {
  background-image: url(circuit-background.webp);
  background-size: cover;
  background-attachment: fixed;
  background-position: center;
}

html,
:host {
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -moz-tab-size: 4;
  -o-tab-size: 4;
  tab-size: 4;
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
  font-feature-settings: normal;
  font-variation-settings: normal;
  -webkit-tap-highlight-color: transparent
}