/* ─────────────────────────────────────────────────────────────────────────
   AccessKit Pro – Widget CSS  v1.0.2
   ───────────────────────────────────────────────────────────────────────── */

:root {
  --ak-color: #1a56db;
  --ak-font-scale: 1;
  --ak-panel-width: 400px;
  --ak-panel-bg: #ffffff;
  --ak-panel-radius: 16px;
  --ak-shadow: 0 12px 48px rgba(0,0,0,.16), 0 2px 8px rgba(0,0,0,.08);
  --ak-text: #111827;
  --ak-text-secondary: #6b7280;
  --ak-border: #e5e7eb;
  --ak-module-bg: #f9fafb;
  --ak-module-radius: 10px;
  --ak-z: 2147483647;
}

/* ── Root ────────────────────────────────────────────────────────────────── */
.ak-root {
  position: fixed !important;
  z-index: var(--ak-z) !important;
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', Roboto, Arial, sans-serif !important;
  font-size: 14px !important;
  line-height: normal !important;
  box-sizing: border-box !important;
  color: var(--ak-text) !important;
}

/* Positions */
.ak-pos-bottom-right { bottom: 24px !important; right: 24px !important; }
.ak-pos-bottom-left  { bottom: 24px !important; left: 24px !important; }
.ak-pos-top-right    { top: 80px !important; right: 24px !important; }
.ak-pos-top-left     { top: 80px !important; left: 24px !important; }
.ak-pos-middle-right { top: 50% !important; right: 0 !important; transform: translateY(-50%) !important; }
.ak-pos-middle-left  { top: 50% !important; left: 0 !important; transform: translateY(-50%) !important; }

/* Children reset */
.ak-root *, .ak-root *::before, .ak-root *::after {
  box-sizing: border-box !important;
  font-family: inherit !important;
  font-size: revert !important;
  line-height: revert !important;
  letter-spacing: normal !important;
  animation: none !important;
  text-transform: none !important;
}

/* ── Open Button ─────────────────────────────────────────────────────────── */
#ak-open-btn {
  width: 56px !important;
  height: 56px !important;
  border-radius: 50% !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #ffffff !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.25), 0 1px 4px rgba(0,0,0,.15) !important;
  transition: transform .15s ease, box-shadow .15s ease !important;
  position: relative !important;
  z-index: 2 !important;
  padding: 0 !important;
  overflow: visible !important;
  margin: 0 !important;
}
#ak-open-btn svg {
  display: block !important;
  width: 26px !important;
  height: 26px !important;
  fill: #ffffff !important;
  pointer-events: none !important;
  flex-shrink: 0 !important;
}
#ak-open-btn:hover  { transform: scale(1.07) !important; box-shadow: 0 6px 24px rgba(0,0,0,.3) !important; }
#ak-open-btn:focus  { outline: 3px solid #000 !important; outline-offset: 3px !important; }
#ak-open-btn:active { transform: scale(.96) !important; }

/* ── Panel ────────────────────────────────────────────────────────────────── */
#ak-panel {
  position: absolute !important;
  width: var(--ak-panel-width) !important;
  /* FIX: use max-height with overflow so sticky header works */
  max-height: 85vh !important;
  overflow: hidden !important;
  display: none !important;
  flex-direction: column !important;
  background: #ffffff !important;
  border-radius: var(--ak-panel-radius) !important;
  box-shadow: var(--ak-shadow) !important;
  border: 1px solid var(--ak-border) !important;
}
#ak-panel:focus { outline: none !important; }
#ak-panel.ak-panel--open { display: flex !important; }

/* Panel positions */
.ak-pos-bottom-right #ak-panel,
.ak-pos-bottom-left  #ak-panel { bottom: 68px !important; }
.ak-pos-top-right    #ak-panel,
.ak-pos-top-left     #ak-panel { top: 68px !important; }
.ak-pos-middle-right #ak-panel { right: 64px !important; bottom: 0 !important; }
.ak-pos-middle-left  #ak-panel { left: 64px !important; bottom: 0 !important; }
.ak-pos-bottom-right #ak-panel,
.ak-pos-top-right    #ak-panel { right: 0 !important; }
.ak-pos-bottom-left  #ak-panel,
.ak-pos-top-left     #ak-panel { left: 0 !important; }

