/* mt-a11y - Accessibility Widget Styles
   Polished light theme with isolated typography */

/* ============================================================
   CSS CUSTOM PROPERTIES
   ============================================================ */
:root {
  --mt-a11y-accent: #002654;
  --mt-a11y-accent-contrast: #ffffff;
  --mt-a11y-ui-bg: #f8fafc;
  --mt-a11y-ui-surface: #ffffff;
  --mt-a11y-ui-surface-muted: #f1f5f9;
  --mt-a11y-ui-text: #111827;
  --mt-a11y-ui-muted: #64748b;
  --mt-a11y-ui-border: rgba(15, 23, 42, 0.12);
  --mt-a11y-ui-shadow: 0 18px 42px rgba(15, 23, 42, 0.16);
  --mt-a11y-font-scale: 1;
  --mt-a11y-font-family: inherit;
  --mt-a11y-link-highlight-bg: rgba(255, 230, 120, 0.35);
  --mt-a11y-cursor-large: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cpath d='M4 2l9 22 3-9 9-3L4 2z' fill='%23000' stroke='%23fff' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E") 2 2, auto;
  --mt-a11y-cursor-xl: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 48 48'%3E%3Cpath d='M6 3l13 32 4-12 12-4L6 3z' fill='%23000' stroke='%23fff' stroke-width='2' stroke-linejoin='round'/%3E%3C/svg%3E") 3 3, auto;
}

@media (prefers-color-scheme: dark) {
  html[data-mt-a11y-theme="auto"] {
    --mt-a11y-ui-bg: #111827;
    --mt-a11y-ui-surface: #1f2937;
    --mt-a11y-ui-surface-muted: #273449;
    --mt-a11y-ui-text: #f9fafb;
    --mt-a11y-ui-muted: #cbd5e1;
    --mt-a11y-ui-border: rgba(255, 255, 255, 0.16);
    --mt-a11y-ui-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
  }
}

html[data-bs-theme="dark"][data-mt-a11y-theme="auto"],
html[data-mt-a11y-theme="dark"] {
  --mt-a11y-ui-bg: #111827;
  --mt-a11y-ui-surface: #1f2937;
  --mt-a11y-ui-surface-muted: #273449;
  --mt-a11y-ui-text: #f9fafb;
  --mt-a11y-ui-muted: #cbd5e1;
  --mt-a11y-ui-border: rgba(255, 255, 255, 0.16);
  --mt-a11y-ui-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
  color-scheme: dark;
}

/* ============================================================
   FONT FACES
   ============================================================ */
@font-face {
  font-family: "OpenDyslexic";
  src: url("../Fonts/OpenDyslexic/OpenDyslexic-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "OpenDyslexic";
  src: url("../Fonts/OpenDyslexic/OpenDyslexic-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "OpenDyslexic";
  src: url("../Fonts/OpenDyslexic/OpenDyslexic-Italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "OpenDyslexic";
  src: url("../Fonts/OpenDyslexic/OpenDyslexic-BoldItalic.woff2") format("woff2");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

/* ============================================================
   FONT SCALE (applied to page)
   ============================================================ */
html {
  font-size: calc(100% * var(--mt-a11y-font-scale, 1));
}

/* ============================================================
   UI TYPOGRAPHY (isolated, cannot be overridden by page CSS)
   ============================================================ */
#mt-a11y-panel,
.mt-a11y-panel,
.mt-a11y-launcher {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  letter-spacing: 0 !important;
  word-spacing: 0 !important;
  text-transform: none !important;
  font-style: normal !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

#mt-a11y-panel *,
.mt-a11y-panel *,
.mt-a11y-launcher * {
  font-family: inherit !important;
  letter-spacing: inherit !important;
  word-spacing: inherit !important;
  text-transform: inherit !important;
}

/* ============================================================
   LAUNCHER BUTTON
   ============================================================ */
.mt-a11y-launcher {
  position: fixed !important;
  right: 20px !important;
  bottom: 20px !important;
  z-index: 99999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 52px !important;
  height: 52px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 50% !important;
  border: 2px solid #2563eb !important;
  background: #fff !important;
  color: #2563eb !important;
  cursor: pointer !important;
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25), 0 2px 4px rgba(0, 0, 0, 0.08) !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease !important;
}

.mt-a11y-launcher svg {
  width: 26px !important;
  height: 26px !important;
}

.mt-a11y-launcher:hover {
  transform: scale(1.05) !important;
  box-shadow: 0 6px 16px rgba(37, 99, 235, 0.3), 0 3px 6px rgba(0, 0, 0, 0.1) !important;
}

.mt-a11y-launcher:focus-visible {
  outline: 3px solid #2563eb !important;
  outline-offset: 3px !important;
}

/* ============================================================
   PANEL CONTAINER
   ============================================================ */
.mt-a11y-panel {
  position: fixed !important;
  right: 20px !important;
  bottom: 84px !important;
  z-index: 99999 !important;
  width: min(360px, calc(100vw - 40px)) !important;
  max-height: 75vh !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  border-radius: 16px !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  background: #fafbfc !important;
  color: #1f2937 !important;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12), 0 8px 16px rgba(0, 0, 0, 0.08) !important;
  padding: 0 !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

.mt-a11y-panel[hidden] {
  display: none !important;
}

.mt-a11y-panel--anchored {
  top: var(--mt-a11y-panel-top) !important;
  right: var(--mt-a11y-panel-right) !important;
  bottom: var(--mt-a11y-panel-bottom) !important;
  max-height: min(75vh, calc(100vh - var(--mt-a11y-panel-top) - 20px)) !important;
}

/* ============================================================
   HEADER
   ============================================================ */
.mt-a11y-header {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  padding: 14px 16px !important;
  margin: 0 !important;
  background: #fff !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 16px 16px 0 0 !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
}

.mt-a11y-header-main,
.mt-a11y-header-actions {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
  min-width: 0 !important;
}

.mt-a11y-header-main {
  justify-content: space-between !important;
  width: 100% !important;
}

.mt-a11y-header-meta {
  display: flex !important;
  justify-content: flex-end !important;
  width: 100% !important;
}

.mt-a11y-lang {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  min-width: min(100%, 210px) !important;
}

.mt-a11y-lang-label {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: #6b7280 !important;
  white-space: nowrap !important;
}

.mt-a11y-header .mt-a11y-lang select {
  min-width: 96px !important;
  width: 96px !important;
  height: 34px !important;
  padding: 0 28px 0 10px !important;
  font-size: 12px !important;
}

.mt-a11y-title {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-width: 0 !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #111827 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.mt-a11y-title span:last-child {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.mt-a11y-title-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 20px !important;
  height: 20px !important;
  color: #2563eb !important;
  flex-shrink: 0 !important;
}

.mt-a11y-title-icon svg {
  width: 20px !important;
  height: 20px !important;
}

.mt-a11y-header .mt-a11y-title {
  margin: 0 !important;
}

.mt-a11y-close {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 34px !important;
  min-width: 34px !important;
  height: 34px !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 22px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #6b7280 !important;
  background: #f3f4f6 !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 999px !important;
  cursor: pointer !important;
  transition: background 0.15s ease, color 0.15s ease !important;
  flex-shrink: 0 !important;
}

.mt-a11y-close svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  stroke: currentColor !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
}

.mt-a11y-close:hover {
  background: #e5e7eb !important;
  color: #374151 !important;
}

.mt-a11y-close:focus-visible {
  outline: 3px solid #2563eb !important;
  outline-offset: 2px !important;
}

/* ============================================================
   ROWS
   ============================================================ */
.mt-a11y-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 14px 16px !important;
  margin: 0 !important;
  background: #fff !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
  min-height: 48px !important;
  box-sizing: border-box !important;
}

.mt-a11y-row--section-title {
  justify-content: flex-start !important;
  background: #f9fafb !important;
}

.mt-a11y-row:last-child {
  border-bottom: 0 !important;
  border-radius: 0 0 16px 16px !important;
}

.mt-a11y-row--stack {
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 14px 16px !important;
}

/* Row labels */
.mt-a11y-row > span:first-child {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #374151 !important;
}

.mt-a11y-row-label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.mt-a11y-row-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  color: #6b7280 !important;
}

.mt-a11y-row-icon svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
}

/* ============================================================
   STACK CONTAINER
   ============================================================ */
.mt-a11y-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  width: 100% !important;
  padding: 12px !important;
  margin: 0 !important;
  background: #f9fafb !important;
  border: 1px solid rgba(0, 0, 0, 0.06) !important;
  border-radius: 10px !important;
  box-sizing: border-box !important;
}

