/*General style of page components with a custom selector (class / id)*/
/*HTML layout defaults are in the layout.css file*/

summary{
    cursor: pointer;
}

/* star adds specificity */
*.green-text, .green-text * {
    color: var(--green-text);
}
*.red-text, .green-text * {
    color: var(--danger-color);
}

.page-content-header-with-action-buttons {
    padding: 2px 0;
    display: flex;
    gap: 15px;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: baseline;
    margin-bottom: 25px;
}

.page-content-header-with-action-buttons h1, .page-content-header-with-action-buttons h2 {
    margin: 0;
    display: inline;
    line-height: 1;
}

.page-content-header-with-action-buttons button {
    font-size: 1rem;
}

/*Last of type is the action buttons*/
.page-content-header-with-action-buttons > div:last-of-type {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: baseline;
}

.secondary-header {
    margin: 0;
    font-size: 1.8em;
    color: var(--secondary-text-color);
    font-weight: 500;
}

.sticky-page-content-header {
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--background-color);
    transition: none 0.2s ease;
    padding: 20px 0 25px 0;
    margin-bottom: 2px;
    /*border-bottom:  transparent;*/
}

/*#title-and-action-button-container.scrolled*/
.sticky-page-content-header.scrolled {
    /*   Bottom shadow for the title and action button container when scrolled*/
    box-shadow: 0 0px 8px var(--background-color);
    /*border-bottom: var(--border-thickness) solid var(--border-color);*/
    border-bottom: var(--border-thickness) solid var(--border-color);
}


/*Divs*/
.clearfix::after {
    content: "";
    clear: both;
    display: table;
}

.no-animation-on-page-load {
    transition: none !important;
}

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

/*Example use-case: center title and plus button next to it*/
.vertical-center {
    display: flex;
    align-items: center;
    /*Add the margin to the group because it has been removed on the h1. Approximately same as normal h1 bottom margin*/
    margin-bottom: 25px;
}

/*Remove bottom margin when header is in vertical-center div to align all elements in the middle*/
.vertical-center h1 {
    margin-bottom: 0;
}

.filled-on-hover-icon-container img {
    filter: var(--theme-color-filter);
    width: 25px;
    cursor: pointer;
}

/*Toggle hover image*/
/*Last of type is hover / focus image and first of type is normal icon*/
.filled-on-hover-icon-container img:last-of-type {
    display: none;
}

.filled-on-hover-icon-container:hover img:first-of-type {
    display: none;
}

.filled-on-hover-icon-container:hover img:last-of-type {
    display: inline-block;
}

/*Button*/
.btn, .form-input-div input[type=submit], .submit-btn {
    background: none;
    color: var(--text-color);
    padding: 13px 25px;
    border: var(--border-thickness) solid var(--theme-color);
    font-weight: 400;
    border-radius: 10px;
    cursor: pointer;
    font-size: 1.1rem;
    /*box-shadow: 2px 3px 11px rgba(0, 0, 0, 0.2);*/
    text-decoration: none; /*For when <a> is used as button*/
    display: inline-block; /*For when <a> is used as button and when icon is used*/
    letter-spacing: 0.1px;
    transition: all 0.2s ease;

}

.btn:hover, .form-input-div input[type=submit]:hover, .submit-btn:hover {
    font-weight: normal !important; /*For when <a> to behave as button*/
    text-decoration: none; /*For when <a> is used as button*/
    background: var(--hover-background-color);
    /*box-shadow: 0 0 0 var(--border-thickness) var(--primary-color);*/
    transform: translateY(-1px);
}

/* Tailwind adds a max-width 100% to all images, so we need to remove it*/
.btn img {
    max-width: none;
}

.btn:focus, .form-input-div input[type=submit]:focus, .submit-btn:focus {
    outline: 3px solid var(--theme-color-2);
    outline-offset: 3px;
}

.btn:disabled {
    /*background: var(--background-accent-4-color);*/
    color: grey;
    cursor: default;
}

.btn:disabled:hover {
    background: none;
    transform: none;
}

.btn-primary {
    background: var(--theme-color);
    color: var(--color-on-primary);
}

.btn-primary:hover {
    background-color: var(--color-primary-hover);
}

.btn-no-border {
    border: none;
}

.btn-red {
    background-color: var(--btn-red-background);
    border-color: var(--btn-red-background);
    color: var(--danger-color);
    /*border: none;*/
}

