.emailTemplate{
    --colour: var(--blue-900);
    --elementGap: 2rem;
    border: 1px solid var(--colour);
    position: relative;
    background-color: #070207;
    &[data-mode=preview]{
        .absContent, .controls{
            display: none;
            &[data-layout=full]{
                display: none;
            }
        }
        &.tagged, .tagged{
            padding: 1rem;
            margin: 0;
            border: none;
            &::before, &::after{
                display: none;
            }
            &.canAdd{
                padding: 0rem;
            }
        }
        .templateColumn, .templateRow{
            min-height: unset;
            @container (max-width: 550px){
                .absContent{
                    display: none;
                }
            }
        }
    }
    img{
        max-width: 100%;
    }
    .absContent{
        position: absolute;
        bottom: 10px;
        left: 50%;
        transform: translateX(-50%);
        width: 100%;
        display: flex;
        justify-content: center;
        select{
            padding: 0.15rem 0.5rem;
        }
        &[data-state=hidden]{
            display: none
        };
    }
    &.tagged, .tagged{
        position: relative;
        margin: var(--elementGap) 0.25rem;
        isolation: isolate;
        &[data-state=hidden]{
            display: none
        };
        &.canAdd{
            padding-bottom: 5rem;
        }
        &::before{
            content: attr(data-type);
            position: absolute;
            top: 0;
            left: 0;
            background: var(--colour);
            padding: 0.25rem 0.5rem;
            transform: translateY(-100%);
            font-size: 0.6rem;
        }
        &::after{
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            border: 1px dashed var(--colour);
            z-index: -1;
        }
    }
    .templateRow{
        --colour: var(--blue-500);
        display: flex;
        justify-content: center;
        container-type: inline-size;
        @container (max-width: 550px){
            .absContent{
                display: block;
                *{
                    width: 100%;
                }
                button{
                    padding: 0.25rem;
                }
            }
        }
    }
    .templateColumn{
        --colour: var(--green-500);
        min-height: 300px;
        width: 100%;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        container-type: inline-size;
        @container (max-width: 550px){
            .absContent{
                display: block;
                *{
                    width: 100%;
                }
                button{
                    padding: 0.25rem;
                }
            }
        }
        .resizeEle, .alignEle{
            display: flex;
            flex-direction: column;
            align-items: center;
            margin: auto;
        }
    }
    .element{
        --colour: var(--orange-400);
        display: flex;
        flex-direction: column;
        min-height: 40px;
        padding: 0.25rem;
        &[data-type=Element-Selected]{
            --colour: var(--pink-300);
        }
        user-select: none;
    }
    .controls{
        --size: 20px;
        position: absolute;
        display: flex;
        top: 0;
        right: 0;
        transform: translateY(-100%);
        div{
            width: calc(var(--size) * 2.2);
            height: var(--size);
            border: 1px solid var(--grey-500);
            border-radius: 8px 8px 0 0;
            margin-left: 1rem;
        }
        .handle{
            cursor: grab;
            background:
                radial-gradient(circle at 25% 30%, var(--colour) 2px, transparent 2.5px),
                radial-gradient(circle at 50% 30%, var(--colour) 2px, transparent 2.5px),
                radial-gradient(circle at 75% 30%, var(--colour) 2px, transparent 2.5px),
                radial-gradient(circle at 25% 70%, var(--colour) 2px, transparent 2.5px),
                radial-gradient(circle at 50% 70%, var(--colour) 2px, transparent 2.5px),
                radial-gradient(circle at 75% 70%, var(--colour) 2px, transparent 2.5px);
        }
        .remove{
            position: relative;
            cursor: pointer;
            &::before, &::after{
                content: '';
                --ourSize: calc(var(--size) * 0.8);
                position: absolute;
                top: 50%;
                left: calc(50% - calc(var(--ourSize) / 2));
                height: 2px;
                border-radius: 10px;
                background: var(--red-200);
                width: var(--ourSize);
                transform: rotate(45deg);
            }
            &::after{
                transform: rotate(-45deg);
            }
        }
        .duplicate, .addAbove, .addBelow{
            position: relative;
            cursor: pointer;
            &::before{
                content: '';
                width: 100%;
                height: 100%;
                top: 0;
                left: 0;
                position: absolute;
                background: url("../img/duplicate.png");
                background-position: center;
                background-size: contain;
                background-repeat: no-repeat;
                filter: brightness(0.7);
            }
        }
        .addBelow::before{
            background: url("../img/addbelow.png");
            background-position: center;
            background-size: contain;
            background-repeat: no-repeat;
        }
        .addAbove::before{
            background: url("../img/addabove.png");
            background-position: center;
            background-size: contain;
            background-repeat: no-repeat;
        }
    }
}
#elementPreview{
    padding-left: 0.5rem;
    border-left: 2px dashed var(--grey-600);
    position: sticky;
    top: 85px;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.previewType{
    position: relative;
    padding: 5px;
    display: grid;
    gap: 1rem;
    &[data-state=hidden]{
        display: none;
    }
    .deselectButton{
        display: block;
        width: 90%;
        margin-inline: auto;
        font-size: 0.8rem;
    }
    h3{
        color: var(--pink-200);
    }
    textarea{
        width: 100%;
        height: 200px;
    }
    img{
        max-width: 100%;
    }
    .styleButtons{
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.25rem;
        button{
            width: 100%;
            --colour: var(--blue-500);
            &:active{
                filter: hue-rotate(180deg);
                transition: 0.01s;
            }
        }
    }
}

.drag-ghost, .drag-placeholder {
    border: 5px solid var(--blue-400);
    position: relative;
    *{
        display: none;
    }
    &::after{
        content: 'Draggable - ' attr(data-type);
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--blue-400);
        height: 100%;
        font-weight: bold;
        color: var(--white);
        opacity: 0.5;
  }
}

.drag-placeholder {
    &::after{
        content: 'Drop Zone - ' attr(data-type);
    }
    border: 3px dashed var(--blue-200);
    border-radius: 6px;
    max-width: 200px;
}

.controls .handle { cursor: grab; }
.drag-ghost { cursor: grabbing; }

#saveTemplateButton, #generateCodeButton{
    width: 100%;
    padding-block: 0.5rem;
}

.mj-button{
    margin-inline: auto;
    background: #232323;
    color: white;
}

.templatePlaceholder{
    text-align: center;
    font-style: italic;
    color: var(--grey-200);
}

#toTopButton{
    position: fixed;
    bottom: 1rem;
    right: 1rem;
}