/* Flex align directions */
.align-top {
    display: flex;
    align-items: flex-start;
}

.align-middle {
    display: flex;
    align-items: center;
}

.align-bottom {
    display: flex;
    align-items: flex-end;
}

.align-left {
    display: flex;
    justify-content: flex-start;
}

.align-center {
    display: flex;
    justify-content: center;
}

.align-between {
    display: flex;
    justify-content: space-between;
}

.align-right {
    display: flex;
    justify-content: flex-end;
}

.middle-center {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* center of container (multiple objects set horizontally) */
.middle-center-rows {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column
}

/* center of container (multiple objects set vertically) */
.aligned-text {
    text-align: justify;
    hyphens: auto;
    -moz-hyphens: auto;
    -webkit-hyphens: auto;
}

/* full aligned text with hyphens */

/* Popup position */
.upright-pos {
    position: absolute;
    right: var(--grid-space);
    top: var(--grid-space);
    z-index: 1
}

.float-right {
    float: right
}

/* Spacing */
.p-space {
    padding: var(--grid-space)
}

.py-space {
    padding-block: var(--grid-space)
}

.px-space {
    padding-inline: var(--grid-space)
}

.pr-space {
    padding-right: var(--grid-space)
}

.pl-space {
    padding-left: var(--grid-space)
}

.pt-space {
    padding-top: var(--grid-space)
}

.pb-space {
    padding-bottom: var(--grid-space)
}

.p-space {
    margin: var(--grid-space)
}

.my-space {
    margin-block: var(--grid-space)
}

.mx-space {
    margin-inline: var(--grid-space)
}

.mr-space {
    margin-right: var(--grid-space)
}

.ml-space {
    margin-left: var(--grid-space)
}

.mt-space {
    margin-top: var(--grid-space)
}

.mb-space {
    margin-bottom: var(--grid-space)
}

.my-gap {
    margin-block: var(--section-gap)
}

.mx-gap {
    margin-inline: var(--section-gap)
}

.mr-gap {
    margin-right: var(--section-gap)
}

.ml-gap {
    margin-left: var(--section-gap)
}

.mt-gap {
    margin-top: var(--section-gap)
}

.mb-gap {
    margin-bottom: var(--section-gap)
}

/**********************************/
/* LIQUID RESPONSIVE rem UNIT SIZE
    It smoothly and progressively resize the root's font size (it reflects to rem unit),
    starting from min-fontsize at minimum viewport width, until and max-fontsize at maximum viewport width */
:root {
    --min-width: 992; /* ◄ define the minimum viewport in pixels (without "px" unit) */
    --min-fontsize: 12; /* ◄ define the corresponding minimum font-size in pixels (without "px" unit) */
    --max-width: 1440; /* ◄ define the maximum viewport in pixels (without "px" unit) */
    --max-fontsize: 16; /* ◄ define the corresponding maximum font-size in pixels (without "px" unit) */
    --liq-fontsize: calc(var(--min-fontsize) * 1px + (var(--max-fontsize) - var(--min-fontsize)) * ((100vw - var(--min-width) * 1px) / (var(--max-width) - var(--min-width))));
}

html {
    font-size: calc(var(--min-fontsize) * 1px);
}

/* ▼ You should fill manually the @media min/max widths bellow (because property doesn't accept css variables) */
@media all and (min-width: 992px) /* ◄ paste manually the variable's "--min-width" defined value (trailed with "px" unit)*/ {
    html {
        font-size: var(--liq-fontsize)
    }
}

@media all and (min-width: 1400px) /* ◄ paste manually the variable's "--max-width" defined value (trailed with "px" unit)*/ {
    html {
        font-size: calc(var(--max-fontsize) * 1px);
    }
}

/**********************************/


body { /* font-family:'Manrope'; */
    interpolate-size: allow-keywords
}

section:not(.no-margins) {
    margin-bottom: var(--section-gap)
}

.area {
    padding: var(--grid-space);
    border-radius: var(--radiusValue);
    background-color: var(--lightergrey);
}

.row:has(>.area) {
    margin: var(--grid-space);
    gap: var(--grid-space);
}

hr {
    width: 100%;
    height: 1px;
    margin-block: var(--grid-space);
    border: none;
    box-shadow: -3px 1px 3px 0px #FFF, 3px 1px 3px 0px #FFF, 0px -1px 0px 0px #0001;
}

img.notFound {
    background-color: var(--primary) !important;
    padding: 20% !important;
    object-fit: contain !important
}

:has(> .overlink) {
    position: relative !important
}

.overlink {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

/* Disable bootstrap outline */
.aabtn.focus, .aabtn:focus, .btn-link.focus, .btn-link:focus, .nav-link.focus, .nav-link:focus, .editor_atto_toolbar button.focus,
.editor_atto_toolbar button:focus, .editor_atto_toolbar .atto_toolbar_row.focus, .editor_atto_toolbar .atto_toolbar_row:focus,
[role="button"].focus, [role="button"]:focus, .list-group-item-action.focus, .list-group-item-action:focus, input[type="checkbox"].focus,
input[type="checkbox"]:focus, input[type="radio"].focus, input[type="radio"]:focus, input[type="file"].focus, input[type="file"]:focus,
input[type="image"].focus, input[type="image"]:focus, .sr-only-focusable.focus, .sr-only-focusable:focus,
a.dropdown-toggle.focus, a.dropdown-toggle:focus, .moodle-dialogue-base .closebutton.focus, .moodle-dialogue-base
.closebutton:focus, button.close.focus, button.close:focus, .form-autocomplete-selection.focus, .form-autocomplete-selection:focus,
[role="treeitem"]:not([aria-expanded="true"]).focus, [role="treeitem"]:not([aria-expanded="true"]):focus {
    box-shadow: none
}

/****************************/


/* ----------------------- OBJECTS ----------------------- */

/* Buttons */
.inline-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--grid-space)
}

