/* ── Klaro modal — Label as positioning context for switch ── */

/* Li: zero padding (label handles spacing now) */
#klaro .cookie-modal li.cm-purpose {
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-bottom: 16px !important;
}

/* Label: flex, full-width, positioning context, reserves space for switch */
#klaro .cookie-modal .cm-list-label {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  width: 100% !important;
  position: relative !important;
  padding-right: 56px !important;
  box-sizing: border-box !important;
}

/* Required label: no right padding (switch is hidden, "Required" needs full width) */
#klaro .cm-list-input.required + .cm-list-label {
  padding-right: 0 !important;
}

/* Prevent modal overflow */
#klaro .cookie-modal .cm-modal {
  overflow: hidden !important;
}

/* ── Title: fills remaining space, bold ── */
#klaro .cookie-modal .cm-list-label .cm-list-title {
  flex: 1 0 0 !important;
  font-family: 'Fraunces', serif !important;
  font-weight: 700 !important;
  font-size: 20px !important;
  line-height: 1.4 !important;
  letter-spacing: -0.2px !important;
  color: #07050c !important;
}

/* ── Required text: compact, pushed right by title flex ── */
#klaro .cookie-modal .cm-list-label .cm-required {
  flex-shrink: 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  line-height: 1.5 !important;
  color: #07050c !important;
  padding: 0 !important;
}

/* ── Switch: absolute within LABEL, right edge, vertically centered ── */
#klaro .cookie-modal .cm-list-label .cm-switch {
  position: absolute !important;
  left: auto !important;
  right: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

/* ── Required purposes: hide toggle, show "Required" text ── */
#klaro .cm-list-input.required + .cm-list-label .cm-switch {
  display: none !important;
}
#klaro .cm-list-input.required + .cm-list-label .cm-required {
  font-size: 0 !important;
}
#klaro .cm-list-input.required + .cm-list-label .cm-required::after {
  content: 'Required';
  font-size: 16px;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  line-height: 1.5;
  color: #07050c;
}

/* ── Toggle switch restyling (Figma specs: 40×24px) ── */
#klaro .cookie-modal .cm-switch {
  width: 40px !important;
  height: 24px !important;
}
#klaro .cookie-modal .cm-list-label .slider {
  background-color: transparent !important;
  border: 1px solid rgba(7, 5, 12, 0.15) !important;
  width: 40px !important;
  height: 24px !important;
  border-radius: 500px !important;
  transition: background-color 0.2s, border-color 0.2s !important;
}
#klaro .cookie-modal .cm-list-label .slider::before {
  background-color: #07050c !important;
  width: 16px !important;
  height: 16px !important;
  left: 3px !important;
  bottom: 3px !important;
  border-radius: 50% !important;
  transition: transform 0.2s, background-color 0.2s !important;
}
#klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider {
  background-color: #07050c !important;
  border-color: #07050c !important;
}
#klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider::before {
  background-color: #ffffff !important;
  transform: translateX(16px) !important;
}
#klaro .cookie-modal .cm-list-input.required:checked + .cm-list-label .slider {
  background-color: #07050c !important;
  opacity: 1 !important;
}
