@use 'abstracts' as *;

#presszone-comments-admin-app {
    display: flex;
    min-height: 100vh;
    background-color: $presszone-comments-bg-primary;
    color: $presszone-comments-text-primary;
    margin-inline-start: calc($presszone-comments-spacing-xl * -1 + $presszone-comments-spacing-xs); /* Compensate for WP Admin padding */
    font-family: $presszone-comments-font-main;
}

.presszone-comments-sidebar {
    width: $presszone-comments-sidebar-width;
    background-color: $presszone-comments-bg-secondary;
    border-inline-end: $presszone-comments-border-width solid $presszone-comments-border;
    display: flex;
    flex-direction: column;
}

.presszone-comments-logo {
    padding: $presszone-comments-spacing-lg;
    border-bottom: $presszone-comments-border-width solid $presszone-comments-border;

    h2 {
        color: $presszone-comments-text-primary;
        margin: $presszone-comments-spacing-zero;
        font-size: $presszone-comments-font-size-lg;
        letter-spacing: $presszone-comments-spacing-xxs;
    }
}

.presszone-comments-nav {
    display: flex;
    flex-direction: column;
    padding: $presszone-comments-spacing-md $presszone-comments-spacing-zero;
}

.presszone-comments-nav-link {
    padding: $presszone-comments-spacing-md $presszone-comments-spacing-lg;
    color: $presszone-comments-text-secondary;
    text-decoration: none;
    transition: all $presszone-comments-duration-normal $presszone-comments-ease-smooth;
    border-inline-start: $presszone-comments-border-width-xl solid transparent;
    font-weight: 500;

    &:hover {
        background-color: $presszone-comments-bg-hover;
        color: $presszone-comments-primary;
    }

    &.active {
        background-color: $presszone-comments-accent-dim;
        color: $presszone-comments-primary;
        border-inline-start-color: $presszone-comments-primary;
    }

    &:focus {
        outline: none;
    }

    &:focus-visible {
        box-shadow: 0 0 0 2px $presszone-comments-primary;
    }
}

.presszone-comments-content {
    flex: 1;
    padding: $presszone-comments-spacing-xl;
    overflow-y: auto;
}

/* Base Component Styles for Admin SPA */
.presszone-comments-admin-card {
    background: $presszone-comments-bg-secondary;
    border: $presszone-comments-border-width solid $presszone-comments-border;
    border-radius: $presszone-comments-radius-lg;
    padding: $presszone-comments-spacing-lg;
    margin-bottom: $presszone-comments-spacing-lg;

    &__header {
        display: flex;
        align-items: flex-start;
        gap: $presszone-comments-spacing-md;
        margin-bottom: $presszone-comments-spacing-lg;
    }

    &__icon {
        font-size: $presszone-comments-font-size-lg;
    }

    &__title {
        margin: $presszone-comments-spacing-zero;
        font-size: $presszone-comments-font-size-md;
    }

    &__description {
        margin: $presszone-comments-spacing-xs $presszone-comments-spacing-zero $presszone-comments-spacing-zero;
        color: $presszone-comments-text-secondary;
        font-size: $presszone-comments-font-size-sm;
    }
}

/* Button Components */
.presszone-comments-admin-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: $presszone-comments-spacing-sm $presszone-comments-spacing-xl;
    border-radius: $presszone-comments-radius-full;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: all $presszone-comments-duration-normal $presszone-comments-ease-smooth;

    &--primary {
        background-color: $presszone-comments-primary;
        color: $presszone-comments-bg-primary;

        &:hover {
            opacity: 0.9;
            transform: translateY(-1px);
        }
    }
}

/* Toggle Component */
.presszone-comments-admin-toggle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: $presszone-comments-spacing-md $presszone-comments-spacing-zero;
    border-bottom: $presszone-comments-border-width solid $presszone-comments-border;

    &:last-child {
        border-bottom: none;
    }

    &__label {
        font-weight: 600;
        display: block;
    }

    &__description {
        margin: $presszone-comments-spacing-xs $presszone-comments-spacing-zero $presszone-comments-spacing-zero;
        font-size: $presszone-comments-font-size-sm;
        color: $presszone-comments-text-muted;
    }

    &__switch {
        position: relative;
        display: inline-block;
        width: $presszone-comments-toggle-width;
        height: $presszone-comments-toggle-height;
    }

    &__input {
        opacity: 0;
        width: $presszone-comments-spacing-zero;
        height: $presszone-comments-spacing-zero;

        &:checked + .presszone-comments-admin-toggle__slider {
            background-color: $presszone-comments-primary;

            &:before {
                transform: translateX($presszone-comments-spacing-xl);
            }

            [dir="rtl"] &:before {
                transform: translateX(calc($presszone-comments-spacing-xl * -1));
            }
        }
    }

    &__slider {
        position: absolute;
        cursor: pointer;
        top: $presszone-comments-spacing-zero;
        inset-inline-start: $presszone-comments-spacing-zero;
        inset-inline-end: $presszone-comments-spacing-zero;
        bottom: $presszone-comments-spacing-zero;
        background-color: $presszone-comments-border;
        transition: .4s;
        border-radius: $presszone-comments-radius-xl;

        &:before {
            position: absolute;
            content: "";
            height: $presszone-comments-icon-size-md;
            width: $presszone-comments-icon-size-md;
            inset-inline-start: calc(($presszone-comments-toggle-height - $presszone-comments-icon-size-md) / 2);
            bottom: calc(($presszone-comments-toggle-height - $presszone-comments-icon-size-md) / 2);
            background-color: $presszone-comments-text-primary;
            transition: .4s;
            border-radius: $presszone-comments-radius-full;
        }
    }
}

