/*
 * CKAN Accessibility Extension - High Contrast Mode
 * Clean, maintainable CSS with CSS variables and modern selectors
 */

/* ========== 0. ANTI-FLASH PROTECTION ========== */

/* Only hide content briefly if preferences are being restored */
html:not(.accessibility-preferences-loaded) {
    /* Very brief opacity reduction to prevent flash */
    opacity: 0.99;
    transition: opacity 0.05s ease-in;
}

/* Show content normally once preferences are loaded */
html.accessibility-preferences-loaded {
    opacity: 1;
    transition: opacity 0.05s ease-in;
}

/* ========== 1. FONT SIZE CLASSES ========== */
html.font-size-normal { font-size: 100%; }
html.font-size-extra-large { font-size: 150%; }

/* ========== 2. HIGH CONTRAST MODE VARIABLES ========== */
html.high-contrast-mode {
    --bg-main: #000000;
    --text-main: #ffffff;
    --accent-primary: #ffff00;
    --border-main: #ffffff;
    
    /* Inverted theme variables (yellow background) */
    --bg-inverted: var(--accent-primary);
    --text-inverted: var(--bg-main);
    --border-inverted: var(--bg-main);
    
    /* Button specific variables */
    --btn-primary-bg: var(--accent-primary);
    --btn-primary-text: var(--bg-main);
    --btn-primary-border: var(--bg-main);
    --btn-primary-hover-bg: var(--text-main);
    --btn-primary-hover-text: var(--bg-main);
    --btn-secondary-bg: var(--bg-main);
    --btn-secondary-text: var(--text-main);
    --btn-secondary-border: var(--border-main);
    --btn-secondary-hover-bg: var(--accent-primary);
    --btn-secondary-hover-text: var(--bg-main);
}

/* ========== 3. GLOBAL STYLES ========== */