/* ── Panel Header — sticky inside panel ──────────────────────────────────── */
.ak-panel__header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 16px 18px 14px !important;
  border-bottom: 1px solid var(--ak-border) !important;
  /* FIX for sticky-jump: header is NOT scrolled, body scrolls separately */
  flex-shrink: 0 !important;
  background: #ffffff !important;
  border-radius: var(--ak-panel-radius) var(--ak-panel-radius) 0 0 !important;
  gap: 10px !important;
}
.ak-panel__title {
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--ak-text) !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  letter-spacing: -.01em !important;
}
.ak-panel__header-btns {
  display: flex !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
}
.ak-btn-reset,
.ak-btn-close {
  border: 1px solid var(--ak-border) !important;
  background: transparent !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  padding: 5px 10px !important;
  color: #374151 !important;
  transition: background .12s, border-color .12s !important;
  white-space: nowrap !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}
.ak-btn-reset:hover, .ak-btn-close:hover {
  background: #f3f4f6 !important;
  color: #111827 !important;
  border-color: #d1d5db !important;
}
.ak-btn-reset:focus, .ak-btn-close:focus {
  outline: 2px solid var(--ak-color) !important;
  outline-offset: 2px !important;
}

/* ── Panel Body — this scrolls, not the whole panel ────────────────────────
   FIX for sticky-jump bug: overflow-y only on .ak-panel__body, not on #ak-panel */
.ak-panel__body {
  padding: 16px !important;
  flex: 1 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
}

/* ── Groups ───────────────────────────────────────────────────────────────── */
.ak-group { margin-bottom: 20px !important; }
.ak-group:last-child { margin-bottom: 0 !important; }
.ak-group__title {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  color: #9ca3af !important;
  margin: 0 0 10px 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

/* ── Module Grid — equal sized boxes ─────────────────────────────────────── */
.ak-group__grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}

/* ── Module Button ────────────────────────────────────────────────────────── */
.ak-module {
  background: var(--ak-module-bg) !important;
  border: 1.5px solid #e5e7eb !important;
  border-radius: var(--ak-module-radius) !important;
  /* Equal height boxes: stretch via grid + padding */
  padding: 14px 12px !important;
  cursor: pointer !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #374151 !important;
  text-align: left !important;
  min-height: 52px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  transition: background .12s, border-color .12s, color .12s !important;
  line-height: 1.3 !important;
  width: 100% !important;
  /* stretch to fill grid cell height */
  align-self: stretch !important;
}
.ak-module:hover {
  background: #f0f3ff !important;
  border-color: #c7d4ff !important;
  color: #1e40af !important;
}
.ak-module:focus {
  outline: 2px solid var(--ak-color) !important;
  outline-offset: 2px !important;
  color: #1e40af !important;
}
.ak-module--on {
  font-weight: 600 !important;
}
.ak-module__label {
  pointer-events: none !important;
  display: block !important;
}

