body:has(> [data-promo]) {
    grid-template-rows: auto auto 1fr auto;
}

[data-favicon] {
    display: inline-block;
    width: 1.0rem;
    height: 1.0rem;
    transform: translate(-4px, 2px);
    margin-right: 4px;
}

[data-favicon] img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

content[data-promo="seen"] .hero-panel {
    padding: 0;
}
 
content + content {
    margin-top: 0;
}
.no-user {
    background-color: var(--bg-color-3);
    background-image: linear-gradient(130deg, var(--bg-color-3) 25%, var(--bg-color-4) 100%);
    padding: 4rem;
    display: flex;
    flex-direction: column;
    width: 300px;
    box-shadow: 0 0 10px 3px var(--bg-color-1), inset 0 0 10px 0 var(--bg-color-3);
    margin: 4rem auto;
    border-radius: 6px;
}
.no-user h3 {
    line-height: 1.6;
}
.no-user span {
    color: var(--hover-color);
    border-bottom: 1px dotted transparent;
    cursor: pointer;
    padding-bottom: 3px;
}
.no-user span:hover {
    border-bottom: 1px dotted var(--hover-color);
}

#shortcuts-menu { display: none; }
body[data-user] #shortcuts-menu { display: block; }



#shortcuts-menu > .nav-block {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    flex-wrap: wrap;
    margin: 0;
    padding: 6px 16px;
    background-color: var(--bg-color-0);
}
.nav-block h3 {
    margin: 0;
    padding: 0;
    color: var(--header-color);
    font-size: 1.2em;
}
.nav-block-buttons button {
    background-color: transparent;
    /* border: 1px solid var(--bg-color-1); */
    border: 0;
    border-radius: 4px;
    padding: 1px 4px;

    display: flex;
    align-items: center;
}
.nav-block button:hover p {
    color: var(--hover-color)
}

.nav-block-buttons button p {
    margin: 0;
    padding: 0;
    color: var(--header-color);
    font-size: 1.1em;
}

.nav-block .button-toggle-outer {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    width: 36px;
    height: 18px;
    margin-right: 8px;
    border-radius: 9px;
    background-color: hsla(0, 0%, 0%, 0.5);
    padding: 1px 2px;
    transition: all 300ms ease-in-out;
    cursor: pointer;
}
.nav-block button.active .button-toggle-outer {
    justify-content: flex-end;
    background: hsla(35,90%,50%,0.6);
    background: color-mix(in srgb, var(--hover-color) 90%, hsl(0,0%,0%) 10%);
    box-shadow: inset 1px 3px 5px 0 color-mix(in srgb, var(--hover-color) 40%, hsl(0,0%,0%) 60%);
}
.nav-block button.active .button-toggle-inner {
    background: hsla(35,10%,90%,1);

}

.nav-block .button-toggle-inner {
    width: 16px;
    height: 16px;
    /* background: var(--header-color); */
    border-radius: 50%;
    background: hsla(0,0%,100%,0.4);
}

.nav-menu h3 {
    display: block;
    margin: 0;
}

.nav-block-buttons {
    display: flex;
    gap: 2rem;
    align-items: center;
}
.nav-block-buttons button {
    color: var(--header-color);
    border-color: var(--hover-color);
}
.nav-block-buttons button:hover {
    color: var(--hover-color);
    border-color: var(--header-color);
}
.nav-menu button {
    display: block;
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    color: #555759;
    font-size: 1.1em;
    cursor: pointer;
}

content > .panel.full-width:has(> .grid-left-sidebar) > * {
    grid-column: 1 / -1;
    background: var(--bg-color);
    margin: 0;
}

.grid-left-sidebar {
    display: grid;
    margin: 0;
    grid-template-columns: auto 1fr;
}

.grid-left-sidebar > * {
    padding: 2rem 1rem;
}
.sidebar-left {
    grid-column: 1 / 2;
    background: var(--bg-color-3);
}
.sidebar-content {
    grid-column: 2 / 3;
    background: var(--bg-color-4);
}

.sidebar-left input,
.sidebar-left select {
    padding: 0.5rem;
    border: 1px solid var(--header-color);
}

/* SHORTCUTS */

#shortcuts {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0rem;
    padding: 0rem;
    background: var(--bg-color-5);
}

#shortcuts .category-cuts {
    /* display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10ch, 1fr)); */
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.5rem 0.5rem 0.5rem 1.5rem;
    background: var(--bg-color-0);
}

