/*
 * Copyright (C) 2020  Yomichan Authors
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 */

/* Variables */
:root {
    --padding: 10px;
    --main-content-size: 700px;
    --main-content-padding: 10px;
    --shadow-color: rgba(0, 0, 0, 0.185);
    --shadow-vertical: 0 1px 4px 0 var(--shadow-color), 0 2px 2px 0 var(--shadow-color);

    --font-size-default: 14px;
    --line-height-default: calc(20 / 14);
    --thin-border-size: 1px;
    --toggle-size: 16px;

    --textarea-line-height: 1.25em;
    --textarea-padding: 0.5em;

    --animation-duration: 0s;
    --animation-duration2: calc(var(--animation-duration) * 2);

    --material-arrow-dimension1: 5px;
    --material-arrow-dimension2: 10px;
    --input-height: 32px;
    --input-width-large: 200px;

    --text-color-default: #222222;
    --background-color: #ffffff;
    --background-color-light: #ffffff;
    --input-background-color: #f2f2f2;
    --input-background-color-dark: #dddddd;
    --input-background-color-darker: #cccccc;
    --separator-color1: #cccccc;
    --button-icon-color: #333333;
    --toggle-track-color: #cccccc;
    --toggle-knob-color: #ffffff;
    --selectable-indicator-color: rgba(160, 160, 160, 0.25);
    --disabled-color: #aaaaaa;
    --disabled-color-light: #dddddd;
    --disabled-color-lighter: #eeeeee;
    --accent-color: #1a73e8;
    --accent-color-lighter: #8db9f4;
    --accent-color-transparent25: rgba(28, 116, 233, 0.25);
}
:root[data-loaded=true] {
    --animation-duration: 0.125s;
}
:root[data-yomichan-theme=dark] {
    --text-color-default: #d8d8d8;
    --background-color: #1e1e1e;
    --shadow-color: rgba(255, 255, 255, 0.185);
    --separator-color1: #cccccc;
    --input-background-color: #2f2f2f;
    --input-background-color-dark: #383838;
    --input-background-color-darker: #484848;
    --selectable-indicator-color: rgba(100, 100, 100, 0.25);
    --button-icon-color: #cccccc;
    --disabled-color: #444444;
    --disabled-color-light: #585858;
    --disabled-color-lighter: #777777;
}

/* Common styles */
:root {
    height: 100%;
}
body {
    background-color: var(--background-color);
    margin: 0;
    padding: 0;
    margin: 0;
    font-size: var(--font-size-default);
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    color: var(--text-color-default);
    line-height: var(--line-height-default);
    height: 100%;
    overflow: hidden;
}
h1 {
    font-size: 2em;
    line-height: 1.5em;
    margin: 0;
    padding: 0.25em 0 0;
    font-weight: normal;
    box-sizing: border-box;
    border-bottom: var(--thin-border-size) solid var(--separator-color1);
}

/* Material design select */
select {
    width: var(--input-width-large);
    height: var(--input-height);
    line-height: var(--input-height);
    border: 0;
    border-radius: 0;
    box-sizing: border-box;
    padding: 0 0.5em;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url(/mixed/img/material-down-arrow.svg);
    background-repeat: no-repeat;
    background-position: right var(--padding) center;
    background-color: var(--input-background-color);
    background-size: var(--material-arrow-dimension2) var(--material-arrow-dimension1);
    cursor: pointer;
    outline: 0;
}
select::-ms-expand {
    display: none;
}

