/* Global HTML harmonization layer for all frontend pages. */
:root {
    --page-max-width: 480px;
}

html,
body {
    background-color: var(--color-background);
    color: var(--color-text-primary);
    font-family: var(--font-body);
}

body {
    min-height: 100dvh;
}

main {
    color: inherit;
}

a {
    color: var(--color-info);
}

a:hover {
    color: var(--color-primary);
}

input,
select,
textarea {
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

input::placeholder,
textarea::placeholder {
    color: var(--color-text-tertiary);
    opacity: 0.9;
}

input:focus,
select:focus,
textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.12);
}

button {
    font-family: var(--font-body);
    color: inherit;
}

.theme-card,
.app-card {
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
}

.theme-muted {
    color: var(--color-text-secondary);
}

.theme-subtle {
    color: var(--color-text-tertiary);
}

.theme-surface-soft {
    background-color: var(--color-surface-soft);
}

.theme-divider {
    border-color: var(--color-border);
}

.theme-max-width {
    max-width: var(--page-max-width);
    margin-left: auto;
    margin-right: auto;
}

/* Input icon alignment: prevent placeholder/text overlap with leading icons. */
.input-wrapper,
.search-wrapper {
    position: relative;
}

.input-wrapper > .input-icon,
.input-wrapper > .material-icons-round.input-icon,
.input-wrapper > i[class*="fa-"],
.search-wrapper > .search-icon {
    color: var(--color-text-secondary);
    pointer-events: none;
    z-index: 2;
}

.input-wrapper > .input-icon ~ input,
.input-wrapper > .input-icon ~ textarea,
.input-wrapper > .input-icon ~ select,
.input-wrapper > .material-icons-round.input-icon ~ input,
.input-wrapper > .material-icons-round.input-icon ~ textarea,
.input-wrapper > .material-icons-round.input-icon ~ select,
.input-wrapper > i[class*="fa-"] ~ input,
.input-wrapper > i[class*="fa-"] ~ textarea,
.input-wrapper > i[class*="fa-"] ~ select,
.search-wrapper > .search-icon ~ input,
.search-wrapper > .search-icon ~ textarea,
.search-wrapper > .search-icon ~ select {
    padding-left: 52px !important;
}

@supports selector(.input-wrapper:has(> .input-icon)) {
    .input-wrapper:has(> .input-icon) > input,
    .input-wrapper:has(> .input-icon) > textarea,
    .input-wrapper:has(> .input-icon) > select,
    .input-wrapper:has(> .material-icons-round.input-icon) > input,
    .input-wrapper:has(> .material-icons-round.input-icon) > textarea,
    .input-wrapper:has(> .material-icons-round.input-icon) > select,
    .input-wrapper:has(> i[class*="fa-"]) > input,
    .input-wrapper:has(> i[class*="fa-"]) > textarea,
    .input-wrapper:has(> i[class*="fa-"]) > select {
        padding-left: 44px !important;
    }
}

@supports selector(.search-wrapper:has(> .search-icon)) {
    .search-wrapper:has(> .search-icon) > input,
    .search-wrapper:has(> .search-icon) > textarea,
    .search-wrapper:has(> .search-icon) > select {
        padding-left: 52px !important;
    }
}

@supports selector(.input-wrapper:has(> .toggle-password)) {
    .input-wrapper:has(> .toggle-password) > input,
    .input-wrapper:has(> .password-toggle) > input,
    .input-wrapper:has(> .toggle-password) > textarea,
    .input-wrapper:has(> .password-toggle) > textarea {
        padding-right: 44px !important;
    }
}
