/* =====================================================================
   Accessibility Widget Styles
   Healing Heroes Hawaii
   Carry-over from RaneWorks standard, palette retuned to HHH brand:
     Primary CTA color : Ocean Blue (#1F6FB2)
     Focus / accent    : Aqua (#5BC0EB)
     Reset destructive : Crimson (#B71C1C)
   The widget is brand-agnostic in markup -- only colors changed.
===================================================================== */

.accessibility-widget {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 10000;
  font-family: 'Open Sans', 'Segoe UI', sans-serif;
}

.accessibility-toggle {
  background: #1F6FB2;
  color: #ffffff;
  border: none;
  border-radius: 50px;
  padding: 12px 16px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 4px 12px rgba(11, 42, 74, 0.25);
  transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  min-height: 44px;
  min-width: 44px;
}

.accessibility-toggle:hover,
.accessibility-toggle:focus {
  background: #0B2A4A;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(11, 42, 74, 0.35);
  outline: 3px solid #5BC0EB;
  outline-offset: 2px;
}

.accessibility-toggle svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.accessibility-panel {
  position: fixed;
  bottom: 80px;
  right: 20px;
  background: #ffffff;
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(11, 42, 74, 0.18);
  padding: 20px;
  width: 300px;
  max-width: calc(100vw - 40px);
  display: none;
  z-index: 10000;
  border: 1px solid #e0e0e0;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.accessibility-panel.show {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.accessibility-panel h3 {
  margin: 0 0 16px 0;
  font-size: 18px;
  color: #0B2A4A;
  font-weight: 700;
  font-family: 'Montserrat', sans-serif;
}

.accessibility-presets,
.accessibility-adjustments { margin-bottom: 20px; }

.accessibility-presets h4,
.accessibility-adjustments h4 {
  margin: 0 0 8px 0;
  font-size: 14px;
  color: #333;
  font-weight: 700;
}

.preset-buttons { display: flex; gap: 8px; flex-wrap: wrap; }

.preset-btn {
  background: #f5f5f5;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 8px 12px;
  font-size: 12px;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  min-height: 32px;
}
.preset-btn:hover,
.preset-btn:focus {
  background: #e7f3fb;
  outline: 2px solid #5BC0EB;
  outline-offset: 1px;
}
.preset-btn.active {
  background: #1F6FB2;
  color: #ffffff;
  border-color: #1F6FB2;
}

.adjustment-group { margin-bottom: 12px; }

.adjustment-group .adjustment-label {
  display: block;
  font-size: 12px;
  color: #666;
  margin-bottom: 4px;
  font-weight: 700;
}

.adjustment-controls { display: flex; align-items: center; gap: 8px; }

.adjustment-btn {
  background: #f5f5f5;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 6px 10px;
  font-size: 12px;
  cursor: pointer;
  transition: background 0.2s;
  min-height: 28px;
  min-width: 28px;
}
.adjustment-btn:hover,
.adjustment-btn:focus {
  background: #e7f3fb;
  outline: 2px solid #5BC0EB;
  outline-offset: 1px;
}

.adjustment-value {
  font-size: 12px;
  color: #333;
  min-width: 50px;
  text-align: center;
}

.accessibility-reset {
  background: #B71C1C;
  color: #ffffff;
  border: none;
  border-radius: 4px;
  padding: 8px 16px;
  font-size: 12px;
  cursor: pointer;
  transition: background 0.2s;
  width: 100%;
  min-height: 32px;
}
.accessibility-reset:hover,
.accessibility-reset:focus {
  background: #8b1414;
  outline: 2px solid #5BC0EB;
  outline-offset: 1px;
}