.btn-red:hover {
    background-color: var(--btn-red-hover-background);
    /*filter: saturate(130%);*/
}

.btn-orange {
    background-color: var(--warning-bg-color);
}

.btn-orange:hover {
    filter: brightness(95%) saturate(130%);
}

.btn-orange:focus {
    filter: brightness(90%) saturate(140%);
}

.btn-green {
    background-color: var(--btn-green-background);
    border-color: var(--btn-green-background);
    color: var(--green-text);
}
.btn-green:hover {
    background-color: var(--btn-green-hover-background);
}
.btn-green:focus {
    filter: brightness(90%) saturate(120%);
}
.hover-background-color:hover {
    background-color: var(--hover-background-color);
}

.hover-background-color-2:hover {
    background-color: var(--hover-background-color-2);
}

.icon-in-btn {
    filter: var(--theme-color-filter);
    width: 16px;
}

.subdued-text {
    text-decoration: none;
    color: var(--gray-secondary-text-color);
    font-size: 14px;
    margin-top: 10px;
    display: inline-block;
}

.subdued-text:hover {
    color: var(--text-color);
    /*font-weight: 500;*/
    text-decoration: none !important;
}

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

.tertiary-text {
    color: var(--tertiary-text-color);
}
.lower-opacity-text {
    opacity: 0.8;
}

.no-wrap-text, .no-wrap-text-until-mobile {
    white-space: nowrap;
}

.outline-on-hover {
    transition: all 0.1s ease;
    border: none;
    outline: var(--border-thickness) solid var(--border-color);
}

.outline-on-hover:hover {
    /*box-shadow: 0 0 0 3px var(--theme-color-2);*/
    outline: 3px solid var(--border-color);
}

.outline-on-hover:focus {
    outline: 3px solid var(--theme-color);
}

/*Default icon color and size*/
.default-icon {
    height: 20px;
    /*filter: var(--primary-color-filter);*/
    filter: var(--theme-color-filter);
}

/* Custom cursor for links that open external pages (uses open-icon) */
.cursor-open-icon {
    /* Use the open-icon as cursor with pointer as fallback; no visual filters here to avoid affecting nested text */
    /*cursor: url("../general-img/action/open-icon-cursor-light.svg"), pointer;*/
}

/* Swap to a high-contrast white cursor in dark mode */
[data-theme="dark"] {
    .cursor-open-icon {
        /*cursor: url("../general-img/action/open-icon-cursor-dark.svg") 8 8, pointer;*/
    }
}

.always-white-icon {
    filter: invert(100%);
}

#recaptcha {
    display: none;
}

#recaptcha > div:first-of-type {
    margin-top: 15px;
    margin-bottom: 15px;
    border-radius: 50px;
}

.error-panel {
    display: block;
    padding: 12px 20px;
    border-radius: 15px;
    background: rgb(255, 189, 177);
    border-bottom: 3px solid #b25353;
}

.default-select {
    border-radius: 99px;
    padding: 5px;
    border: var(--border-thickness) solid var(--theme-color);
    background: var(--background-accent-2-color);
}

.default-select:disabled {
    filter: grayscale(0.7) brightness(95%);
    color: var(--black-white-opposite-theme);
}

/*disable resize on auto-resize-textareas*/
.auto-resize-textarea {
    resize: none;
}

.relative {
    position: relative;
}

[data-deleted="1"] {
    color: orangered;
}

.cursor-pointer {
    cursor: pointer;
}

/*Collapsible elements*/
.collapsible-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.2s ease-out;
}

.min-width-90, .min-width-90-on-desktop {
    min-width: 90px;
}

.min-width-120 {
    min-width: 120px;
}

.hidden {
    display: none !important;
}
hr {
    margin: 20px 0;
    border: none;
    border-bottom: var(--border-thickness) solid var(--border-color);
    border-radius: 99px;
}

/*Ipad mini and smaller*/
@media (max-width: 768px) {
    .no-wrap-text-until-mobile {
        white-space: normal;
        min-width: auto;
    }

    .sticky-page-content-header {
        /*Disable sticky on mobile*/
        position: relative;
    }

    .sticky-page-content-header.scrolled {
        border-bottom: none;
        box-shadow: none;
    }
}

/*mobile */
@media (max-width: 641px) {
    /*Twice to increase specificity*/
    .hidden-on-mobile.hidden-on-mobile {
        display: none;
    }

    .min-width-90-on-desktop {
        min-width: auto;
    }
}