/* Smooth transitions */
.high-contrast-mode,
.high-contrast-mode * {
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* Base background and text */
html.high-contrast-mode,
html.high-contrast-mode body {
    background-color: var(--bg-main) !important;
    color: var(--text-main) !important;
}

/* Focus and selection */
.high-contrast-mode *:focus-visible {
    outline: 4px solid var(--accent-primary) !important;
    outline-offset: 3px !important;
}

.high-contrast-mode ::selection {
    background-color: var(--accent-primary) !important;
    color: var(--bg-main) !important;
}

/* ========== 4. TYPOGRAPHY ========== */

/* General text elements */
.high-contrast-mode :is(p, span, li, ul, ol, td, label, strong, em, b, div:not(.module-search)) {
    background-color: transparent;
    color: inherit;
}

/* Headings */
.high-contrast-mode :is(h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6) {
    color: var(--text-main) !important;
    font-weight: 700 !important;
    border-bottom: 3px solid var(--accent-primary) !important;
    padding-bottom: 8px !important;
}

/* Links */
.high-contrast-mode a {
    color: var(--accent-primary) !important;
    text-decoration: underline !important;
    font-weight: 600 !important;
}

.high-contrast-mode a:is(:hover, :focus) {
    color: var(--bg-main) !important;
    background-color: var(--accent-primary) !important;
}

/* ========== 5. COMPONENTS ========== */

/* Standard components (black background) */
.high-contrast-mode :is(
    .form-control, .form-select, input, textarea, select,
    .table, .card:not(.module-search), .modal-content, .dropdown-menu,
    .context-info, .filters, .results, .dataset-list, .dataset-item
) {
    background-color: var(--bg-main) !important;
    color: var(--text-main) !important;
    border: 2px solid var(--border-main) !important;
}

/* Inverted components (yellow background) */
.high-contrast-mode :is(
    .masthead, .navbar, .card-header, .modal-header, .module-heading,
    .page-header, .account-masthead, footer, table th
) {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
}

/* ========== 14. SEARCH ICON FIXES ========== */

/* Reset search icon styles to prevent conflicts */
.high-contrast-mode .search-form button i,
.high-contrast-mode .search-form .btn i,
.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form button i,
.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form .btn i {
    font-size: 1em !important;
    margin: 0 !important;
    transform: none !important;
    transition: none !important;
}

/* Reset any other icons that might be affected */
.high-contrast-mode .navbar i,
.high-contrast-mode .masthead i,
.high-contrast-mode .module-search i:not(.accessibility-controls i) {
    font-size: 1em !important;
    margin: 0 !important;
    transform: none !important;
    transition: none !important;
}

/* Ensure search functionality works */
.high-contrast-mode .search-form button,
.high-contrast-mode .search-form .btn {
    background-color: var(--bg-main) !important;
    color: var(--text-main) !important;
    border: 2px solid var(--border-main) !important;
    padding: 8px 12px !important;
    font-size: 1rem !important;
    border-radius: 4px !important;
}

.high-contrast-mode .search-form button:hover,
.high-contrast-mode .search-form .btn:hover {
    background-color: var(--accent-primary) !important;
    color: var(--bg-main) !important;
    border-color: var(--accent-primary) !important;
    transform: none !important;
}

/* ========== 6. CONTEXTUAL OVERRIDES ========== */

/* Headings in inverted components */
.high-contrast-mode :is(.masthead, .navbar, .card-header, .modal-header, footer, .module-search) :is(h1, h2, h3, h4, h5, h6) {
    color: var(--text-inverted) !important;
    border-bottom: none !important;
}

/* Site title and logo */
.high-contrast-mode :is(.site-title, .site-description, .logo-text, .logo-text a) {
    color: var(--text-inverted) !important;
    background-color: transparent !important;
}

/* Links in inverted components */
.high-contrast-mode :is(.masthead, .navbar, footer, .account-masthead, .module-search) a {
    color: var(--text-inverted) !important;
    text-decoration: underline !important;
    font-weight: 700 !important;
}

.high-contrast-mode :is(.masthead, .navbar, footer, .account-masthead, .module-search) a:is(:hover, :focus) {
    color: var(--bg-main) !important;
    background-color: var(--text-main) !important;
}

/* ========== 7. SEARCH MODULE FIXES ========== */

/* Search module container */
.high-contrast-mode .module-search {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
}

/* Search input and placeholder */
.high-contrast-mode .module-search input,
.high-contrast-mode .module-search input::placeholder {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
}

/* Search button icon */
.high-contrast-mode .module-search .search-form button i {
    color: var(--text-inverted) !important;
    background-color: transparent !important;
}

/* Search form elements */
.high-contrast-mode .module-search .search-form {
    background-color: transparent !important;
}

.high-contrast-mode .module-search .search-form button {
    background-color: var(--bg-main) !important;
    color: var(--text-main) !important;
    border: 2px solid var(--border-main) !important;
}

/* ========== 8. MUSTERSTADT HOMEPAGE SEARCH ========== */

/* Musterstadt homepage search specific styles - MAXIMUM SPECIFICITY */
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search.card {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search.card.box {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .ster-home-search {
    background-color: transparent !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form {
    background-color: transparent !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-input {
    background-color: transparent !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .form-group {
    background-color: transparent !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-giant {
    background-color: transparent !important;
}

/* Specific input field styling - MAXIMUM SPECIFICITY */
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search #field-main-search,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .form-control,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search .form-control,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form .form-control {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
    font-weight: 600 !important;
    font-size: 1.1em !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search #field-main-search::placeholder,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .form-control::placeholder,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search .form-control::placeholder,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form .form-control::placeholder {
    color: var(--text-inverted) !important;
    opacity: 0.8 !important;
}

html.high-contrast-mode .homepage .hero.musterstadt-homepage-search #field-main-search:focus,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .form-control:focus,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search .form-control:focus,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form .form-control:focus {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 4px solid var(--border-inverted) !important;
    box-shadow: 0 0 0 0.3rem rgba(0, 0, 0, 0.3) !important;
}

/* Force override any existing styles */
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search * {
    background-color: inherit !important;
    color: inherit !important;
}

/* Specific override for the search input */
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search input[type="text"],
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search input[type="search"],
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search input.form-control {
    background-color: var(--bg-inverted) !important;
    color: var(--text-inverted) !important;
    border: 3px solid var(--border-inverted) !important;
    font-weight: 600 !important;
    font-size: 1.1em !important;
}

/* ========== 9. SEARCH CONTAINER & ICON FIXES ========== */

/* Remove borders from search container */
html.high-contrast-mode .module-search,
html.high-contrast-mode .module-search.card,
html.high-contrast-mode .module-search.card.box,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search.card,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .module-search.card.box {
    border: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
}

/* Remove borders from search form elements */
html.high-contrast-mode .search-form,
html.high-contrast-mode .search-input,
html.high-contrast-mode .form-group,
html.high-contrast-mode .search-giant,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-input,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .form-group,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-giant {
    border: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
}

/* Fix search icon and remove its border */
html.high-contrast-mode .search-form button,
html.high-contrast-mode .search-form button i,
html.high-contrast-mode .search-form .btn,
html.high-contrast-mode .search-form .btn i,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form button,
html.high-contrast-mode .homepage .hero.musterstadt-homepage-search .search-form button i {
    border: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
    color: #000000 !important;
}

/* Remove any input group styling */
html.high-contrast-mode .input-group,
html.high-contrast-mode .input-group-text,
html.high-contrast-mode .input-group-append,
html.high-contrast-mode .input-group-prepend {
    border: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
}

/* Remove any additional borders from search components */
html.high-contrast-mode .ster-home-search,
html.high-contrast-mode .module-content {
    border: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
}

/* ========== 10. AGGRESSIVE OVERRIDES ========== */

/* Nuclear option - override everything for the search field */
html.high-contrast-mode input#field-main-search {
    background-color: #ffff00 !important;
    color: #000000 !important;
    border: 3px solid #000000 !important;
    font-weight: 600 !important;
    font-size: 1.1em !important;
}

html.high-contrast-mode input#field-main-search::placeholder {
    color: #000000 !important;
    opacity: 1 !important;
}

html.high-contrast-mode .btn-default {
    background-color: #ffff00 !important;
    color: #000000 !important;
    border: 3px solid #000000 !important;
}   


html.high-contrast-mode input#field-main-search:focus {
    background-color: #ffff00 !important;
    color: #000000 !important;
    border: 4px solid #000000 !important;
    box-shadow: 0 0 0 0.3rem rgba(0, 0, 0, 0.3) !important;
}

/* Override any Musterstadt theme styles */
html.high-contrast-mode .musterstadt-homepage-search {
    background-color: #ffff00 !important;
}

html.high-contrast-mode .musterstadt-homepage-search * {
    background-color: inherit !important;
    color: inherit !important;
}

html.high-contrast-mode .musterstadt-homepage-search input {
    background-color: #ffff00 !important;
    color: #000000 !important;
    border: 3px solid #000000 !important;
}

/* ========== 11. FRONT CATEGORIES ========== */

/* Front categories styling */
html.js.high-contrast-mode body div.homepage div.container.front-categories div.front-categories div.view-content div.grid-2 div span a {
    color: var(--text-inverted) !important;
    background-color: var(--accent-primary) !important;
}

/* ========== 12. SCROLLBAR ========== */

.high-contrast-mode ::-webkit-scrollbar {
    width: 16px !important;
}

.high-contrast-mode ::-webkit-scrollbar-track {
    background: var(--bg-main) !important;
}

.high-contrast-mode ::-webkit-scrollbar-thumb {
    background: var(--accent-primary) !important;
    border: 2px solid var(--border-main) !important;
    border-radius: 8px !important;
}

.high-contrast-mode ::-webkit-scrollbar-thumb:hover {
    background: var(--text-main) !important;
}

/* .accessibility-btn {
    font-size: 0.8rem;
    padding: 0.5rem 1rem;
    margin: 0 4px;
    border-radius: 6px;
    border: 2px solid #222;
    background-color: #fff;
    color: #111;
    transition: all 0.2s ease;
    box-shadow: 0 1px 3px rgba(0,0,0,0.12);
    position: relative;
    overflow: hidden;
    font-weight: 600;
    letter-spacing: 0.02em;
    outline: none;
} */

.accessibility-btn {
    font-size: 0.8rem;
    vertical-align: text-bottom;
    padding: 0.1rem 1rem;
    margin: 0 4px;
    border-radius: 6px;
    border: none;
    background-color: transparent;
    color: #111;
    transition: all 0.2s ease;
    box-shadow: none;
    position: relative;
    overflow: hidden;
    font-weight: 600;
    letter-spacing: 0.02em;
    outline: none;
}

#accessibility-btn-font-normal {
    font-size: 0.6rem;
}

.accessibility-last-listelement {
    margin-right: 30px;
}




.accessibility-btn:focus {
    outline: 3px solid #0056b3;
    outline-offset: 2px;
    z-index: 2;
}

.accessibility-btn:hover,
.accessibility-btn:focus-visible {
    background-color: #e9ecef;
    color: #000;
    border-color: #0056b3;
    box-shadow: 0 3px 8px rgba(0,0,0,0.18);
    text-decoration: underline;
}

.accessibility-btn:active {
    background-color: #d6d8db;
    color: #000;
    border-color: #0056b3;
    box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}

.accessibility-btn.active {
    background-color: #0056b3 !important;
    border-color: #0056b3 !important;
    color: #fff !important;
    box-shadow: 0 2px 6px rgba(0,86,179,0.25);
    font-weight: 700;
    text-decoration: underline;
}

.accessibility-btn.active:hover,
.accessibility-btn.active:focus-visible {
    background-color: #003366 !important;
    border-color: #003366 !important;
    box-shadow: 0 4px 10px rgba(0,86,179,0.35);
}

.accessibility-btn i {
    margin-right: 6px;
    font-size: 1.5em;
    vertical-align: middle;
}

.accessibility-btn .btn-text {
    font-weight: 700;
    font-size: 1em;
    letter-spacing: 0.01em;
}

.high-contrast-mode .accessibility-btn {
    background-color: #000 !important;
    border-color: #fff !important;
    color: #fff !important;
    box-shadow: 0 1px 3px rgba(255,255,0,0.25);
}

.high-contrast-mode .accessibility-btn:hover,
.high-contrast-mode .accessibility-btn:focus-visible {
    background-color: #222 !important;
    border-color: #ffff00 !important;
    color: #000 !important;
    box-shadow: 0 3px 8px rgba(255,255,0,0.35);
    text-decoration: underline;
}

.high-contrast-mode .accessibility-btn.active {
    background-color: #ffff00 !important;
    border-color: #000 !important;
    color: #000 !important;
    box-shadow: 0 2px 6px rgba(255,255,0,0.5);
    font-weight: 900;
    text-decoration: underline;
}

.high-contrast-mode .accessibility-btn.active:hover,
.high-contrast-mode .accessibility-btn.active:focus-visible {
    background-color: #fff200 !important;
    border-color: #000 !important;
    color: #000 !important;
    box-shadow: 0 4px 10px rgba(255,255,0,0.7);
}

/* ========== 12. SCROLLBAR ========== */


.accessibility-controls {
    margin-right: 15px;
    display: inline-block;
    left: 40%;
    position: relative;
}