.inline-buttons .item {
    flex: 1 0 min-content;
    padding: var(--grid-space);
    border-radius: var(--radiusValue);
    text-decoration: none;
    transition: 0.5s background-color, 0.5s color, 0.5s fill;
}

.inline-buttons .item.active {
    pointer-events: none
}

.inline-buttons.as-single {
    gap: calc(var(--grid-space) / 4)
}

.inline-buttons.as-single .item {
    border-radius: 0;
}

.inline-buttons.as-single .item:first-of-type {
    border-top-left-radius: var(--radiusValue);
    border-bottom-left-radius: var(--radiusValue);
}

.inline-buttons.as-single .item:last-of-type {
    border-top-right-radius: var(--radiusValue);
    border-bottom-right-radius: var(--radiusValue);
}

.block-buttons .item {
    display: block;
    padding: var(--grid-space);
    margin-block: var(--grid-space);
    border: none;
    border-radius: var(--radiusValue);
    text-decoration: none;
    white-space: pre-line;
    transition: 0.5s background-color, 0.5s color
}

.block-buttons .item.active {
    pointer-events: none
}

.block-buttons .item:first-of-type {
    margin-top: 0 !important
}

.block-buttons .item:last-of-type {
    margin-bottom: 0 !important
}

.block-buttons.as-single .item {
    border-radius: 0;
    margin-block: calc(var(--grid-space) / 4)
}

.block-buttons.as-single .item:first-of-type {
    border-top-left-radius: var(--radiusValue);
    border-top-right-radius: var(--radiusValue);
}

.block-buttons.as-single .item:last-of-type {
    border-bottom-left-radius: var(--radiusValue);
    border-bottom-right-radius: var(--radiusValue);
}


/* Block title */
.block-title {
    width: 100%;
    padding: calc(var(--grid-space));
    margin-bottom: var(--grid-space);
    border-radius: var(--radiusValue);
    background-color: var(--primary);
    color: #FFF;
}

.block-title * {
    margin: 0;
}

.block-title .btn {
    width: fit-content
}

@container (max-width:400px) {
    .block-title {
        flex-direction: column
    }

    .block-title * {
        text-align: center
    }

    .block-title .btn {
        margin-inline: auto;
        margin-top: var(--grid-space)
    }
}


