/* TODO: clean the style */
.positive {
    border: none;
    border-radius: 4px;
    box-shadow: 2px 3px var(--positive-color-shadow);
    background-color: var(--positive-color-background);
    text-align: center;
    color: var(--positive-color-text);
    cursor: pointer;
}

.neutral {
    border: none;
    border-radius: 4px;
    box-shadow: 2px 3px var(--neutral-color-shadow);
    background-color: var(--neutral-color-background);
    text-align: center;
    color: var(--neutral-color-text);
    cursor: pointer;
}

.positive i, .neutral i, .a i {
    font-size: 15px;
}

.button {
    display: block;
    min-width: 90px;
    min-height: 50px;
    margin: 10px auto 0 auto;
}

button.neutral:disabled {
    background-color: var(--disabled-color-background);
    box-shadow: 2px 3px var(--disabled-color-shadow);
    color: var(--disabled-color-text);
}

button.wait {
    cursor: wait;
}

/* Grid */
.button-a {
    display: inline-grid;
    grid-template-columns: auto auto;
    column-gap: 10px;
    justify-items: center;
    align-items: center;
    justify-content: center;
    align-content: center;
    min-width: 100px;
    min-height: 50px;
    padding: 5px;
}

/* center the Google button */
.g-signin2 {
    width: 100%;
}

.g-signin2 > div {
    width: 400px !important;
    margin: 0 auto 10px auto;
}

/* buttons inside tables */
.button-action {
    display: block;
    width: 70%;
    min-height: 25px;
    margin: 10px auto 0 auto;
    padding: 5px;
    border: none;
    border-radius: 4px;
    text-align: center;
}

.button-action i {
    font-size: 15px;
}

.button-action-delete, .button-action-archive, .button-action-unarchive {
    box-shadow: 2px 3px var(--negative-color-shadow);
    background-color: var(--negative-color-background);
    color: var(--negative-color-text);
}

.button-action-edit, .button-action-history, .button-action-reboot, .button-action-interfaces, .button-action-update, .button-action-statistics {
    box-shadow: 2px 3px var(--neutral-color-shadow);
    background-color: var(--neutral-color-background);
    color: var(--neutral-color-text);
}

.button-action-show {
    display: block;
    width: 15%;
    margin: 10px auto 10px auto;
    box-shadow: 2px 3px var(--neutral-color-shadow);
    background-color: var(--neutral-color-background);
    color: var(--neutral-color-text);
}

/* We want the FranceConnect button to not be styled like Cigale,
 * as is required by FranceConnect terms of use
 */
div.button-franceconnect a {
    color: blue;
    text-decoration: underline;
}
div.button-franceconnect a div {
    position: absolute;
}
div.button-franceconnect a div img {
    width: initial;
    margin-bottom: 8px;
}
div.button-franceconnect a div img.hover {
    position: absolute;
    top: 0;
    left: 0;
    display: none;
}
div.button-franceconnect a:hover img.hover {
    display: inline;
}