/* ── Slider — full width ──────────────────────────────────────────────────── */
.ak-module--slider {
  grid-column: 1 / -1 !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 8px !important;
  cursor: default !important;
  min-height: unset !important;
}
.ak-module--slider:hover {
  background: var(--ak-module-bg) !important;
  border-color: #e5e7eb !important;
  color: #374151 !important;
}
.ak-slider__row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.ak-slider {
  flex: 1 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  height: 4px !important;
  border-radius: 2px !important;
  background: #e5e7eb !important;
  cursor: pointer !important;
  accent-color: var(--ak-color) !important;
}
.ak-slider::-webkit-slider-thumb {
  -webkit-appearance: none !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  background: var(--ak-color) !important;
  cursor: pointer !important;
  border: 2px solid #fff !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.2) !important;
}
.ak-slider:focus { outline: 2px solid var(--ak-color) !important; outline-offset: 4px !important; }
.ak-slider__val {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #374151 !important;
  min-width: 40px !important;
  text-align: right !important;
}
.ak-slider__reset {
  border: 1px solid var(--ak-border) !important;
  background: transparent !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  font-size: 13px !important;
  padding: 3px 7px !important;
  color: #6b7280 !important;
  line-height: 1 !important;
}
.ak-slider__reset:hover { background: #f3f4f6 !important; color: #111 !important; }
.ak-slider__reset:focus { outline: 2px solid var(--ak-color) !important; }

/* ── Panel Footer ─────────────────────────────────────────────────────────── */
.ak-panel__footer {
  padding: 12px 18px !important;
  border-top: 1px solid var(--ak-border) !important;
  /* column layout: powered-by on top-left, statement below */
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 6px !important;
  font-size: 11px !important;
  color: #9ca3af !important;
  flex-shrink: 0 !important;
  background: #ffffff !important;
  border-radius: 0 0 var(--ak-panel-radius) var(--ak-panel-radius) !important;
}
/* Statement link — left aligned, full width */
.ak-statement-link {
  color: #6b7280 !important;
  text-decoration: underline !important;
  font-size: 11px !important;
  text-align: left !important;
  display: block !important;
}
.ak-statement-link:hover { color: var(--ak-color) !important; }
.ak-statement-link:focus { outline: 2px solid var(--ak-color) !important; }
/* "Powered by digitaleformate" — left aligned */
.ak-powered-by {
  color: #9ca3af !important;
  font-size: 11px !important;
  display: block !important;
  text-align: left !important;
}
.ak-powered-by a {
  color: #6b7280 !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}
.ak-powered-by a:hover { color: var(--ak-color) !important; text-decoration: underline !important; }

/* ── Text Magnifier ──────────────────────────────────────────────────────── */
#ak-magnifier {
  position: fixed !important;
  background: #1f2937 !important;
  color: #f9fafb !important;
  font-size: 17px !important;
  padding: 10px 14px !important;
  border-radius: 10px !important;
  max-width: 260px !important;
  z-index: calc(var(--ak-z) - 1) !important;
  pointer-events: none !important;
  line-height: 1.5 !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.25) !important;
  word-break: break-word !important;
}

/* ── Reading Mask ─────────────────────────────────────────────────────────── */
.ak-reading-mask {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  background: rgba(0,0,0,.65) !important;
  pointer-events: none !important;
  z-index: calc(var(--ak-z) - 2) !important;
}
.ak-reading-mask--top    { top: 0 !important; }
.ak-reading-mask--bottom { bottom: 0 !important; }

/* ═══════════════════════════════════════════════════════════════════════════
   BODY EFFECT CLASSES
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Font Scale — FIX: target actual text elements including Elementor ─────
   Using font-size directly on elements rather than html root
   to ensure Elementor widgets, custom CSS etc. all get scaled */
body.ak-font-scaled *:not(#accesskit-root):not(#accesskit-root *):not(script):not(style):not(svg):not(path) {
  font-size: calc(1em * var(--ak-font-scale, 1)) !important;
}
/* Exempt the widget itself always */
#accesskit-root, #accesskit-root * { font-size: revert !important; }

/* ── Contrast ─────────────────────────────────────────────────────────────── */
/* FIX for sticky: apply filter to body children, NOT to body itself —
   body-level filter creates a new stacking context that breaks position:fixed */