/* Action item menu */
.actions .dropdown-menu {
    display: block !important;
    padding: 0.25rem !important;
    transform: translate3d(0px, 0px, 0px) !important;
    left: auto !important;
    right: 2rem;
    box-shadow: rgba(0, 0, 0, 0.4) -6px 6px 12px;
    width: 280px;
    overflow: clip;
    height: 0;
    opacity: 0;
    transition: all 0.25s;
}

.actions .dropdown-menu.show {
    height: auto;
    opacity: 1
}

.actions .action {
    display: flex;
    align-items: center;
    column-gap: 0.5rem;
    width: 100%;
    padding: 1rem .33rem;
    margin-bottom: 0.25rem;
    border: none;
    text-decoration: none;
    white-space: pre-line
}

.actions .action:active {
    filter: brightness(1) contrast(20) grayscale(1)
}

.actions .action:first-child {
    border-top-left-radius: var(--radiusValue);
    border-top-right-radius: var(--radiusValue);
}

.actions .action:last-child {
    border-bottom-left-radius: var(--radiusValue);
    border-bottom-right-radius: var(--radiusValue);
}

.actions .action:not(:last-child) {
    border-bottom: 2px ridge #FFF3;
}

.actions .action i.faicon {
    display: inline-block;
    width: 1.75rem;
    vertical-align: text-bottom;
    text-align: center;
}

/* Grids */
.grids .grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--grid-space);
    padding-inline: 0
}

.grids .grid .item {
    padding: 0 !important;
    position: relative !important; /*overflow:hidden*/
}

.grids .grid .item picture img {
    border-radius: var(--radiusValue);
    width: 100%
}

.grids .grid .item .name {
    margin-block: 0.5rem;
    text-align: center;
    font-size: 1.25rem;
}

.grids .grid.col3 .item {
    flex: 0 0 calc(33.3333333% - var(--grid-space) * 0.666666);
}

.grids .grid.col2 .item {
    flex: 0 0 calc(50% - var(--grid-space) * 0.5);
}

.grids .grid.col1 .item {
    flex: 0 0 calc(100% - var(--grid-space));
}

.grids {
    container-type: inline-size
}

@container (max-width:800px) {
    .grids .grid.col3 .item {
        flex: 0 0 calc(50% - var(--grid-space) * 0.5);
    }
}
@container (max-width:400px) {
    .grids .grid.col3 .item {
        flex: 0 0 calc(100% - var(--grid-space));
    }

    .grids .grid.col2 .item {
        flex: 0 0 calc(100% - var(--grid-space));
    }
}


/* FILTER FIELDS ------------------------ */

/* Areas and distances */
.fieldbox {
    container-type: inline-size
}

.fieldbox .panel {
    margin-block: var(--grid-space);
    padding: var(--grid-space);
    background-color: var(--lightgrey);
    border-radius: var(--radiusValue);
}

.fieldbox .panel label input:is([type="checkbox"]) {
    accent-color: white;
    mix-blend-mode: multiply;
    color: white
}

.fieldbox .panel label input[type="radio"]:not(:checked) {
    mix-blend-mode: multiply;
}

.fieldbox .panel label input[type="radio"]:checked {
    accent-color: var(--primary);
}

.fieldbox .panel label:has(input:is([type="checkbox"],[type="radio"]):checked) {
    font-weight: 600;
    color: var(--primary);
}

.fieldbox .panel :is(h2,h3,h4,h5,h6) {
    margin: 0;
}

.fieldbox .field {
    display: block;
}

.fieldbox .field .box {
    display: block;
    width: 100%;
    padding: calc(var(--grid-space) / 2);
    border: 1px solid #DDD;
    outline: none;
    border-radius: var(--radiusValue)
}

.fieldbox .field.columns {
    display: flex;
    gap: var(--grid-space)
}

.fieldbox .field :is(h2,h3,h4,h5,h6) {
    margin: 0;
    padding: 0
}

.fieldbox label {
    all: unset;
}