#shortcuts [data-icon] {
    display: inline-block;
    height: 1rem;   
}
#shortcuts [data-icon] svg {
    height: 100%;
    object-fit: contain;
}
#shortcuts [data-icon] svg path {
    fill: var(--text);
}

#shortcuts .cat-edit {
    display: none;
}

#shortcuts[data-editing="true"] .cat-edit {
    display: block;
}
#shortcuts .cut-edit-toggle {
    display: none;
}
#shortcuts[data-editing="true"] .cut-edit-toggle {
    display: flex;
}

#shortcuts .cut-delete {
    display: none;
}
#shortcuts[data-deleting="true"] .cut-delete {
    display: flex;
}

#shortcuts .cut-edit {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;

}

#shortcuts p[contenteditable] {
    outline: 1px solid var(--text);
    outline-offset: 3px 6px;
    padding: 0 3px;
    margin: 0;
}

#shortcuts [data-editing="false"] .category-display {
    display: flex;
}
#shortcuts [data-editing="false"] .category-edit {
    display: none;
}
#shortcuts [data-editing="true"] .category-display {
    display: none;
}
#shortcuts [data-editing="true"] .category-edit {
    display: flex;
    flex-direction: row;
    gap: 0.5rem;
}

#shortcuts .category p {
    margin: 0;
    color: color-mix(in srgb, var(--header-color) 60%, transparent 40%);
    font-size: 1.1em;
}
#shortcuts .category:hover p {
    color: color-mix(in srgb, var(--header-color) 90%, transparent 10%);
}

#shortcuts .category p span {
    font-weight: 600;
}

#shortcuts .category-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    background: linear-gradient(to bottom, var(--bg-color-2) 0%, var(--bg-color-0) 100%);
    padding: 3px 16px 3px 26px;
}
#shortcuts .category.dragging {
    /* outline: 1px solid red; */
    /* outline-offset: 2px; */
    z-index: 3;

    position: relative;

    ::after {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: var(--bg-color-0);
        opacity: 0.5;
        z-index: 4;
    }
}
#shortcuts .category-header.dragover {
    outline: 1px solid cornflowerblue;
}
#shortcuts .category-header.dragging .category-name {

    outline: 1px solid red;
    outline-offset: -2px;
}
#shortcuts .category-header.dragging .category-name p {
    color: red;
}


#shortcuts .cut {
    position: relative;
    display: flex;
    z-index: 1;
    transition: 50ms linear;
} 

#shortcuts .cut[data-span="2"] { grid-column: span 2; }
#shortcuts .cut[data-span="3"] { grid-column: span 3; }
#shortcuts .cut[data-span="4"] { grid-column: span 4; }
#shortcuts .cut[data-span="5"] { grid-column: span 5; }
#shortcuts .cut[data-span="6"] { grid-column: span 6; }
#shortcuts .cut[data-span="7"] { grid-column: span 7; }

#shortcuts .cut.dragging {
    outline: 1px solid var(--hover-color);
    outline-offset: 3px 6px;

}

#shortcuts .cut-header {
    display: flex;
    flex-direction: row;
    padding: 8px;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    background-color: var(--bg-color-1);
    background: linear-gradient(to bottom, var(--bg-color-1) 0%, var(--bg-color-0) 100%);
    box-shadow: 0 3px 5px hsl(0, 0%, 0%, 0.5);
    border-radius: 7px;
    z-index: 2;
    transition: 450ms ease-in;
} 
#shortcuts .cut-header:has(> a:hover) {
    background-color: var(--bg-color-3);
    background: linear-gradient(to bottom, var(--bg-color-1) 0%, color-mix(in srgb, var(--bg-color-1) 60%, var(--hover-color) 40%) 80%, var(--hover-color) 100%);
}
#shortcuts .cut-header a {
    font-weight: 500;
    color: color-mix(in srgb, var(--hover-color) 80%, var(--header-color) 20%);
    padding: 0 0.5rem;
    transition: 250ms linear;
}
#shortcuts .cut-header a:hover {
    color: var(--header-color);
}

#shortcuts .cut-edit {
    display: flex;
    position: absolute;

    top: -6px;
    left: -6px;
    width: 300px;
    z-index: 1;
    background: var(--bg-color-3);
    opacity: 0;
    pointer-events: none;
    padding: 3.5rem 0.5rem 0.5rem 0.5rem;
}
#shortcuts .cut[data-editing="true"] {
    z-index: 5;
}
#shortcuts .cut[data-editing="true"] .cut-edit {
    opacity: 1;
    pointer-events: all;
}

/* SIDEBAR MENU */


