.auth-body,
.admin-body {
    min-height: 100vh;
    background:
        radial-gradient(circle at top left, rgba(111, 154, 88, 0.18), transparent 26%),
        linear-gradient(180deg, #f8fbf6 0%, #edf4ea 100%);
}

.auth-shell {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 1.5rem;
}

.login-card {
    width: min(32rem, 100%);
    padding: 1.5rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1.4rem;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--ohs-shadow);
}

.auth-home-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
    font-weight: 700;
    text-decoration: none;
}

.login-brand {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1.5rem;
}

.login-brand img {
    width: 4.75rem;
}

.login-form {
    display: grid;
    gap: 1rem;
}

.admin-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 18rem minmax(0, 1fr);
}

.admin-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding: 1.25rem;
    border-right: 1px solid var(--ohs-border);
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(14px);
}

.admin-brand {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    align-items: center;
    color: var(--ohs-ink);
    text-decoration: none;
}

.admin-brand img {
    width: 3rem;
}

.admin-brand-title {
    display: block;
    font-family: "Fraunces", serif;
    font-size: 1.05rem;
    font-weight: 700;
}

.admin-brand-subtitle {
    display: block;
    color: var(--ohs-muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.admin-user-card,
.admin-card {
    padding: 1.2rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1.2rem;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--ohs-shadow-sm);
}

.admin-nav {
    display: grid;
    gap: 0.45rem;
}

.admin-nav-group {
    display: grid;
    gap: 0.45rem;
}

.admin-nav-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    padding: 0.8rem 0.9rem;
    border: 1px solid transparent;
    border-radius: 0.95rem;
    background: transparent;
    color: var(--ohs-ink-soft);
    font-weight: 700;
    text-align: left;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.admin-nav-toggle span {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

.admin-nav-toggle:hover,
.admin-nav-toggle:focus,
.admin-nav-toggle.active {
    background: rgba(111, 154, 88, 0.12);
    border-color: rgba(111, 154, 88, 0.15);
    color: var(--ohs-forest-ink);
}

.admin-nav-toggle-caret {
    transition: transform 0.2s ease;
}

.admin-nav-toggle[aria-expanded="true"] .admin-nav-toggle-caret {
    transform: rotate(180deg);
}

.admin-nav-submenu {
    display: grid;
    gap: 0.35rem;
    margin-top: 0.2rem;
    padding-left: 0.8rem;
    border-left: 1px solid rgba(111, 154, 88, 0.18);
}

.admin-nav-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.8rem 0.9rem;
    border-radius: 0.95rem;
    color: var(--ohs-ink-soft);
    font-weight: 700;
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.admin-nav-link:hover,
.admin-nav-link:focus,
.admin-nav-link.active {
    background: rgba(111, 154, 88, 0.16);
    color: var(--ohs-forest-ink);
}

.admin-nav-link.is-child {
    padding-block: 0.68rem;
    padding-inline: 0.8rem 0.9rem;
    font-size: 0.94rem;
}

.admin-nav-link.is-child i {
    font-size: 0.92rem;
}

.admin-main {
    padding: 1.5rem;
}

.admin-header {
    margin-bottom: 1.25rem;
}

.admin-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: end;
    gap: 1rem;
}

.admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin-stat-card h2 {
    margin-bottom: 0.35rem;
    font-size: 2rem;
}

.admin-content-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.admin-list {
    padding-left: 1rem;
    color: var(--ohs-ink-soft);
}

.admin-list li + li {
    margin-top: 0.55rem;
}

.role-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.32rem 0.65rem;
    border-radius: 999px;
    background: rgba(111, 154, 88, 0.16);
    color: var(--ohs-forest-ink);
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.role-callout {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.85rem 1rem;
    border-radius: 1rem;
    background: rgba(111, 154, 88, 0.12);
    color: var(--ohs-ink-soft);
    font-weight: 700;
}

.admin-toolbar-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.32rem 0.65rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.status-active {
    background: rgba(47, 107, 65, 0.14);
    color: var(--ohs-forest-ink);
}

.status-inactive {
    background: rgba(201, 81, 103, 0.12);
    color: #8f3043;
}

.status-published {
    background: rgba(47, 107, 65, 0.14);
    color: var(--ohs-forest-ink);
}

.status-draft {
    background: rgba(51, 103, 164, 0.14);
    color: #274f80;
}

.status-source-local {
    background: rgba(111, 154, 88, 0.14);
    color: var(--ohs-forest-ink);
}

.status-source-external {
    background: rgba(51, 103, 164, 0.14);
    color: #274f80;
}

.admin-form {
    display: grid;
    gap: 1.5rem;
}

.admin-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.admin-inline-fields {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(11rem, 0.7fr);
    gap: 0.85rem;
}

.admin-form-span {
    grid-column: 1 / -1;
}

.admin-fieldset {
    border: 0;
    padding: 0;
    margin: 0;
}

.role-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
    gap: 0.85rem;
}