.fieldbox label:has(input:is([type="checkbox"],[type="radio"])) {
    cursor: pointer
}

.fieldbox label.option-line {
    margin-bottom: var(--grid-space);
    display: flex;
    align-items: flex-start;
    column-gap: calc(var(--grid-space) / 2);
}

.fieldbox label.option-line:last-of-type {
    margin-bottom: 0;
}

.fieldbox label.option-block {
    margin-bottom: var(--grid-space);
}

.fieldbox label.option-block:last-of-type {
    margin-bottom: 0;
}

.fieldbox label.option-block :is(h4,h5,h6,p):has(+:is(select,input,button)) {
    padding: 0;
    margin: 0;
    margin-bottom: calc(var(--grid-space) / 4)
}

.fieldbox label.option-block :last-child {
    margin-bottom: 0;
}

/* Listbox multiselect */
.fieldbox select[multiple] {
    position: relative;
    background-color: var(--lightgrey);
    border: 1px solid #CCC !important;
    -webkit-appearance: none;
    appearance: none;
    scrollbar-width: thin
}

.fieldbox select[multiple]:focus > option:checked {
    background: var(--primary) linear-gradient(0deg, var(--primary) 0%, var(--primary) 100%);
}

.fieldbox select[multiple] > option {
    padding-block: 0.5rem;
    font-size: 0.85rem;
    overflow-x: clip;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.fieldbox select[multiple] > option:not(:last-of-type) {
    border-bottom: 1px solid #CCC;
}

.fieldbox select[multiple] > option.function {
    display: inline-block;
    margin-block: var(--grid-space);
    padding-inline: 0.5rem;
    background-color: #FFF6;
    border-radius: var(--radiusValue);
    border: outset 1px;
    text-align: center;
    font-style: italic;
    font-size: 0.75rem;
}

.fieldbox select[multiple] > option.function:not(:last-of-type) {
    margin-right: var(--grid-space);
}

.fieldbox select[multiple] > option:checked {
    align-items: top;
    background-color: var(--primary);
    color: white;
    border-radius: var(--radiusValue);
    white-space: break-spaces;
}

.fieldbox select[multiple] > option:checked:not(.function) {
    display: flex;
    gap: 0.5rem;
    padding-left: 0.5rem;
}

.fieldbox select[multiple] > option:checked:not(.function)::before {
    content: '✓';
}

.fieldbox select[multiple] > option:has(+option:checked) {
    border-bottom: 1px solid var(--lightgrey) !important
}

.fieldbox select[multiple] > option:nth-of-type(3) {
    margin-top: 0.5rem;
    border-top: 1px solid #CCC;
}

@container (max-width:400px) {
    .fieldbox select[multiple] > option {
        white-space: break-spaces
    }
}

/* Accordion */
.fieldbox .button-accordion {
    padding: 0;
    border-radius: var(--radiusValue);
    overflow: hidden;
}

.fieldbox .button-accordion:has( > button.collapsed) {
    border: none
}

.fieldbox .button-accordion:has( > button:not(.collapsed)) {
    border: 1px solid var(--primary)
}

.fieldbox .button-accordion > button {
    width: 100%;
    padding: 1rem;
    background-color: var(--lightergrey);
    border: none;
    text-align: left;
    transition: 0.75s all
}

.fieldbox .button-accordion > button .blocktitle {
    margin: 0;
    display: flex;
    align-items: center;
    text-align: left;
    color: var(--plain-tx)
}

.fieldbox .button-accordion > button .faicon {
    padding-right: 1.5em;
    width: 1.75rem;
    display: inline-block;
    text-align: center;
}

.fieldbox .button-accordion > button:not(.collapsed) {
    background-color: var(--primary);
}

.fieldbox .button-accordion > button i.toggle {
    margin-left: auto;
    font-size: 0.75rem;
    transition: 0.5s rotate, 0.5s color
}

.fieldbox .button-accordion > button:not(.collapsed) i.toggle {
    rotate: 180deg;
}

.fieldbox .button-accordion > button:not(.collapsed) .blocktitle {
    color: #FFF
}

.fieldbox .button-accordion > .details {
    margin: 0 !important
}

#related-subjects header {
    padding: var(--grid-space);
    margin-bottom: var(--grid-space);
    background-color: var(--lightergrey);
    border-radius: var(--radiusValue)
}