.sidebar-left.hidden {
    display: none;
}

.sidebar-left p {
    margin: 0;
}
.sidebar-left h3 {
    margin: 0 0 1rem 0;
    padding: 0;
    color: var(--header-color);
    font-size: 1.2em;
    font-weight: 600;
}

.sidebar-left h3:hover,
.sidebar-left h3:has(+ .menu:not(.hidden)) {
    color: var(--hover-color);
}
.sidebar-left h3 + button {
    display: block;
    margin: 0;
    padding: 0.4rem 0.8rem;
    background: none;
    border: 1px solid var(--header-color);
    color: #555759;
    font-size: 1.1em;
    cursor: pointer;
}

.sidebar-left .menu {
    display: flex;
    flex-direction: column;
    border-left: 2px solid var(--bg-color-2);
    padding-left: 0.5rem;
    margin-bottom: 1rem;
    margin-left: -0.5rem;
    gap: 0.5rem;
}
.sidebar-left .menu button {
    display: block;
    margin: 0;
    padding: 0.4rem 0.8rem;
    background: none;
    border: 1px solid var(--header-color);
    color: var(--hover-color);
    font-size: 1.1em;
    cursor: pointer;

}

.sidebar-left .menu button:focus-visible,
.sidebar-left .menu input:focus-visible,
.sidebar-left .menu select:focus-visible {
    box-shadow: inset 0 0 5px -2px var(--hover-color);
    outline: none;
    border: 1px solid var(--hover-color);
}
.sidebar-left .menu button:hover {
    border-color: var(--hover-color);
    box-shadow: inset 0 0 5px -2px var(--hover-color);
}

.sidebar-left .menu.hidden {
    display: none;
}

.icon-panel .icons {
    display: flex;
    flex-direction: row;
    gap: 0.5rem;
    flex-wrap: wrap;
    width: 100vw;
}

.icons div {
    width: 2rem;
    height: 2rem;
}

.icons div svg {
    object-fit: contain;
    width: 100%;
    aspect-ratio: 1;
}

/* TUTORIAL */
.tutorial .instructions {
    display: flex;
    flex-direction: column;
    border-top: 1px solid var(--bg-color-1);
    padding-top : 1rem;
}
.tutorial[data-hidden=true] .instructions {
    display: none;
}
.tutorial .tutorial-header {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 0.5rem;
    padding: 8px 0px;

}

.tutorial .tutorial-header button {
    background-color: transparent;
    border: 1px solid var(--bg-color-1);
    color: var(--bg-color-5);
    border-radius: 4px;
    padding: 4px 12px;
}
.tutorial .tutorial-header button:hover {
    color: var(--text);
}
.tutorial .tutorial-header h3 {margin: 0;}

.tutorial .tutorial-header button span:nth-child(1),
.tutorial[data-hidden=true] .tutorial-header button span:nth-child(2) {
    display: none;
}
.tutorial .tutorial-header button span:nth-child(2),
.tutorial[data-hidden=true] .tutorial-header button span:nth-child(1) {
    display: flex;
}


.search-block {
    position: relative;
    & :focus-visible {
        outline: none;
    }
}

#search-cuts {
    width: 100%;
    padding: 0.5rem;
    /* border: 1px solid var(--header-color); */
    border: 0;
    border-radius: 4px;
    width: 350px;
    background-color: #00000033;
    color: #aaac97;

}
.search-cuts-results {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background: var(--bg-color-0);
    /* border: 1px solid var(--header-color); */
    border-top: none;
    border-radius: 0 0 4px 4px;
    max-height: 200px;
    overflow-y: auto;
    /* display: none; */
    z-index: 88;
}

.search-cuts-results:focus-visible {
    outline: 1px solid var(--hover-color);
    outline-offset: -1px;
}

.search-cuts-results .result {
    padding: 0.5rem;
    cursor: pointer;
    height: fit-content;
    max-height: 500px;
}
.search-cuts-results .result:hover {
    background: var(--bg-color-4);
}

a.search-result .cut-name {
    padding: 1px 4px;
    color: var(--text);

    &:hover {
        color: var(--hover-color);
    }
}
a.search-result:hover {
    background-color: red;
}

button.clear-search-button {
    background-color: transparent;
    border: 1px solid var(--bg-color-2);
    color: var(--header-color);
    border-radius: 4px;
    padding: 0.4rem 0.8rem;
    margin: 0;
    cursor: pointer;
    &:hover {
        border-color: var(--hover-color);
        color: var(--hover-color);
        box-shadow: none !important;
    }
}