.role-option {
    display: flex;
    gap: 0.8rem;
    align-items: start;
    padding: 0.95rem 1rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(111, 154, 88, 0.05);
    cursor: pointer;
}

.role-option input {
    margin-top: 0.2rem;
}

.role-option span {
    display: grid;
    gap: 0.15rem;
}

.role-option small {
    color: var(--ohs-muted);
    line-height: 1.45;
}

.admin-form-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem;
}

.admin-card-danger {
    border-color: rgba(201, 81, 103, 0.18);
}

.access-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.38rem 0.72rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.access-active {
    background: rgba(47, 107, 65, 0.14);
    color: var(--ohs-forest-ink);
}

.access-grace {
    background: rgba(182, 140, 24, 0.14);
    color: #6d5510;
}

.access-pending {
    background: rgba(51, 103, 164, 0.14);
    color: #274f80;
}

.access-expired,
.access-cancelled,
.access-none {
    background: rgba(201, 81, 103, 0.12);
    color: #8f3043;
}

.membership-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
    gap: 0.85rem;
    margin-top: 1.35rem;
}

.summary-item {
    padding: 0.95rem 1rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(111, 154, 88, 0.05);
}

.summary-label {
    margin-bottom: 0.35rem;
    color: var(--ohs-muted);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.summary-value {
    margin: 0;
    color: var(--ohs-ink);
    font-weight: 700;
}

.admin-version {
    color: var(--ohs-muted);
    font-size: 0.84rem;
    text-align: center;
}

.table-subtext {
    margin-top: 0.2rem;
    color: var(--ohs-muted);
    font-size: 0.88rem;
}

.empty-state-card {
    display: grid;
    gap: 0.55rem;
    place-items: start;
    padding: 1.2rem;
    border: 1px dashed rgba(47, 107, 65, 0.25);
    border-radius: 1.1rem;
    background: rgba(111, 154, 88, 0.06);
}

.empty-state-card i {
    font-size: 1.3rem;
    color: var(--ohs-forest);
}

.admin-code-area {
    min-height: 24rem;
    font-family: Consolas, "Courier New", monospace;
    font-size: 0.92rem;
    line-height: 1.5;
}

.rich-editor-shell .toastui-editor-defaultUI {
    border-color: var(--ohs-border);
    border-radius: 1rem;
    overflow: hidden;
}

.rich-editor-shell .toastui-editor-toolbar {
    background: rgba(111, 154, 88, 0.06);
}

.rich-editor-shell .toastui-editor-contents {
    font-family: "Manrope", sans-serif;
    font-size: 0.98rem;
    line-height: 1.7;
    color: var(--ohs-ink);
}

.admin-media-preview {
    display: grid;
    grid-template-columns: minmax(12rem, 15rem) minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(111, 154, 88, 0.05);
}

.admin-media-preview img {
    width: 100%;
    aspect-ratio: 16 / 10;
    border-radius: 0.95rem;
    object-fit: cover;
}

.observation-photo-admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    gap: 1rem;
}

.observation-photo-admin-card {
    display: grid;
    gap: 0.75rem;
    padding: 0.9rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(111, 154, 88, 0.05);
}

.observation-photo-admin-card img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 0.8rem;
}

.observation-picker-map {
    min-height: 22rem;
}

.admin-link-targets {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
    gap: 0.85rem;
}

.editor-tools-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.editor-tool-card {
    display: grid;
    gap: 0.95rem;
    padding: 1.15rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(111, 154, 88, 0.05);
}

.editor-tool-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 1rem;
}

.admin-link-target-results {
    display: grid;
    gap: 0.75rem;
}

.admin-link-target-card {
    display: grid;
    gap: 0.45rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.92);
}

.admin-link-target-meta {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: start;
}

.admin-link-target-scientific {
    display: block;
    margin-top: 0.2rem;
    color: var(--ohs-muted);
    font-size: 0.9rem;
    font-style: italic;
    font-weight: 700;
}

.admin-link-insert-btn {
    justify-self: start;
}

.body-media-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    align-items: end;
}

.body-media-upload-input {
    flex: 1 1 18rem;
}

.body-media-toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.body-media-status {
    min-height: 1.5rem;
}

.body-media-library {
    display: grid;
    gap: 0.9rem;
}