#related-subjects header #search-results {
    display: none
}

#search-tabs {

#related-subjects header {
    margin-top: var(--grid-space);
    background-color: var(--primary) !important;
    color: white !important
}

#related-subjects header h4 {
    display: none !important
}

#related-subjects header #search-results {
    display: block !important;
    margin: 0 !important
}

#related-subjects header .btn.primary.outline {
    background-color: white !important;
    color: var(--primary) !important
}

}
#related-subjects .subject {
    margin: 0rem;
    padding: var(--grid-space);
    margin-bottom: var(--grid-space);
    gap: var(--grid-space);
}

#related-subjects .subject > picture {
    width: 100%;
    padding: 0;
    border-radius: var(--radiusValue);
    overflow: clip;
    max-height:260px;
    max-width:260px;
    cursor:pointer;
}

#related-subjects .subject > picture img {
    object-fit: cover
}

#related-subjects div.subjects .more-subjects {
    display: block;
    margin-inline: auto
}

#related-subjects .creator picture {
    width: 2.5rem !important;
    aspect-ratio: 1/1;
    margin-right: 0.5rem;
    border-radius: 50%;
    overflow: clip;
}

#related-subjects .creator picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

#related-subjects .creator .title {
    color: var(--primary)
}

#related-collections header {
    padding: var(--grid-space);
    margin-bottom: var(--grid-space);
    background-color: var(--lightergrey);
    border-radius: var(--radiusValue)
}

#related-collections header #search-results {
    display: none
}

#search-tabs {

#related-collections header {
    margin-top: var(--grid-space);
    background-color: var(--primary) !important;
    color: white !important
}

#related-collections header h4 {
    display: none !important
}

#related-collections header #search-results {
    display: block !important;
    margin: 0 !important
}

#related-collections header .btn.primary.outline {
    background-color: white !important;
    color: var(--primary) !important
}
 .btn.primary:not(.feedmore) {
      background-color: var(--primary) !important;
      color: var(--primaryText);
  }
}
#related-collections #collections.row {
    margin-inline: calc(var(--grid-space) / -2);
}

#related-collections #collections.row .collection-info {
    padding: 0
}

#related-collections #collections.row .collection-info .area {
    margin: calc(var(--grid-space) / 2);
}

#related-collections #collections.row .collection-info .area picture {
    display: block;
    width: 100%;
    padding: 0;
    border-radius: var(--radiusValue);
    overflow: clip
}

#related-collections #collections.row .collection-info .area picture img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

#related-collections #collections.row .collection-info .area h6.collection-title {
    margin-block: 0.5rem;
    text-align: center;
    font-size: 1.5rem;
}

#related-collections #collections.row .collection-info .iconbutton {
    flex: 1 1 0;
}

#related-collections div.collections .more-subjects {
    display: block;
    margin-inline: auto
}

#related-creator .title {
    color: var(--primary);
    font-weight: 400;
    font-size: 1rem
}

#related-creator .creator {
    font-size: 1.15rem;
    font-weight: 600;
    line-height: 1
}

#related-creator .published {
    margin-top: var(--grid-space);
    padding: 0.25rem 0.5rem;
    background-color: var(--lightgrey);
    border-radius: var(--radiusValue)
}

#related-creator .published > * {
    display: inline
}

#related-creator .lastupdated {
    margin-top: var(--grid-space);
    padding: 0.25rem 0.5rem;
    background-color: var(--lightgrey);
    border-radius: var(--radiusValue)
}

#related-creator .lastupdated > * {
    display: inline
}

#related-creator :is(.published,.lastupdated) > * {
    font-size: 0.875rem
}

#related-creator picture {
    margin: 0;
    padding: 0;
    border-radius: 50%;
    overflow: clip
}

#related-creator picture img {
    width: 100%;
    aspect-ratio: 1/1;
    object-fit: cover;
    object-position: center;
}