/* Form Fields */
.presszone-comments-admin-field {
    margin-bottom: $presszone-comments-spacing-lg;

    &__label {
        display: block;
        font-weight: 600;
        margin-bottom: $presszone-comments-spacing-xs;
    }

    &__help {
        font-size: $presszone-comments-font-size-sm;
        color: $presszone-comments-text-muted;
        margin: $presszone-comments-spacing-zero $presszone-comments-spacing-zero $presszone-comments-spacing-sm;
    }
}

.presszone-comments-admin-input, 
.presszone-comments-admin-select {
    width: 100%;
    background: $presszone-comments-bg-primary;
    border: $presszone-comments-border-width solid $presszone-comments-border;
    color: $presszone-comments-text-primary;
    padding: $presszone-comments-spacing-sm $presszone-comments-spacing-md;
    border-radius: $presszone-comments-radius-md;

    &:focus {
        outline: none;
    }

    &:focus-visible {
        border-color: $presszone-comments-primary;
        box-shadow: 0 0 0 2px rgba(31, 113, 221, 0.2);
    }
}

/* Toast Component */
.presszone-comments-admin-toast-container {
    position: fixed;
    bottom: $presszone-comments-spacing-xl;
    inset-inline-end: $presszone-comments-spacing-xl;
    z-index: 9999;
}

.presszone-comments-admin-toast {
    background: $presszone-comments-bg-secondary;
    color: $presszone-comments-text-primary;
    padding: $presszone-comments-spacing-md $presszone-comments-spacing-xl;
    border-radius: $presszone-comments-radius-md;
    border-inline-start: $presszone-comments-border-width-xl solid $presszone-comments-primary;
    box-shadow: 0 $presszone-comments-shadow-offset-y $presszone-comments-shadow-spread $presszone-comments-shadow;
    margin-top: $presszone-comments-spacing-sm;
    animation: presszone-comments-toast-in $presszone-comments-duration-normal ease;

    [dir="rtl"] & {
        animation-name: presszone-comments-toast-in-rtl;
    }

    &--error {
        border-inline-start-color: $presszone-comments-error;
    }
}