body.ak-dark-contrast > *:not(#accesskit-root):not(.ak-reading-mask):not(#ak-magnifier) {
  filter: invert(1) hue-rotate(180deg) !important;
}
body.ak-dark-contrast > *:not(#accesskit-root) img,
body.ak-dark-contrast > *:not(#accesskit-root) video { filter: invert(1) hue-rotate(180deg) !important; }

body.ak-light-contrast > *:not(#accesskit-root):not(.ak-reading-mask):not(#ak-magnifier) {
  filter: brightness(1.12) contrast(1.08) !important;
}

body.ak-high-contrast > *:not(#accesskit-root):not(.ak-reading-mask):not(#ak-magnifier) {
  filter: contrast(2) saturate(1.5) !important;
}

body.ak-monochrome > *:not(#accesskit-root):not(.ak-reading-mask):not(#ak-magnifier) {
  filter: grayscale(1) !important;
}

/* ── Hide Images ─────────────────────────────────────────────────────────── */
body.ak-hide-images img:not(#accesskit-root img),
body.ak-hide-images video:not(#accesskit-root video),
body.ak-hide-images figure:not(#accesskit-root figure) { visibility: hidden !important; }

/* ── Readable Font ───────────────────────────────────────────────────────── */
body.ak-readable-font *:not(#accesskit-root):not(#accesskit-root *) {
  font-family: Georgia, 'Times New Roman', serif !important;
}

/* ── Dyslexia Font ───────────────────────────────────────────────────────── */
body.ak-dyslexia-font *:not(#accesskit-root):not(#accesskit-root *) {
  font-family: 'Comic Sans MS', 'Arial Rounded MT Bold', cursive !important;
}

/* ── Bold text ───────────────────────────────────────────────────────────── */
body.ak-bold-text *:not(#accesskit-root):not(#accesskit-root *) { font-weight: 700 !important; }

/* ── Highlight Links ─────────────────────────────────────────────────────── */
body.ak-highlight-links a:not(#accesskit-root a) {
  background: #fef08a !important;
  color: #1a1a1a !important;
  text-decoration: underline !important;
  border-radius: 2px !important;
  padding: 0 2px !important;
}

/* ── Highlight Titles ────────────────────────────────────────────────────── */
body.ak-highlight-titles h1:not(#accesskit-root h1),
body.ak-highlight-titles h2:not(#accesskit-root h2),
body.ak-highlight-titles h3:not(#accesskit-root h3),
body.ak-highlight-titles h4:not(#accesskit-root h4),
body.ak-highlight-titles h5:not(#accesskit-root h5),
body.ak-highlight-titles h6:not(#accesskit-root h6) {
  outline: 2px solid #1a56db !important;
  padding: 4px 8px !important;
  border-radius: 4px !important;
}

/* ── Big Cursor ──────────────────────────────────────────────────────────── */
body.ak-big-cursor * {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 24 24'%3E%3Cpath d='M4 0 L4 20 L8 16 L12 24 L14 23 L10 15 L16 15 Z' fill='black' stroke='white' stroke-width='1'/%3E%3C/svg%3E") 0 0, auto !important;
}

/* ── Stop Animations ─────────────────────────────────────────────────────── */
body.ak-stop-animations *:not(#accesskit-root):not(#accesskit-root *)::before,
body.ak-stop-animations *:not(#accesskit-root):not(#accesskit-root *)::after {
  animation-duration: 0.001ms !important;
  animation-iteration-count: 1 !important;
  transition-duration: 0.001ms !important;
}
body.ak-stop-animations *:not(#accesskit-root):not(#accesskit-root *) {
  animation-duration: 0.001ms !important;
  animation-iteration-count: 1 !important;
  transition-duration: 0.001ms !important;
  scroll-behavior: auto !important;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 440px) {
  :root { --ak-panel-width: calc(100vw - 32px); }
}

/* ── WordPress admin bar ─────────────────────────────────────────────────── */
.admin-bar .ak-pos-top-right,
.admin-bar .ak-pos-top-left { top: 112px !important; }

/* ── Hide Images — Elementor background images (JS-handled, CSS fallback) ── */
body.ak-hide-images .elementor-background-overlay,
body.ak-hide-images [class*="elementor-"][style*="background-image"],
body.ak-hide-images .elementor-widget-image,
body.ak-hide-images .elementor-image,
body.ak-hide-images .elementor-carousel img,
body.ak-hide-images [style*="background-image"]:not(#accesskit-root):not(#accesskit-root *) {
  visibility: hidden !important;
}
/* Also zero out the background-image property for overlays via opacity */
body.ak-hide-images .elementor-background-overlay {
  opacity: 0 !important;
  visibility: hidden !important;
}