#creator-description {
    padding: 1rem;
    margin-bottom: 2rem;
    background-color: var(--lightergrey);
    border-radius: var(--radiusValue);
}

#creator-description > div.header .left.side {
    flex-grow: 1
}

#creator-description > div.header .left.side picture {
    width: 4rem;
    aspect-ratio: 1/1;
    margin-right: 1rem;
    border-radius: 50%;
    overflow: clip
}

#creator-description > div.header .left.side picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center
}

#creator-description > div.header .left.side h6.title {
    margin: 0;
    color: var(--primary);
    font-weight: 400;
    font-size: 1rem
}

#creator-description > div.header .left.side p.creator {
    margin: 0;
    line-height: 1;
    font-size: 1.5rem;
    font-weight: 700
}

#creator-description > div.header .right.side .followers {
    color: var(--primary);
}

#creator-description > div.header .right.side .followers i {
    font-size: 1.25rem;
}

#collection-description {
    padding: 1rem;
    margin-bottom: 2rem;
    background-color: var(--lightergrey);
    border-radius: var(--radiusValue);
}

#collection-description picture {
    width: 100%;
    overflow: clip;
    border-radius: var(--radiusValue)
}

#collection-description picture img {
    width: 100%;
    height: 100%;
    padding: 0;
    object-fit: cover;
    object-position: center;
    border-radius: var(--radiusValue)
}


#asiderelated-collections #collections picture {
    display: block;
    width: 100%;
    border-radius: var(--radiusValue);
    overflow: clip
}

#asiderelated-collections #collections picture > img {
    width: 100%;
    height: 100%
}

#asiderelated-collections #collections .collection-info {
    margin-bottom: calc(var(--grid-space) * 2);
}

#asiderelated-collections #collections .collection-info h6.collection-title {
    margin-block: 0.5rem;
    text-align: center;
    font-size: 1.5rem;
}

#asiderelated-collections #collections .collection-info .iconbutton .faicon {
    font-size: 1.25rem !important;
}

#related-creators header {
    padding: var(--grid-space);
    margin-bottom: var(--grid-space);
    background-color: var(--lightergrey);
    border-radius: var(--radiusValue)
}

#related-creators header #search-results {
    display: none
}

#search-tabs {

#related-creators header {
    margin-top: var(--grid-space);
    background-color: var(--primary) !important;
    color: white !important
}

#related-creators header h4 {
    display: none !important
}

#related-creators header #search-results {
    display: block !important;
    margin: 0 !important
}

#related-creators header .btn.primary.outline {
    background-color: white !important;
    color: var(--primary) !important
}

}

#related-creators #creators.row {
    margin-inline: calc(var(--grid-space) / -2);
}

#related-creators #creators.row .creator-info {
    padding: 0 !important;
}

#related-creators #creators.row .creator-info .area {
    margin: calc(var(--grid-space) / 2);
}

button.feedmore {
    margin-top: calc(var(--grid-space) * 2);
    margin-inline: auto;
    display: block;
}

#subject-reference .attribs {
    margin-block: 0.5rem;
    line-height: 2;
}

#related-creators #creators.row .creator-info .area picture {
    display: block;
    width: 33%;
    aspect-ratio: 1/1;
    padding: 0;
    margin-inline: auto;
    border-radius: 50%;
    overflow: clip
}

#related-creators #creators.row .creator-info .area picture img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

#related-creators #creators.row .creator-info .area .title {
    margin: 0;
    margin-top: 1rem;
    line-height: 1;
    text-align: center;
    color: var(--primary)
}

#related-creators #creators.row .creator-info .area .creator-title {
    margin: 0;
    margin-top: 0.5rem;
    margin-bottom: 1rem;
    line-height: 1;
    text-align: center;
    font-size: 1.25rem
}

#related-creators div.creators .more-subjects {
    display: block;
    margin-inline: auto
}

#subjectfield-title {
    padding-block: 2rem;
    text-align: center;
    background-color: var(--lightergrey);
    border-radius: var(--radiusValue)
}

