/**
 * JackBot Toggle (Switch)
 *
 * A lightweight, accessible toggle control that fits the app's design.
 * Usage (with text):
 *   <div class="jb-toggle">
 *     <input class="jb-toggle-input" type="checkbox" id="id" name="name">
 *     <label class="jb-toggle-label" for="id">
 *       <span class="jb-toggle-control" aria-hidden="true"></span>
 *       <span class="jb-toggle-content">
 *         <span class="jb-toggle-title"><strong>Label</strong></span>
 *         <span class="jb-toggle-help">Help text</span>
 *       </span>
 *     </label>
 *   </div>
 *
 * Compact (control only):
 *   <div class="jb-toggle jb-toggle-compact">
 *     <input class="jb-toggle-input" type="checkbox" id="id2" name="name2">
 *     <label class="jb-toggle-label" for="id2">
 *       <span class="jb-toggle-control" aria-hidden="true"></span>
 *     </label>
 *   </div>
 */

@charset "UTF-8";

/* Design tokens come from assets/styles/styleguide/colors.css */

.jb-toggle {
  --jb-toggle-width: 44px;
  --jb-toggle-height: 24px;
  --jb-toggle-radius: 999px;
  --jb-toggle-track: var(--color-grey-dark);
  --jb-toggle-track-hover: #d7dbdf;
  --jb-toggle-track-on: var(--color-green);
  --jb-toggle-track-on-hover: #2fd496;
  --jb-toggle-thumb: #fff;
  --jb-toggle-focus: rgba(54, 224, 160, 0.35);

  display: block;
}

.jb-toggle-label {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  cursor: pointer;
  user-select: none;
}

/* Hide the native checkbox but keep it accessible */
.jb-toggle-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.jb-toggle-control {
  position: relative;
  width: var(--jb-toggle-width);
  height: var(--jb-toggle-height);
  border-radius: var(--jb-toggle-radius);
  background-color: var(--jb-toggle-track);
  transition: background-color .2s ease, box-shadow .2s ease;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .05);
}

.jb-toggle-control::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: calc(var(--jb-toggle-height) - 4px);
  height: calc(var(--jb-toggle-height) - 4px);
  border-radius: 50%;
  background-color: var(--jb-toggle-thumb);
  transition: transform .2s ease;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .15);
}

/* Hover state */
.jb-toggle-label:hover .jb-toggle-control {
  background-color: var(--jb-toggle-track-hover);
}

/* Checked state */
.jb-toggle-input:checked + .jb-toggle-label .jb-toggle-control {
  background-color: var(--jb-toggle-track-on);
}

.jb-toggle-input:checked + .jb-toggle-label:hover .jb-toggle-control {
  background-color: var(--jb-toggle-track-on-hover);
}

.jb-toggle-input:checked + .jb-toggle-label .jb-toggle-control::after {
  transform: translateX(calc(var(--jb-toggle-width) - var(--jb-toggle-height)));
}

/* Focus ring */
.jb-toggle-input:focus-visible + .jb-toggle-label .jb-toggle-control {
  box-shadow: 0 0 0 4px var(--jb-toggle-focus);
}

/* Disabled */
.jb-toggle-input[disabled] + .jb-toggle-label {
  opacity: .6;
  cursor: not-allowed;
}

.jb-toggle-content {
  display: inline-flex;
  flex-direction: column;
}

.jb-toggle-help {
  color: #6c757d; /* bootstrap secondary text */
  font-size: .875rem;
}

/* Compact variant for table rows */
.jb-toggle-compact .jb-toggle-label {
  gap: 0;
}

.jb-toggle-compact .jb-toggle-content {
  display: none;
}

/* Size variants */
.jb-toggle.jb-toggle-lg {
  --jb-toggle-width: 54px;
  --jb-toggle-height: 28px;
}

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

/* Small variant adjustments for better proportions */
.jb-toggle-sm .jb-toggle-control::after {
  left: 0;
}