/* ---------- High-contrast theme ---------- */
body.accessibility-high-contrast {
  background: #000000 !important;
  color: #ffffff !important;
}
body.accessibility-high-contrast a { color: #ffff00 !important; }
body.accessibility-high-contrast a:hover,
body.accessibility-high-contrast a:focus {
  color: #ffffff !important;
  background: #333333 !important;
}
body.accessibility-high-contrast h1,
body.accessibility-high-contrast h2,
body.accessibility-high-contrast h3,
body.accessibility-high-contrast h4,
body.accessibility-high-contrast h5,
body.accessibility-high-contrast h6 { color: #ffffff !important; }
body.accessibility-high-contrast .accessibility-panel {
  background: #000000 !important;
  color: #ffffff !important;
  border: 3px solid #ffffff !important;
}
body.accessibility-high-contrast .accessibility-panel h3,
body.accessibility-high-contrast .accessibility-presets h4,
body.accessibility-high-contrast .accessibility-adjustments h4,
body.accessibility-high-contrast .adjustment-group .adjustment-label,
body.accessibility-high-contrast .adjustment-value { color: #ffffff !important; }
body.accessibility-high-contrast .preset-btn,
body.accessibility-high-contrast .adjustment-btn {
  background: #ffffff !important;
  color: #000000 !important;
  border: 2px solid #ffffff !important;
}
body.accessibility-high-contrast .preset-btn:hover,
body.accessibility-high-contrast .preset-btn:focus,
body.accessibility-high-contrast .adjustment-btn:hover,
body.accessibility-high-contrast .adjustment-btn:focus {
  background: #ffff00 !important;
  color: #000000 !important;
}
body.accessibility-high-contrast .preset-btn.active {
  background: #000000 !important;
  color: #ffff00 !important;
  border-color: #ffff00 !important;
}
body.accessibility-high-contrast .accessibility-reset {
  background: #ff0000 !important;
  color: #ffffff !important;
  border: 2px solid #ffffff !important;
}
body.accessibility-high-contrast #page-footer { background: #000000 !important; }

/* ---------- Dark theme ---------- */
body.accessibility-dark {
  background: #1a1a1a !important;
  color: #e0e0e0 !important;
}
body.accessibility-dark a { color: #5BC0EB !important; }
body.accessibility-dark a:hover,
body.accessibility-dark a:focus { color: #ffffff !important; }
body.accessibility-dark h1,
body.accessibility-dark h2,
body.accessibility-dark h3,
body.accessibility-dark h4,
body.accessibility-dark h5,
body.accessibility-dark h6 { color: #ffffff !important; }
body.accessibility-dark .accessibility-panel {
  background: #2a2a2a !important;
  color: #e0e0e0 !important;
  border-color: #444 !important;
}
body.accessibility-dark .accessibility-panel h3,
body.accessibility-dark .accessibility-presets h4,
body.accessibility-dark .accessibility-adjustments h4,
body.accessibility-dark .adjustment-group .adjustment-label,
body.accessibility-dark .adjustment-value { color: #e0e0e0 !important; }
body.accessibility-dark .preset-btn,
body.accessibility-dark .adjustment-btn {
  background: #444 !important;
  color: #e0e0e0 !important;
  border-color: #666 !important;
}
body.accessibility-dark .preset-btn:hover,
body.accessibility-dark .preset-btn:focus,
body.accessibility-dark .adjustment-btn:hover,
body.accessibility-dark .adjustment-btn:focus { background: #666 !important; }
body.accessibility-dark .preset-btn.active {
  background: #5BC0EB !important;
  color: #0B2A4A !important;
  border-color: #5BC0EB !important;
}
body.accessibility-dark #page-footer { background: #1a1a1a !important; }

/* ---------- Text size adjustments ---------- */
body.accessibility-text-small  { font-size: 0.85em !important; }
body.accessibility-text-large  { font-size: 1.15em !important; }
body.accessibility-text-xlarge { font-size: 1.35em !important; }

/* ---------- Line spacing adjustments ---------- */
body.accessibility-spacing-tight,
body.accessibility-spacing-tight * { line-height: 1.2 !important; }

body.accessibility-spacing-loose,
body.accessibility-spacing-loose * { line-height: 1.7 !important; }

/* ---------- Mobile ---------- */
@media (max-width: 768px) {
  .accessibility-widget { bottom: 10px; right: 10px; }
  .accessibility-toggle { padding: 10px 12px; font-size: 12px; min-height: 40px; min-width: 40px; }
  .accessibility-panel { bottom: 60px; right: 10px; left: 10px; width: auto; max-width: none; padding: 16px; }
  .accessibility-panel h3 { font-size: 16px; margin-bottom: 12px; }
  .preset-buttons { flex-direction: column; gap: 8px; }
  .adjustment-group { display: flex; flex-direction: column; align-items: flex-start; }
  .adjustment-controls { display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: 200px; }
}
@media (max-width: 480px) {
  .accessibility-widget { bottom: 5px; right: 5px; }
  .accessibility-toggle { padding: 8px 10px; min-height: 36px; min-width: 36px; }
  .accessibility-toggle svg { width: 18px; height: 18px; }
  .accessibility-panel { bottom: 50px; right: 5px; left: 5px; padding: 12px; }
}

/* Visually hidden helper for screen-reader announcements */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}