#subjectfield-title label {
    margin: 0;
    line-height: 1;
    font-size: 1.25rem;
    color: #849DD1;
}

#subjectfield-title h1 {
    margin: 0;
    line-height: 1;
    font-size: 2.5rem;
    color: #4164AF
}

#related-subjectfield header {
    padding: var(--grid-space);
    margin-bottom: var(--grid-space);
    background-color: var(--lightergrey);
    border-radius: var(--radiusValue)
}

#related-subjectfield header #search-results {
    display: none
}

#related-subjectfield header {
    margin-top: var(--grid-space);
    background-color: var(--primary) !important;
    color: white !important
}

#related-subjectfield header:not(:first-of-type) {
    margin-top: calc(var(--grid-space) * 2);
}

#related-subjectfield header h4 {
    margin: 0;
    margin-bottom: 0.33rem
}

#related-subjectfield header .btn.primary.outline {
    background-color: white !important;
    color: var(--primary) !important
}

#related-subjectfield .subjectfields-group {
    list-style-type: none;
    display: flex;
    flex-wrap: wrap;
    gap: var(--grid-space)
}

#related-subjectfield .subjectfields-group > .subjectfield {
    flex: 1 1 calc(33% - var(--grid-space));;
    width: calc(50% - var(--grid-space));
}

#related-subjectfield .subjectfields-group > .subjectfield:has(.overflowed) {
    flex: 1 1 calc(50% - var(--grid-space));
}

#related-subjectfield .subjectfields-group > .subjectfield .area {
    height: 100%;
    margin: 0;
    display: flex;
    flex-direction: column;
    border-radius: var(--radiusValue);
    background-color: var(--lightergrey);
}

#related-subjectfield .subjectfields-group > .subjectfield .area .title {
    margin-bottom: var(--grid-space);
    text-overflow: ellipsis;
    overflow: hidden;
    line-height: 1;
    white-space: nowrap;
    line-height: 1.15;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--plain-tx)
}

#related-subjectfield .subjectfields-group > .subjectfield .area .title.overflowed {
    white-space: normal !important;
}

#related-subjectfield .subjectfields-group > .subjectfield .area .impact {
    margin-top: auto;
    white-space: nowrap;
}

#related-subjectfield .subjectfields-group > .subjectfield .area .impact > * {
    white-space: nowrap;
}

#related-subjectfield .subjectfields-group > .subjectfield .area .impact span {
    margin: 0 !important;
    padding-inline: 0.5rem;
    color: var(--primary) !important
}

#related-subjectfield .subjectfields-group > .subjectfield .area .impact span:first-of-type {
    padding-left: 0;
}

#related-subjectfield .subjectfields-group > .subjectfield .area .impact span:not(:first-of-type) {
    border-left: 1px solid #0004
}

#related-subjectfield .subjectfields-group > .subjectfield .area .impact.overflowed span {
    display: block;
    border: none !important;
    padding-inline: 0 !important;
}
.group.grid.col3 > .details .item.area {
    padding: 0 !important;
    /* position: relative !important; */
}

.group.grid.col3 > .details .item {
    flex: 0 0 calc(33.3333333% - var(--grid-space)* 0.666666);
    /* overflow: clip; */
}
.group.grid > .details .item {
    flex: 0 0 calc(100%);
    /* overflow: clip; */
}
.group > header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--grid-space);
    background-color: var(--primary);
    border-radius: var(--radiusValue);
    color: white;
}
.group.grid.col3 > .details .item {
    flex: 0 0 calc(33.3333333% - var(--grid-space)* 0.666666);
    /* overflow: clip; */
}
.group.grid > .details {
    margin-top: var(--grid-space);
    display: flex;
    flex-wrap: wrap;
    gap: var(--grid-space);
}
.group.grid > .details .item > .name {
    margin-block: 0.5rem;
    text-align: center;
    font-size: 1.25rem;
}
.iconbutton:not(:last-child) {
    border-right: 1px solid #DBDBDB;
}
@media (max-width: 767px) {
    #related-subjectfield .subjectfields-group > .subjectfield {
        flex: 1 0 100% !important;
    }
}