/* Material design toggle switch */
label.toggle {
    cursor: default;
}
.toggle {
    font-size: var(--toggle-size);
    display: inline-block;
}
.toggle>input[type=checkbox] {
    opacity: 0;
    width: 0;
    height: 0;
    display: block;
    margin: 0;
    padding: 0;
    border: none;
    appearance: none;
    -moz-appearance: none;
}
.toggle-body {
    display: block;
    cursor: pointer;
    width: 2em;
    height: 1em;
    position: relative;
}
.toggle-track {
    display: block;
    position: absolute;
    left: 0.125em;
    right: 0.125em;
    top: 0.125em;
    bottom: 0.125em;
    background-color: var(--toggle-track-color);
    border-radius: 0.4375em;
    transition: background-color var(--animation-duration) ease-in-out;
}
.toggle-knob {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 1em;
    height: 1em;
    background-color: var(--toggle-knob-color);
    border-radius: 0.5em;
    box-shadow: var(--shadow-vertical);
    transition: transform var(--animation-duration) ease-in-out,
                background-color var(--animation-duration) ease-in-out;
}
.toggle-body>.toggle-knob::after {
    position: absolute;
    display: block;
    content: "";
    left: -0.75em;
    top: -0.75em;
    right: -0.75em;
    bottom: -0.75em;
    border-radius: 2.5em;
    background-color: var(--selectable-indicator-color);
    pointer-events: none;
    transform: scale(0);
    opacity: 0;
    visibility: hidden;
    transition: transform 0s ease-in-out var(--animation-duration2),
                background-color var(--animation-duration2) ease-in-out,
                opacity var(--animation-duration2) ease-in-out,
                visibility 0s ease-in-out var(--animation-duration2);
}
.toggle>input[type=checkbox]:focus:not(:disabled)+.toggle-body>.toggle-knob::after,
.toggle:active>input[type=checkbox]:not(:disabled)+.toggle-body>.toggle-knob::after {
    transform: scale(1);
    opacity: 1;
    visibility: visible;
    transition: transform var(--animation-duration2) ease-in-out,
                background-color var(--animation-duration2) ease-in-out,
                opacity var(--animation-duration2) ease-in-out,
                visibility var(--animation-duration2) ease-in-out;
}
.toggle>input[type=checkbox]:focus+.toggle-body>.toggle-knob::after {
    opacity: 0.5;
}
.toggle:active>input[type=checkbox]:focus+.toggle-body>.toggle-knob::after {
    opacity: 1;
}
.toggle>input[type=checkbox]:checked+.toggle-body>.toggle-knob {
    transform: translateX(1em);
}
.toggle>input[type=checkbox]:checked:not(:disabled)+.toggle-body>.toggle-track {
    background-color: var(--accent-color-lighter);
}
.toggle>input[type=checkbox]:checked:not(:disabled)+.toggle-body>.toggle-knob {
    background-color: var(--accent-color);
}
.toggle>input[type=checkbox]:focus:checked:not(:disabled)+.toggle-body>.toggle-knob::after,
.toggle:active>input[type=checkbox]:checked:not(:disabled)+.toggle-body>.toggle-knob::after {
    background-color: var(--accent-color-transparent25);
}
.toggle>input[type=checkbox]:disabled+.toggle-body {
    cursor: default;
}
.toggle>input[type=checkbox]:disabled+.toggle-body>.toggle-track {
    background-color: var(--disabled-color-light);
}
.toggle>input[type=checkbox]:disabled+.toggle-body>.toggle-knob {
    background-color: var(--disabled-color-lighter);
}

/* Content layout */
.content {
    flex: 1 0 auto;
    flex-flow: row nowrap;
    width: 100%;
    display: flex;
    position: relative;
    align-items: stretch;
    justify-content: center;
}
.content-center {
    flex: 1 1 auto;
    width: var(--main-content-size);
    padding: 0 var(--main-content-padding);
    max-width: var(--main-content-size);
    box-sizing: border-box;
}

/* Search bar */
.search-textbox-container {
    display: flex;
    flex-flow: row nowrap;
    width: 100%;
    align-items: stretch;
    margin: 0;
    padding: 0;
    border: 0;
}
#search-textbox {
    color: var(--text-color-default);
    flex: 1 1 auto;
    box-sizing: border-box;
    padding: var(--textarea-padding);
    font-family: 'Courier New', Courier, monospace;
    background-color: var(--input-background-color);
    border-radius: 0;
    line-height: var(--textarea-line-height);
    border: 0;
    outline: none;
    width: 100%;
    height: calc(var(--textarea-line-height) + var(--textarea-padding) * 2);
    min-height: calc(var(--textarea-line-height) + var(--textarea-padding) * 2);
    max-height: calc(var(--textarea-line-height) * 10 + var(--textarea-padding) * 2);
    resize: vertical;
    font-size: var(--font-size-default);
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    color: var(--text-color-default);
    white-space: pre-wrap;
}
#search-button {
    flex: 0 0 auto;
    position: relative;
    width: 2.5em;
    background-color: var(--input-background-color);
    border: 0;
    padding: 0;
    margin: 0;
    cursor: pointer;
    outline: none;
    transition: background-color var(--animation-duration) ease-in-out;
}
#search-button:hover,
#search-button:focus {
    background-color: var(--input-background-color-dark);
}
#search-button:active {
    background-color: var(--input-background-color-darker);
}

.icon-button-icon {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background-color: var(--button-icon-color);
    mask-repeat: no-repeat;
    mask-position: center center;
    mask-mode: alpha;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center center;
    -webkit-mask-mode: alpha;
}
.icon-button-icon[data-icon=magnifying-glass] {
    mask-image: url(/mixed/img/magnifying-glass.svg);
    -webkit-mask-image: url(/mixed/img/magnifying-glass.svg);
    mask-size: 16px 16px;
    -webkit-mask-size: 16px 16px;
}

/* Search options */
.search-options {
    display: flex;
    flex-flow: row wrap;
    margin: 0.5em -1em;
    align-items: center;
}
.search-option {
    flex: 0 1 auto;
    margin: 0.5em 1em;
    align-items: center;
    cursor: pointer;
}
.search-option:not([hidden]) {
    display: flex;
}
.search-option-label {
    padding-left: 0.5em;
}
.search-option-pre-label {
    padding-right: 0.5em;
}
#query-parser-mode-container {
    flex: 1 1 auto;
}
#query-parser-mode-container:not([hidden]) {
    display: flex;
}
#query-parser-mode-select {
    flex: 1 1 auto;
    max-width: 220px;
    min-width: 100px;
}

/* Search styles */
#intro {
    overflow: hidden;
}
#intro>p {
    margin: 0;
}

#query-parser-content:not(:empty) {
    border-bottom: var(--thin-border-size) solid var(--separator-color1);
    padding-bottom: 0.5em;
}