@keyframes presszone-comments-toast-in {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

@keyframes presszone-comments-toast-in-rtl {
    from { transform: translateX(-100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

/* Page Header */
.presszone-comments-admin-page__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: $presszone-comments-spacing-xl;

    h1 {
        margin: $presszone-comments-spacing-zero;
        font-size: $presszone-comments-font-size-xl;
    }
}

/* Tabs Component */
.presszone-comments-admin-tabs {
    display: flex;
    gap: $presszone-comments-spacing-sm;
    margin-bottom: $presszone-comments-spacing-lg;
    border-bottom: $presszone-comments-border-width solid $presszone-comments-border;
    padding-bottom: $presszone-comments-spacing-sm;
}

.presszone-comments-admin-tab-btn {
    background: none;
    border: none;
    color: $presszone-comments-text-secondary;
    padding: $presszone-comments-spacing-sm $presszone-comments-spacing-lg;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: $presszone-comments-spacing-sm;
    border-radius: $presszone-comments-radius-md;
    transition: all $presszone-comments-duration-normal;

    &:hover {
        background: $presszone-comments-bg-hover;
    }

    &.active {
        background: $presszone-comments-accent-dim;
        color: $presszone-comments-primary;
    }
}

.presszone-comments-admin-tab-icon {
    font-size: $presszone-comments-font-size-md;
}

.presszone-comments-admin-tab-count {
    background-color: $presszone-comments-primary;
    color: $presszone-comments-bg-primary;
    font-size: $presszone-comments-font-size-xs;
    font-weight: bold;
    padding: $presszone-comments-spacing-xxs $presszone-comments-spacing-xs;
    border-radius: $presszone-comments-radius-sm;
    min-width: $presszone-comments-icon-size-md;
    text-align: center;
}

/* Moderation Table Helpers */
.presszone-comments-admin-table-actions {
    display: flex;
    gap: $presszone-comments-spacing-xs;
}

.presszone-comments-admin-search-box {
    display: flex;
    gap: $presszone-comments-spacing-sm;
    margin-bottom: $presszone-comments-spacing-lg;

    input {
        max-width: $presszone-comments-input-max-width;
    }
}

.presszone-comments-text-warning {
    color: $presszone-comments-warning;
}

/* Grid Layout */
.presszone-comments-admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax($presszone-comments-grid-min-col-width, 1fr));
    gap: $presszone-comments-spacing-lg;
}

.presszone-comments-admin-stat {
    font-size: $presszone-comments-font-size-xxl;
    font-weight: bold;
    margin: $presszone-comments-spacing-sm $presszone-comments-spacing-zero $presszone-comments-spacing-zero;
    color: $presszone-comments-primary;
}

/* Nested Fields */
.presszone-comments-admin-nested {
    margin-top: $presszone-comments-spacing-md;
    padding-inline-start: $presszone-comments-spacing-lg;
    border-inline-start: $presszone-comments-border-width-lg solid $presszone-comments-border;
}

/* Tag Input Component */
.presszone-comments-admin-tag-wrapper {
    background: $presszone-comments-bg-primary;
    border: $presszone-comments-border-width solid $presszone-comments-border;
    border-radius: $presszone-comments-radius-md;
    padding: $presszone-comments-spacing-xs;
    display: flex;
    flex-wrap: wrap;
    gap: $presszone-comments-spacing-xs;
    align-items: center;

    &:focus-within {
        border-color: $presszone-comments-primary;
    }
}

.presszone-comments-admin-tags {
    display: flex;
    flex-wrap: wrap;
    gap: $presszone-comments-spacing-xs;
}

.presszone-comments-admin-tag {
    background-color: $presszone-comments-accent-dim;
    color: $presszone-comments-primary;
    padding: $presszone-comments-spacing-xxs $presszone-comments-spacing-sm;
    border-radius: $presszone-comments-radius-sm;
    font-size: $presszone-comments-font-size-sm;
    display: flex;
    align-items: center;
    gap: $presszone-comments-spacing-xs;
    border: $presszone-comments-border-width solid $presszone-comments-primary;

    &__remove {
        background: none;
        border: none;
        color: $presszone-comments-primary;
        cursor: pointer;
        font-size: $presszone-comments-font-size-md;
        line-height: 1;
        padding: $presszone-comments-spacing-zero;
        display: flex;
        align-items: center;
        justify-content: center;

        &:hover {
            color: $presszone-comments-error;
        }
    }
}

.presszone-comments-admin-tag-input {
    border: none !important;
    flex: 1;
    min-width: $presszone-comments-input-min-width;
    padding: $presszone-comments-spacing-xs $presszone-comments-spacing-sm !important;
}

/* Border Width Variations for Admin UI elements */
.presszone-comments-btn--border-standard,
.presszone-comments-select--border-standard,
.presszone-comments-input--border-standard {
    border-width: $presszone-comments-border-width !important;
    border-style: solid !important;
}

.presszone-comments-btn--border-thick,
.presszone-comments-select--border-thick,
.presszone-comments-input--border-thick {
    border-width: $presszone-comments-border-width-lg !important;
    border-style: solid !important;
}

.presszone-comments-btn--border-extra-thick,
.presszone-comments-select--border-extra-thick,
.presszone-comments-input--border-extra-thick {
    border-width: $presszone-comments-border-width-xl !important;
    border-style: solid !important;
}

.presszone-comments-btn--borderless,
.presszone-comments-select--borderless,
.presszone-comments-input--borderless,
.presszone-comments-btn--no-borders,
.presszone-comments-select--no-borders,
.presszone-comments-input--no-borders {
    border-style: none !important;
    border-width: 0 !important;
}

/* Report List Styling */
.presszone-comments-admin-report-item {
    padding: $presszone-comments-spacing-md $presszone-comments-spacing-zero;
    border-bottom: $presszone-comments-border-width solid $presszone-comments-border;

    &:last-child {
        border-bottom: none;
    }
}

.presszone-comments-admin-report-meta {
    font-size: $presszone-comments-font-size-sm;
    color: $presszone-comments-text-secondary;
    margin-bottom: $presszone-comments-spacing-xs;
}

.presszone-comments-admin-report-reason {
    margin: $presszone-comments-spacing-xs $presszone-comments-spacing-zero;
    color: $presszone-comments-warning;
}

.presszone-comments-admin-report-snippet {
    background: $presszone-comments-bg-primary;
    padding: $presszone-comments-spacing-sm $presszone-comments-spacing-md;
    border-radius: $presszone-comments-radius-sm;
    margin: $presszone-comments-spacing-sm $presszone-comments-spacing-zero;
    border-inline-start: $presszone-comments-border-width-lg solid $presszone-comments-border;
    font-style: italic;
    color: $presszone-comments-text-muted;
}

.presszone-comments-admin-report-actions {
    display: flex;
    gap: $presszone-comments-spacing-sm;
    margin-top: $presszone-comments-spacing-sm;
}