/* ============================================================
   CONTROLS
   ============================================================ */
.mt-a11y-control {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #4b5563 !important;
}

.mt-a11y-control--select {
  align-items: center !important;
}

/* ============================================================
   HELP TEXT
   ============================================================ */
.mt-a11y-help {
  font-size: 12px !important;
  font-weight: 400 !important;
  color: #6b7280 !important;
  line-height: 1.4 !important;
  margin: 4px 0 0 0 !important;
  padding: 0 !important;
}

/* ============================================================
   FORM ELEMENTS - BUTTONS
   ============================================================ */
.mt-a11y-actions {
  display: inline-flex !important;
  gap: 6px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.mt-a11y-actions button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 36px !important;
  height: 36px !important;
  padding: 0 10px !important;
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #374151 !important;
  background: #fff !important;
  border: 1px solid rgba(0, 0, 0, 0.15) !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.1s ease !important;
}

.mt-a11y-actions button:hover {
  background: #f3f4f6 !important;
  border-color: rgba(0, 0, 0, 0.2) !important;
}

.mt-a11y-actions button:active {
  transform: scale(0.96) !important;
}

.mt-a11y-actions button:focus-visible {
  outline: 3px solid #2563eb !important;
  outline-offset: 2px !important;
}

/* ============================================================
   FORM ELEMENTS - SELECT
   ============================================================ */
.mt-a11y-panel select,
#mt-a11y-panel select {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  display: inline-flex !important;
  align-items: center !important;
  min-width: 100px !important;
  height: 34px !important;
  padding: 0 32px 0 12px !important;
  margin: 0 !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #374151 !important;
  background-color: #fff !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  background-size: 12px !important;
  border: 1px solid rgba(0, 0, 0, 0.15) !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
}

.mt-a11y-panel select:hover,
#mt-a11y-panel select:hover {
  border-color: rgba(0, 0, 0, 0.25) !important;
}

.mt-a11y-panel select:focus,
#mt-a11y-panel select:focus {
  outline: none !important;
  border-color: #2563eb !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15) !important;
}

.mt-a11y-panel select option,
#mt-a11y-panel select option {
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #374151 !important;
  background: #fff !important;
  padding: 8px 12px !important;
}

/* ============================================================
   FORM ELEMENTS - CHECKBOX
   ============================================================ */
.mt-a11y-panel input[type="checkbox"],
#mt-a11y-panel input[type="checkbox"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: #fff !important;
  border: 2px solid #d1d5db !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease !important;
  flex-shrink: 0 !important;
}

.mt-a11y-panel input[type="checkbox"]:hover,
#mt-a11y-panel input[type="checkbox"]:hover {
  border-color: #9ca3af !important;
}

.mt-a11y-panel input[type="checkbox"]:checked,
#mt-a11y-panel input[type="checkbox"]:checked {
  background: #2563eb !important;
  border-color: #2563eb !important;
}

.mt-a11y-panel input[type="checkbox"]:checked::after,
#mt-a11y-panel input[type="checkbox"]:checked::after {
  content: "" !important;
  display: block !important;
  width: 5px !important;
  height: 9px !important;
  border: solid #fff !important;
  border-width: 0 2px 2px 0 !important;
  transform: rotate(45deg) translate(-1px, -1px) !important;
}

