@use 'abstracts' as *;

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

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

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

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

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

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

    &:hover {
        background-color: var(--presszone-comments-bg-hover);
        color: var(--presszone-comments-primary);
    }

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

    &:focus {
        outline: none;
    }

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

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

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

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

    &__icon {
        font-size: var(--presszone-comments-font-size-lg);
    }

    &__title {
        margin: var(--presszone-comments-spacing-zero);
        font-size: var(--presszone-comments-font-size-md);
    }

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

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

    &--primary {
        background-color: var(--presszone-comments-primary);
        color: var(--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: var(--presszone-comments-spacing-md) var(--presszone-comments-spacing-zero);
    border-bottom: $presszone-comments-border-width solid var(--presszone-comments-border);

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

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

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

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

    &__input {
        opacity: 0;
        width: var(--presszone-comments-spacing-zero);
        height: var(--presszone-comments-spacing-zero);

        &:checked + .presszone-comments-admin-toggle__slider {
            background-color: var(--presszone-comments-primary);

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

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

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

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

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

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

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

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

    &:focus {
        outline: none;
    }

    &:focus-visible {
        border-color: var(--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: var(--presszone-comments-spacing-xl);
    inset-inline-end: var(--presszone-comments-spacing-xl);
    z-index: 9999;
}

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

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

    &--error {
        border-inline-start-color: var(--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: var(--presszone-comments-spacing-xl);

    h1 {
        margin: var(--presszone-comments-spacing-zero);
        font-size: var(--presszone-comments-font-size-xl);
    }
}

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

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

    &:hover {
        background: var(--presszone-comments-bg-hover);
    }

    &.active {
        background: var(--presszone-comments-accent-dim);
        color: var(--presszone-comments-primary);
    }
}

.presszone-comments-admin-tab-icon {
    font-size: var(--presszone-comments-font-size-md);
}

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

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

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

    input {
        max-width: var(--presszone-comments-input-max-width);
    }
}

.presszone-comments-text-warning {
    color: var(--presszone-comments-warning);
}

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

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

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

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

    &:focus-within {
        border-color: var(--presszone-comments-primary);
    }
}

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

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

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

        &:hover {
            color: var(--presszone-comments-error);
        }
    }
}

.presszone-comments-admin-tag-input {
    border: none !important;
    flex: 1;
    min-width: var(--presszone-comments-input-min-width);
    padding: var(--presszone-comments-spacing-xs) var(--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: var(--presszone-comments-spacing-md) var(--presszone-comments-spacing-zero);
    border-bottom: $presszone-comments-border-width solid var(--presszone-comments-border);

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

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

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

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

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