.body-media-card {
    display: grid;
    grid-template-columns: minmax(8rem, 10rem) minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.92);
}

.body-media-card img {
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 0.85rem;
    object-fit: cover;
}

.body-media-card-body {
    display: grid;
    gap: 0.75rem;
}

.body-media-select {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--ohs-ink-soft);
    font-size: 0.9rem;
    font-weight: 700;
}

.body-media-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.admin-link-target-card code,
.admin-media-preview code,
.body-media-card code {
    white-space: pre-wrap;
    word-break: break-word;
}

.audit-log-list {
    display: grid;
    gap: 1rem;
}

.audit-entry-card {
    padding: 1.15rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1.1rem;
    background: rgba(111, 154, 88, 0.04);
}

.audit-entry-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.85rem;
}

.audit-meta {
    display: grid;
    justify-items: end;
    gap: 0.2rem;
    color: var(--ohs-muted);
    font-size: 0.86rem;
    text-align: right;
}

.audit-details summary {
    cursor: pointer;
    color: var(--ohs-forest-ink);
    font-weight: 800;
}

.audit-change-list {
    display: grid;
    gap: 0.9rem;
    margin-top: 0.9rem;
}

.audit-change-row {
    padding: 0.95rem 1rem;
    border: 1px solid rgba(47, 107, 65, 0.12);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.88);
}

.audit-change-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.audit-change-heading {
    margin-bottom: 0.35rem;
    color: var(--ohs-muted);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.audit-change-value {
    min-height: 3rem;
    padding: 0.75rem 0.85rem;
    border-radius: 0.85rem;
    background: rgba(111, 154, 88, 0.08);
    color: var(--ohs-ink-soft);
    white-space: pre-wrap;
    word-break: break-word;
}

.compact-role-grid {
    grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
}

.compact-role-option {
    padding: 0.8rem 0.9rem;
}

.nav-icon-picker,
.nav-admin-card {
    padding: 1.1rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(111, 154, 88, 0.05);
}

.nav-icon-picker-head,
.nav-admin-card-head,
.nav-admin-child {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
}

.nav-icon-preview,
.nav-admin-icon {
    display: grid;
    place-items: center;
    width: 3rem;
    height: 3rem;
    border-radius: 0.95rem;
    border: 1px solid var(--ohs-border);
    background: rgba(255, 255, 255, 0.92);
    color: var(--ohs-forest-ink);
    box-shadow: var(--ohs-shadow-sm);
}

.nav-admin-icon.is-child {
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 0.8rem;
}

.nav-icon-preview i,
.nav-admin-icon i {
    font-size: 1.1rem;
}

.nav-icon-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
    gap: 0.65rem;
}

.nav-icon-option {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.55rem;
}

.nav-admin-stack {
    display: grid;
    gap: 1rem;
}

.nav-admin-card-title,
.nav-admin-child-main {
    display: flex;
    gap: 0.85rem;
    align-items: start;
}

.nav-admin-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem 1rem;
    margin-top: 0.9rem;
    color: var(--ohs-muted);
    font-size: 0.9rem;
    font-weight: 700;
}

.nav-admin-children {
    display: grid;
    gap: 0.75rem;
    margin-top: 1rem;
}

.nav-admin-child {
    padding: 0.9rem 1rem;
    border: 1px solid var(--ohs-border);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.92);
}

.nav-admin-empty {
    margin-top: 1rem;
}

.transport-panel[hidden],
.nav-destination-block[hidden] {
    display: none !important;
}

.table > :not(caption) > * > * {
    padding-block: 0.9rem;
}

@media (max-width: 991.98px) {
    .admin-shell {
        grid-template-columns: 1fr;
    }

    .admin-sidebar {
        border-right: 0;
        border-bottom: 1px solid var(--ohs-border);
    }

    .admin-grid,
    .admin-content-grid {
        grid-template-columns: 1fr;
    }

    .admin-form-grid {
        grid-template-columns: 1fr;
    }

    .admin-inline-fields {
        grid-template-columns: 1fr;
    }

    .editor-tools-grid,
    .audit-change-grid {
        grid-template-columns: 1fr;
    }

    .audit-meta {
        justify-items: start;
        text-align: left;
    }

    .admin-media-preview {
        grid-template-columns: 1fr;
    }

    .body-media-card {
        grid-template-columns: 1fr;
    }

    .nav-icon-picker-head,
    .nav-admin-card-head,
    .nav-admin-child,
    .nav-admin-card-title,
    .nav-admin-child-main {
        flex-direction: column;
        align-items: stretch;
    }
}