.mt-a11y-panel input[type="checkbox"]:focus-visible,
#mt-a11y-panel input[type="checkbox"]:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.25) !important;
}

/* ============================================================
   RESET BUTTON
   ============================================================ */
.mt-a11y-row button[data-action="reset"] {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px 16px !important;
  margin: 0 !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #dc2626 !important;
  background: #fef2f2 !important;
  border: 1px solid #fecaca !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  transition: background 0.15s ease, border-color 0.15s ease !important;
}

.mt-a11y-row button[data-action="reset"]:hover {
  background: #fee2e2 !important;
  border-color: #fca5a5 !important;
}

.mt-a11y-row button[data-action="reset"]:focus-visible {
  outline: 3px solid #dc2626 !important;
  outline-offset: 2px !important;
}

.mt-a11y-footer {
  display: flex !important;
  justify-content: center !important;
  padding: 14px 16px !important;
  margin: 0 !important;
  background: var(--mt-a11y-ui-surface) !important;
  border-top: 1px solid var(--mt-a11y-ui-border) !important;
  border-radius: 0 0 16px 16px !important;
  box-sizing: border-box !important;
}

.mt-a11y-reset-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 38px !important;
  padding: 8px 12px !important;
  margin: 0 !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--mt-a11y-ui-muted) !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  text-decoration: underline !important;
  text-underline-offset: 0.16em !important;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease !important;
}

.mt-a11y-reset-link:hover {
  color: #b91c1c !important;
  background: color-mix(in srgb, #dc2626 6%, var(--mt-a11y-ui-surface)) !important;
  border-color: color-mix(in srgb, #dc2626 20%, var(--mt-a11y-ui-border)) !important;
}

.mt-a11y-reset-link:focus-visible {
  outline: 3px solid var(--mt-a11y-accent) !important;
  outline-offset: 2px !important;
}

.mt-a11y-reading-overlay {
  position: fixed;
  inset: 0;
  z-index: 99990;
  pointer-events: none;
  display: none;
  --mt-a11y-reading-x: 50vw;
  --mt-a11y-reading-y: 50vh;
  --mt-a11y-reading-band-h: 48px;
  --mt-a11y-reading-mask-height: 160px;
  --mt-a11y-reading-spotlight-size: 160px;
  --mt-a11y-reading-dim-alpha: 0.55;
}

.mt-a11y-reading-overlay.is-active {
  display: block;
}

.mt-a11y-reading-overlay.is-paused {
  display: none;
}

.mt-a11y-reading-guide {
  position: fixed;
  left: 0;
  right: 0;
  top: calc(var(--mt-a11y-reading-y) - (var(--mt-a11y-reading-band-h) / 2));
  height: var(--mt-a11y-reading-band-h);
  background: rgba(255,255,255,.18);
  border-top: 1px solid rgba(0,0,0,.2);
  border-bottom: 1px solid rgba(0,0,0,.2);
  display: none;
}

.mt-a11y-reading-guide.is-active {
  display: block;
}

.mt-a11y-reading-mask {
  position: fixed;
  inset: 0;
  display: none;
  background: rgba(0,0,0,var(--mt-a11y-reading-dim-alpha));
}

.mt-a11y-reading-mask.is-active {
  display: block;
}

.mt-a11y-reading-mask.is-line {
  -webkit-mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,1) 0,
    rgba(0,0,0,1) calc(var(--mt-a11y-reading-y) - (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,0) calc(var(--mt-a11y-reading-y) - (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,0) calc(var(--mt-a11y-reading-y) + (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,1) calc(var(--mt-a11y-reading-y) + (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,1) 100%
  );
  mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,1) 0,
    rgba(0,0,0,1) calc(var(--mt-a11y-reading-y) - (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,0) calc(var(--mt-a11y-reading-y) - (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,0) calc(var(--mt-a11y-reading-y) + (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,1) calc(var(--mt-a11y-reading-y) + (var(--mt-a11y-reading-mask-height) / 2)),
    rgba(0,0,0,1) 100%
  );
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.mt-a11y-reading-mask.is-spotlight {
  -webkit-mask-image: radial-gradient(
    circle var(--mt-a11y-reading-spotlight-size) at var(--mt-a11y-reading-x)
      var(--mt-a11y-reading-y),
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) 55%,
    rgba(0,0,0,1) 75%
  );
  mask-image: radial-gradient(
    circle var(--mt-a11y-reading-spotlight-size) at var(--mt-a11y-reading-x)
      var(--mt-a11y-reading-y),
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) 55%,
    rgba(0,0,0,1) 75%
  );
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.mt-a11y-reading-overlay--fallback .mt-a11y-reading-mask.is-line {
  background: transparent;
}

.mt-a11y-reading-overlay--fallback .mt-a11y-reading-mask.is-line::before,
.mt-a11y-reading-overlay--fallback .mt-a11y-reading-mask.is-line::after {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  background: rgba(0,0,0,var(--mt-a11y-reading-dim-alpha));
}

.mt-a11y-reading-overlay--fallback .mt-a11y-reading-mask.is-line::before {
  top: 0;
  height: calc(var(--mt-a11y-reading-y) - (var(--mt-a11y-reading-mask-height) / 2));
}

.mt-a11y-reading-overlay--fallback .mt-a11y-reading-mask.is-line::after {
  top: calc(var(--mt-a11y-reading-y) + (var(--mt-a11y-reading-mask-height) / 2));
  bottom: 0;
}

.mt-a11y-reading-overlay--fallback .mt-a11y-reading-mask.is-spotlight {
  background: radial-gradient(
    circle var(--mt-a11y-reading-spotlight-size) at var(--mt-a11y-reading-x)
      var(--mt-a11y-reading-y),
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) 55%,
    rgba(0,0,0,var(--mt-a11y-reading-dim-alpha)) 75%
  );
}

/* Phase 1 core effects (applied via html classes) */
html.mt-a11y-focus :focus-visible {
  outline: 3px solid #1a73e8;
  outline-offset: 3px;
}

html.mt-a11y-font-system {
  --mt-a11y-font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

html.mt-a11y-font-dyslexic {
  --mt-a11y-font-family: "OpenDyslexic", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

/* High contrast mode (MVP)
   Keep it conservative: improve contrast without breaking layouts.
   Do not reintroduce filter-based contrast. */
html.mt-a11y-contrast {
  --mt-a11y-hc-bg: #000;
  --mt-a11y-hc-fg: #fff;
  --mt-a11y-hc-link: #00e5ff;
  --mt-a11y-hc-link-visited: #ffb74d;
  --mt-a11y-hc-border: #fff;
  --mt-a11y-hc-focus: #ffd54f;
  --mt-a11y-link-highlight-bg: rgba(255, 255, 255, 0.18);
  color-scheme: dark;
}

html.mt-a11y-contrast body {
  background: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast p:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast li:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast dt:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast dd:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast blockquote:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast figcaption:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast small:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast label:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast h1:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast h2:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast h3:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast h4:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast h5:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast h6:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)) {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast :where(
  section,
  article,
  main,
  [role="main"],
  blockquote,
  figure,
  figcaption,
  fieldset,
  legend,
  table,
  thead,
  tbody,
  tfoot,
  th,
  td,
  .card,
  [class*="card"],
  [class*="panel"],
  [class*="box"],
  [class*="tile"],
  [class*="callout"],
  [class*="frame"],
  [class*="content"]
):not(:where(
  [data-mt-a11y-contrast-preserve-bg],
  [data-mt-a11y-contrast-preserve],
  [data-mt-a11y-contrast-preserve] *
)) {
  background-color: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast [data-mt-a11y-contrast-preserve-bg] {
  background-color: transparent !important;
}

html.mt-a11y-contrast a:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)) {
  color: var(--mt-a11y-hc-link) !important;
  text-decoration: underline !important;
  text-decoration-thickness: 2px;
}

html.mt-a11y-contrast a:visited:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)) {
  color: var(--mt-a11y-hc-link-visited) !important;
}

html.mt-a11y-contrast input:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast textarea:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast select:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast button:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)) {
  background: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast input:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *))::placeholder,