/* SEARCH FIELDS ********************************************************* */
.field {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    margin-block: calc(var(--grid-space) * 2);
    line-height: 1;
    font-weight: 600;
}

.field > .filter-option {
    display: block;
    width: 100%;
    padding: calc(var(--grid-space) / 2);
    margin-top: calc(var(--grid-space) / 2);
    border: none;
    outline: none;
    border-radius: var(--radiusValue)
}

#filter-bar.container {
    margin-inline: calc(-1 * var(--grid-space));
    width: calc(100% + var(--grid-space) * 2.5);
}

#filter-bar form {
    width: 100%;
    margin-inline: auto;
    display: flex;
    align-items: center;
    column-gap: var(--grid-space)
}

#filter-bar #filter-text {
    padding: calc(var(--grid-space) / 2);
    border-radius: var(--radiusValue);
    border: 1px solid #8a8a8a;
    outline: none;
    flex-grow: 1;
}

#filter-bar button[type="submit"] {
    white-space: nowrap;
}

#filter-bar button[type="submit"] i.faicon {
    font-size: inherit !important
}

.iconbutton {
    padding: 0.30em 0.75em;
    background: none;
    border: none;
    color: var(--primary);
}

#subject-reference > h2 {
    font-size: 1.25rem;
    line-height: 1;
}

#subject-reference .attribs .properties .pill {
    font-size: 0.875rem;
}

#subject-reference .attribs .classification .title {
    display: inline;
    font-weight: 600;
    font-size: 0.875rem;
}

.pill {
    padding: 0.2rem 0.4rem;
    border-radius: var(--radiusValue);
    width: fit-content;
    white-space: nowrap;
}

main#subject-details i.faicon {
    font-size: 1.5rem !important;
    margin-inline: 0.25em !important;
}

header [id*="search-stats"] {
    display: block !important;
    margin: 0 !important;
}

/* Tabs */
ul[role="tablist"] {
    list-style-type: none;
    margin: 0;
    padding: 0;
    display: flex;
    column-gap: 1rem;
    justify-content: center;
    border-bottom: 1px solid #0003;
}

ul[role="tablist"] > li.nav-item:hover,
ul[role="tablist"] > li.nav-item > .nav-link {
    height: unset;
    box-shadow: none;
    border: none;
    color: var(--secondary);
}

ul[role="tablist"] > li.nav-item > .nav-link:hover,
ul[role="tablist"] > li.nav-item > .nav-link.active {
    background-color: unset;
    border-bottom: 2px solid var(--primary);
    color: var(--primary);
}

ul[role="tablist"] > li.nav-item > .nav-link.active {
    cursor: default;
    pointer-events: none
}

ul[role="tablist"] {
    container-type: inline-size
}

@container (max-width:400px) {
    ul[role="tablist"] {
        flex-direction: column;
        background-color: white;
        margin-top: calc(var(--grid-space) * 2)
    }

    ul[role="tablist"] > li.nav-item {
        background-color: none;
    }

    ul[role="tablist"] > li.nav-item > .nav-link {
        width: 100%;
        border-radius: none;
        border-top-left-radius: var(--radiusValue);
        border-top-right-radius: var(--radiusValue);
    }

    ul[role="tablist"] > li.nav-item > .nav-link {
        border: none !important;
        background-color: #FFF !important
    }

    ul[role="tablist"] > li.nav-item > .nav-link:not(.active) {
        padding-block: 1.5rem;
        margin-bottom: -8px;
        border: 1px solid var(--lightgrey) !important;
        box-shadow: inset 0 -4px 10px 0px #0001;
    }

    ul[role="tablist"] > li.nav-item > .nav-link.active {
        font-size: 125% !important;
        font-weight: 600 !important;
        background-color: var(--primary) !important
    }

    ul[role="tablist"] > li.nav-item:has(.nav-link.active) {
        order: 100;
    }
}

@media (min-width: 1440px) {
    .container {
        max-width: 1280px;
    }
}

/* -------------------------------------- */