html.mt-a11y-contrast textarea:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *))::placeholder {
  color: var(--mt-a11y-hc-fg) !important;
  opacity: 0.75;
}

html.mt-a11y-contrast hr:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)) {
  border-color: var(--mt-a11y-hc-border) !important;
  background-color: var(--mt-a11y-hc-border) !important;
  color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast blockquote:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast fieldset:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast table:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast th:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)),
html.mt-a11y-contrast td:not(:where([data-mt-a11y-contrast-preserve], [data-mt-a11y-contrast-preserve] *)) {
  border-color: var(--mt-a11y-hc-border) !important;
}

/* ============================================================
   HIGH CONTRAST MODE - PANEL/LAUNCHER UI
   Ensure our own UI stays readable in contrast mode
   ============================================================ */
html.mt-a11y-contrast .mt-a11y-launcher {
  background: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
  box-shadow: 0 0 0 2px var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-panel {
  background: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
  box-shadow: 0 0 0 2px var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-header {
  background: var(--mt-a11y-hc-bg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-title {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-title-icon {
  color: var(--mt-a11y-hc-focus) !important;
}

html.mt-a11y-contrast .mt-a11y-lang-label {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-row {
  background: var(--mt-a11y-hc-bg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-footer {
  background: var(--mt-a11y-hc-bg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-row > span:first-child {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-row--section-title {
  background: #111 !important;
}

html.mt-a11y-contrast .mt-a11y-row-icon {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-stack {
  background: var(--mt-a11y-hc-bg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-control {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-help {
  color: var(--mt-a11y-hc-fg) !important;
  opacity: 0.85;
}

html.mt-a11y-contrast .mt-a11y-close {
  background: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-actions button {
  background: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-panel select {
  background-color: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E") !important;
}

html.mt-a11y-contrast .mt-a11y-panel select option {
  background: var(--mt-a11y-hc-bg) !important;
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-panel input[type="checkbox"] {
  background: var(--mt-a11y-hc-bg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-panel input[type="checkbox"]:checked {
  background: var(--mt-a11y-hc-focus) !important;
  border-color: var(--mt-a11y-hc-focus) !important;
}

html.mt-a11y-contrast .mt-a11y-panel input[type="checkbox"]:checked::after {
  border-color: var(--mt-a11y-hc-bg) !important;
}

html.mt-a11y-contrast .mt-a11y-row button[data-action="reset"] {
  background: var(--mt-a11y-hc-bg) !important;
  color: #ff6b6b !important;
  border-color: #ff6b6b !important;
}

html.mt-a11y-contrast .mt-a11y-reset-link {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-reset-link:hover {
  color: #ff6b6b !important;
  background: #1a1a1a !important;
  border-color: #ff6b6b !important;
}

html.mt-a11y-contrast .mt-a11y-panel :focus-visible,
html.mt-a11y-contrast .mt-a11y-launcher:focus-visible {
  outline: 3px solid var(--mt-a11y-hc-focus) !important;
  outline-offset: 2px !important;
}

/* Spacing presets (MVP)
   Keep this conservative to avoid layout breakage. */
:root {
  --mt-a11y-line-height: 1.55;
  --mt-a11y-letter-spacing: 0;
  --mt-a11y-word-spacing: 0;
}

body {
  line-height: var(--mt-a11y-line-height);
  letter-spacing: var(--mt-a11y-letter-spacing);
  word-spacing: var(--mt-a11y-word-spacing);
}

html.mt-a11y-font-system body,
html.mt-a11y-font-system input,
html.mt-a11y-font-system textarea,
html.mt-a11y-font-system select,
html.mt-a11y-font-system button,
html.mt-a11y-font-system h1,
html.mt-a11y-font-system h2,
html.mt-a11y-font-system h3,
html.mt-a11y-font-system h4,
html.mt-a11y-font-system h5,
html.mt-a11y-font-system h6,
html.mt-a11y-font-system p,
html.mt-a11y-font-system li,
html.mt-a11y-font-system dt,
html.mt-a11y-font-system dd,
html.mt-a11y-font-system blockquote,
html.mt-a11y-font-system figcaption,
html.mt-a11y-font-system small,
html.mt-a11y-font-dyslexic body,
html.mt-a11y-font-dyslexic input,
html.mt-a11y-font-dyslexic textarea,
html.mt-a11y-font-dyslexic select,
html.mt-a11y-font-dyslexic button {
  font-family: var(--mt-a11y-font-family, inherit) !important;
}

html.mt-a11y-font-dyslexic h1,
html.mt-a11y-font-dyslexic h2,
html.mt-a11y-font-dyslexic h3,
html.mt-a11y-font-dyslexic h4,
html.mt-a11y-font-dyslexic h5,
html.mt-a11y-font-dyslexic h6,
html.mt-a11y-font-dyslexic p,
html.mt-a11y-font-dyslexic li,
html.mt-a11y-font-dyslexic dt,
html.mt-a11y-font-dyslexic dd,
html.mt-a11y-font-dyslexic blockquote,
html.mt-a11y-font-dyslexic figcaption,
html.mt-a11y-font-dyslexic small {
  font-family: var(--mt-a11y-font-family, inherit) !important;
}

html.mt-a11y-spacing-1 {
  --mt-a11y-line-height: 1.55;
  --mt-a11y-letter-spacing: 0;
  --mt-a11y-word-spacing: 0;
}

html.mt-a11y-spacing-2 {
  --mt-a11y-line-height: 1.75;
  --mt-a11y-letter-spacing: 0.02em;
  --mt-a11y-word-spacing: 0.04em;
}

/* Reduce motion (improved)
   - When enabled, enforce no animation/transition and disable smooth scrolling.
   - Also set a hint attribute to allow CSS targeting if needed later. */
html.mt-a11y-reduce-motion {
  scroll-behavior: auto !important;
}

html.mt-a11y-reduce-motion *,
html.mt-a11y-reduce-motion *::before,
html.mt-a11y-reduce-motion *::after {
  animation: none !important;
  transition: none !important;
  scroll-behavior: auto !important;
}

/* Respect OS setting automatically (no UI toggle required) */
@media (prefers-reduced-motion: reduce) {
  html:not(.mt-a11y-reduce-motion-disabled) {
    scroll-behavior: auto;
  }
}

/* Reading mode (simplify layout)
   Best-effort approach: applies layout constraints to common content roots.
   Themes vary, so this is conservative and may not work perfectly on all sites.
   
   Content root override: If [data-mt-a11y-reading-root] exists, apply constraints
   ONLY to that element. Otherwise, fall back to best-effort selectors. */
:root {
  --mt-a11y-reading-max-width: 78ch;
  --mt-a11y-reading-padding: 1.5rem;
}

/* Priority: Override element (if present) */
html.mt-a11y-reading-mode [data-mt-a11y-reading-root] {
  max-width: var(--mt-a11y-reading-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--mt-a11y-reading-padding);
  padding-right: var(--mt-a11y-reading-padding);
}

/* Fallback: Best-effort selectors (only when override element does NOT exist)
   Use :has() when supported, with class fallback for older browsers */
html.mt-a11y-reading-mode:not(:has([data-mt-a11y-reading-root])):not(.mt-a11y-reading-has-root) :where(main, article, [role="main"], #content, .content, .main, .page-content) {
  max-width: var(--mt-a11y-reading-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--mt-a11y-reading-padding);
  padding-right: var(--mt-a11y-reading-padding);
}

/* Hide distractions (best-effort, optional)
   Only hides common semantic elements. Themes vary, so this may not catch all cases. */
html.mt-a11y-reading-mode.mt-a11y-reading-mode--hide-chrome :where(header, nav, aside, footer) {
  display: none !important;
}

/* Ensure mt-a11y launcher/panel are never affected by reading mode constraints */
html.mt-a11y-reading-mode .mt-a11y-launcher {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0 !important;
}

html.mt-a11y-reading-mode .mt-a11y-panel {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  /* Preserve panel's own padding system */
}

html.mt-a11y-reading-mode.mt-a11y-reading-mode--hide-chrome .mt-a11y-launcher,
html.mt-a11y-reading-mode.mt-a11y-reading-mode--hide-chrome .mt-a11y-panel {
  display: block !important;
}

/* ============================================================
   PHASE 1.5 QUICK WINS (READABILITY)
   ============================================================ */
html.mt-a11y-cursor-big,
html.mt-a11y-cursor-big body {
  cursor: var(--mt-a11y-cursor-large);
}

html.mt-a11y-cursor-big.mt-a11y-cursor-size-l,
html.mt-a11y-cursor-big.mt-a11y-cursor-size-l body {
  cursor: var(--mt-a11y-cursor-large);
}

html.mt-a11y-cursor-big.mt-a11y-cursor-size-xl,
html.mt-a11y-cursor-big.mt-a11y-cursor-size-xl body {
  cursor: var(--mt-a11y-cursor-xl);
}

html.mt-a11y-links [data-mt-a11y-reading-root] :where(a) {
  text-decoration: underline !important;
  text-decoration-thickness: 2px !important;
  text-underline-offset: 0.15em !important;
}

html.mt-a11y-links [data-mt-a11y-reading-root]
  :where(p, li, dt, dd, blockquote, figcaption)
  a {
  background-color: var(--mt-a11y-link-highlight-bg) !important;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  padding: 0 0.05em;
}

html.mt-a11y-links:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(a) {
  text-decoration: underline !important;
  text-decoration-thickness: 2px !important;
  text-underline-offset: 0.15em !important;
}

html.mt-a11y-links:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(p, li, dt, dd, blockquote, figcaption)
  a {
  background-color: var(--mt-a11y-link-highlight-bg) !important;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  padding: 0 0.05em;
}

html.mt-a11y-hide-images [data-mt-a11y-reading-root]
  :where(img, picture, video)
  :not(:where(nav, header, footer, button, [role="button"]) *) {
  display: none !important;
}

html.mt-a11y-hide-images [data-mt-a11y-reading-root]
  :where(svg[aria-hidden="true"], svg:not([role]):not([aria-label]))
  :not(:where(nav, header, footer, button, [role="button"]) *) {
  display: none !important;
}

html.mt-a11y-hide-images:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(img, picture, video)
  :not(:where(nav, header, footer, button, [role="button"]) *) {
  display: none !important;
}

html.mt-a11y-hide-images:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(svg[aria-hidden="true"], svg:not([role]):not([aria-label]))
  :not(:where(nav, header, footer, button, [role="button"]) *) {
  display: none !important;
}

html.mt-a11y-weight-boost [data-mt-a11y-reading-root]
  :where(p, li, dt, dd, blockquote, figcaption, small, a) {
  font-weight: 500 !important;
}

html.mt-a11y-weight-boost:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(p, li, dt, dd, blockquote, figcaption, small, a) {
  font-weight: 500 !important;
}

html.mt-a11y-align-left [data-mt-a11y-reading-root]
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: left !important;
}

html.mt-a11y-align-center [data-mt-a11y-reading-root]
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: center !important;
}

html.mt-a11y-align-justify [data-mt-a11y-reading-root]
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: justify !important;
}

html.mt-a11y-align-right [data-mt-a11y-reading-root]
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: right !important;
}

html.mt-a11y-align-left:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: left !important;
}

html.mt-a11y-align-center:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: center !important;
}

html.mt-a11y-align-justify:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: justify !important;
}

html.mt-a11y-align-right:not(.mt-a11y-content-has-root)
  :where(main, article, [role="main"], #content, .content, .main, .page-content)
  :where(p, li, dt, dd, blockquote, figcaption, h1, h2, h3, h4, h5, h6) {
  text-align: right !important;
}

.mt-a11y-magnifier {
  position: fixed;
  right: 20px;
  bottom: 88px;
  z-index: 99995;
  max-width: min(360px, calc(100vw - 40px));
  max-height: 35vh;
  overflow: auto;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #fff;
  color: #111827;
  font-size: calc(1rem * var(--mt-a11y-magnifier-scale, 1.4));
  line-height: 1.5;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.2);
  pointer-events: none;
  display: none;
}

.mt-a11y-magnifier.is-active {
  display: block;
}

html.mt-a11y-contrast .mt-a11y-magnifier {
  background: var(--mt-a11y-hc-bg);
  color: var(--mt-a11y-hc-fg);
  border-color: var(--mt-a11y-hc-border);
}

/* ============================================================
   SCROLLBAR STYLING (for panel internal scroll)
   ============================================================ */
.mt-a11y-panel::-webkit-scrollbar {
  width: 8px;
}

.mt-a11y-panel::-webkit-scrollbar-track {
  background: transparent;
}

.mt-a11y-panel::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.15);
  border-radius: 4px;
}

.mt-a11y-panel::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.25);
}

/* Firefox scrollbar */
.mt-a11y-panel {
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, 0.15) transparent;
}

/* ============================================================
   QUICK TILES SECTION
   ============================================================ */
.mt-a11y-tiles-section {
  padding: 14px 16px !important;
  margin: 0 !important;
  background: #fff !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
  box-sizing: border-box !important;
}

.mt-a11y-tiles-title {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #374151 !important;
  margin: 0 0 12px 0 !important;
  padding: 0 !important;
}

.mt-a11y-tiles-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.mt-a11y-tiles-section--priority {
  background: color-mix(in srgb, var(--mt-a11y-accent) 6%, var(--mt-a11y-ui-surface)) !important;
}

.mt-a11y-priority-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.mt-a11y-tiles-grid--priority {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.mt-a11y-tile {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 6px !important;
  padding: 14px !important;
  margin: 0 !important;
  background: #f9fafb !important;
  border: 2px solid #e5e7eb !important;
  border-radius: 12px !important;
  cursor: pointer !important;
  transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease !important;
  text-align: left !important;
  min-height: 90px !important;
  box-sizing: border-box !important;
}

.mt-a11y-tile:hover {
  background: #f3f4f6 !important;
  border-color: #d1d5db !important;
}

.mt-a11y-tile:focus-visible {
  outline: 3px solid #2563eb !important;
  outline-offset: 2px !important;
}

.mt-a11y-tile.is-active {
  background: #eff6ff !important;
  border-color: #3b82f6 !important;
  box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.2) !important;
}

.mt-a11y-tile.is-active:hover {
  background: #dbeafe !important;
  border-color: #2563eb !important;
}

.mt-a11y-tile-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 24px !important;
  height: 24px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #6b7280 !important;
  flex-shrink: 0 !important;
}

.mt-a11y-tile-icon svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
}

.mt-a11y-tile.is-active .mt-a11y-tile-icon {
  color: #2563eb !important;
}

.mt-a11y-tile-label {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #374151 !important;
  line-height: 1.3 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.mt-a11y-tile.is-active .mt-a11y-tile-label {
  color: #1e40af !important;
}

.mt-a11y-tile-status {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 2px 8px !important;
  margin: 0 !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #6b7280 !important;
  background: #e5e7eb !important;
  border-radius: 10px !important;
  line-height: 1.4 !important;
}

.mt-a11y-tile.is-active .mt-a11y-tile-status {
  color: #1e40af !important;
  background: #bfdbfe !important;
}

/* ============================================================
   QUICK TILES - HIGH CONTRAST MODE
   ============================================================ */
html.mt-a11y-contrast .mt-a11y-tiles-section {
  background: var(--mt-a11y-hc-bg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-tiles-title {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-tile {
  background: var(--mt-a11y-hc-bg) !important;
  border-color: var(--mt-a11y-hc-border) !important;
}

html.mt-a11y-contrast .mt-a11y-tile:hover {
  background: #1a1a1a !important;
}

html.mt-a11y-contrast .mt-a11y-tile.is-active {
  background: #1a2744 !important;
  border-color: var(--mt-a11y-hc-focus) !important;
}

html.mt-a11y-contrast .mt-a11y-tile-icon {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-tile.is-active .mt-a11y-tile-icon {
  color: var(--mt-a11y-hc-focus) !important;
}

html.mt-a11y-contrast .mt-a11y-tile-label {
  color: var(--mt-a11y-hc-fg) !important;
}

html.mt-a11y-contrast .mt-a11y-tile.is-active .mt-a11y-tile-label {
  color: var(--mt-a11y-hc-focus) !important;
}

html.mt-a11y-contrast .mt-a11y-tile-status {
  color: var(--mt-a11y-hc-fg) !important;
  background: #333 !important;
}

html.mt-a11y-contrast .mt-a11y-tile.is-active .mt-a11y-tile-status {
  color: var(--mt-a11y-hc-bg) !important;
  background: var(--mt-a11y-hc-focus) !important;
}

/* ============================================================
   CONFIGURABLE NEUTRAL WIDGET THEME
   ============================================================ */
.mt-a11y-launcher {
  border-color: var(--mt-a11y-accent) !important;
  background: var(--mt-a11y-ui-surface) !important;
  color: var(--mt-a11y-accent) !important;
  box-shadow: var(--mt-a11y-ui-shadow) !important;
}

.mt-a11y-launcher:hover {
  box-shadow: 0 20px 46px rgba(15, 23, 42, 0.2) !important;
}

.mt-a11y-launcher:focus-visible,
.mt-a11y-close:focus-visible,
.mt-a11y-actions button:focus-visible,
.mt-a11y-tile:focus-visible {
  outline-color: var(--mt-a11y-accent) !important;
}

.mt-a11y-panel {
  background: var(--mt-a11y-ui-bg) !important;
  color: var(--mt-a11y-ui-text) !important;
  border-color: var(--mt-a11y-ui-border) !important;
  box-shadow: var(--mt-a11y-ui-shadow) !important;
}

.mt-a11y-header,
.mt-a11y-row,
.mt-a11y-tiles-section {
  background: var(--mt-a11y-ui-surface) !important;
  border-color: var(--mt-a11y-ui-border) !important;
}

.mt-a11y-row--section-title,
.mt-a11y-stack,
.mt-a11y-tile,
.mt-a11y-close,
.mt-a11y-actions button {
  background: var(--mt-a11y-ui-surface-muted) !important;
  border-color: var(--mt-a11y-ui-border) !important;
}

.mt-a11y-title,
.mt-a11y-row > span:first-child,
.mt-a11y-tiles-title,
.mt-a11y-tile-label,
.mt-a11y-control,
.mt-a11y-control span,
.mt-a11y-actions button,
.mt-a11y-panel select,
#mt-a11y-panel select,
.mt-a11y-panel select option,
#mt-a11y-panel select option {
  color: var(--mt-a11y-ui-text) !important;
}

.mt-a11y-title-icon,
.mt-a11y-tile.is-active .mt-a11y-tile-icon,
.mt-a11y-tile.is-active .mt-a11y-tile-label {
  color: var(--mt-a11y-accent) !important;
}

.mt-a11y-lang-label,
.mt-a11y-row-icon,
.mt-a11y-help,
.mt-a11y-tile-icon,
.mt-a11y-tile-status,
.mt-a11y-close {
  color: var(--mt-a11y-ui-muted) !important;
}

.mt-a11y-panel select,
#mt-a11y-panel select,
.mt-a11y-panel select option,
#mt-a11y-panel select option,
.mt-a11y-panel input[type="checkbox"],
#mt-a11y-panel input[type="checkbox"] {
  background-color: var(--mt-a11y-ui-surface) !important;
  border-color: var(--mt-a11y-ui-border) !important;
}

.mt-a11y-panel input[type="checkbox"]:checked,
#mt-a11y-panel input[type="checkbox"]:checked,
.mt-a11y-tile.is-active {
  background: color-mix(in srgb, var(--mt-a11y-accent) 14%, var(--mt-a11y-ui-surface)) !important;
  border-color: var(--mt-a11y-accent) !important;
}

.mt-a11y-panel input[type="checkbox"]:checked,
#mt-a11y-panel input[type="checkbox"]:checked {
  background: var(--mt-a11y-accent) !important;
}

.mt-a11y-tile--priority {
  min-height: 116px !important;
  padding: 16px !important;
  border-color: color-mix(in srgb, var(--mt-a11y-accent) 28%, var(--mt-a11y-ui-border)) !important;
}

.mt-a11y-tile--priority .mt-a11y-tile-label {
  font-size: 15px !important;
  font-weight: 700 !important;
}

.mt-a11y-tiles-grid--priority .mt-a11y-tile--priority:last-child {
  grid-column: 1 / -1 !important;
  min-height: 86px !important;
}

.mt-a11y-row--priority {
  min-height: 64px !important;
  border: 1px solid var(--mt-a11y-ui-border) !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03) !important;
}

.mt-a11y-row--priority > span:first-child,
.mt-a11y-row--priority .mt-a11y-row-label {
  font-size: 15px !important;
  font-weight: 700 !important;
}

.mt-a11y-row--priority .mt-a11y-actions button {
  min-width: 40px !important;
  height: 40px !important;
  font-size: 15px !important;
}

.mt-a11y-row--text-size {
  flex-wrap: wrap !important;
}

.mt-a11y-row--text-size,
.mt-a11y-row--spacing {
  background: var(--mt-a11y-ui-surface) !important;
  border: 1px solid var(--mt-a11y-ui-border) !important;
  border-color: var(--mt-a11y-ui-border) !important;
  border-radius: 12px !important;
}

.mt-a11y-row.mt-a11y-row--spacing {
  border-radius: 12px !important;
}

.mt-a11y-row--text-size .mt-a11y-actions {
  margin-left: auto !important;
}

.mt-a11y-row--spacing select {
  margin-left: auto !important;
}

html.mt-a11y-contrast .mt-a11y-tiles-section--priority {
  background: var(--mt-a11y-hc-bg) !important;
}

html.mt-a11y-contrast .mt-a11y-row--priority {
  border-color: var(--mt-a11y-hc-border) !important;
  box-shadow: none !important;
}

html.mt-a11y-contrast .mt-a11y-tile--priority {
  border-color: var(--mt-a11y-hc-border) !important;
}

/* Keep the toolbar UI isolated from page-level high contrast overrides. */
html.mt-a11y-contrast .mt-a11y-launcher,
html.mt-a11y-contrast .mt-a11y-panel {
  /* Isolate from high contrast, but keep a theme-aware widget surface. */
  --mt-a11y-ui-bg: #f8fafc;
  --mt-a11y-ui-surface: #ffffff;
  --mt-a11y-ui-surface-muted: #f1f5f9;
  --mt-a11y-ui-text: #111827;
  --mt-a11y-ui-muted: #64748b;
  --mt-a11y-ui-border: rgba(15, 23, 42, 0.12);
  --mt-a11y-ui-shadow: 0 18px 42px rgba(15, 23, 42, 0.16);
  background: var(--mt-a11y-ui-bg) !important;
  color: var(--mt-a11y-ui-text) !important;
  border-color: var(--mt-a11y-ui-border) !important;
  box-shadow: var(--mt-a11y-ui-shadow) !important;
  color-scheme: light !important;
}

html.mt-a11y-contrast[data-bs-theme="dark"] .mt-a11y-launcher,
html.mt-a11y-contrast[data-bs-theme="dark"] .mt-a11y-panel,
html.mt-a11y-contrast[data-mt-a11y-theme="dark"] .mt-a11y-launcher,
html.mt-a11y-contrast[data-mt-a11y-theme="dark"] .mt-a11y-panel {
  --mt-a11y-accent: #93c5fd;
  --mt-a11y-accent-contrast: #111827;
  --mt-a11y-ui-bg: #111827;
  --mt-a11y-ui-surface: #1f2937;
  --mt-a11y-ui-surface-muted: #273449;
  --mt-a11y-ui-text: #f9fafb;
  --mt-a11y-ui-muted: #cbd5e1;
  --mt-a11y-ui-border: rgba(255, 255, 255, 0.16);
  --mt-a11y-ui-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
  color-scheme: dark !important;
}

html.mt-a11y-contrast .mt-a11y-panel * {
  background-color: transparent !important;
}

html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-header,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-row,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tiles-section {
  background: var(--mt-a11y-ui-surface) !important;
  border-color: var(--mt-a11y-ui-border) !important;
}

html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-row--section-title,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-stack,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tile,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-close,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-actions button {
  background: var(--mt-a11y-ui-surface-muted) !important;
  border-color: var(--mt-a11y-ui-border) !important;
}

html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-title,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-row > span:first-child,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tiles-title,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tile-label,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-control,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-control span,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-actions button,
html.mt-a11y-contrast .mt-a11y-panel select,
html.mt-a11y-contrast #mt-a11y-panel select,
html.mt-a11y-contrast .mt-a11y-panel select option,
html.mt-a11y-contrast #mt-a11y-panel select option {
  color: var(--mt-a11y-ui-text) !important;
}

html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-lang-label,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-row-icon,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-help,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tile-icon,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tile-status,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-close {
  color: var(--mt-a11y-ui-muted) !important;
}

html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-title-icon,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tile.is-active .mt-a11y-tile-icon,
html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tile.is-active .mt-a11y-tile-label {
  color: var(--mt-a11y-accent) !important;
}

html.mt-a11y-contrast .mt-a11y-panel select,
html.mt-a11y-contrast #mt-a11y-panel select {
  background-color: var(--mt-a11y-ui-surface) !important;
  border-color: var(--mt-a11y-ui-border) !important;
}

html.mt-a11y-contrast .mt-a11y-panel input[type="checkbox"],
html.mt-a11y-contrast #mt-a11y-panel input[type="checkbox"] {
  background: var(--mt-a11y-ui-surface) !important;
  border-color: var(--mt-a11y-ui-border) !important;
}

html.mt-a11y-contrast .mt-a11y-panel input[type="checkbox"]:checked,
html.mt-a11y-contrast #mt-a11y-panel input[type="checkbox"]:checked {
  background: var(--mt-a11y-accent) !important;
  border-color: var(--mt-a11y-accent) !important;
}

html.mt-a11y-contrast .mt-a11y-panel .mt-a11y-tile.is-active {
  background: color-mix(in srgb, var(--mt-a11y-accent) 14%, var(--mt-a11y-ui-surface)) !important;
  border-color: var(--mt-a11y-accent) !important;
}

@media (max-width: 420px) {
  .mt-a11y-tiles-grid--priority {
    grid-template-columns: 1fr !important;
  }

  .mt-a11y-tile--priority {
    min-height: 82px !important;
  }

  .mt-a11y-row--text-size .mt-a11y-actions {
    width: 100% !important;
    margin-left: 0 !important;
  }

  .mt-a11y-row--text-size .mt-a11y-actions button {
    flex: 1 1 0 !important;
  }
}
