/* Lazy-loaded Image Studio surface styles.
   Loaded with the image surface so chat startup does not carry gallery/editor chrome. */

        /* ── IMAGE STUDIO VIEW (V3 SPLIT) ── */
        .img-split {
            display: flex;
            flex: 1;
            overflow: hidden;
            min-width: 0;
        }

        .img-controls {
            width: 320px;
            border-right: 1px solid var(--border);
            padding: 24px;
            display: flex;
            flex-direction: column;
            gap: 18px;
            overflow-y: auto;
            background: var(--bg-1);
        }

        .ctrl-label {
            font-size: 11px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            color: var(--text-3);
            margin-bottom: 6px;
        }

        .ctrl {
            width: 100%;
            padding: 9px 12px;
            background: var(--bg-0);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text);
            font-family: inherit;
            font-size: 14px;
            outline: none;
            transition: 0.2s;
        }

        .ctrl:focus {
            border-color: var(--accent);
        }

        .ctrl option {
            background: var(--bg-1);
            color: var(--text);
        }

        .gen-btn {
            width: 100%;
            padding: 12px;
            background: var(--accent);
            color: var(--bg-0);
            border: none;
            border-radius: var(--radius);
            font-weight: 600;
            cursor: pointer;
            font-size: 14px;
            margin-top: auto;
            transition: 0.2s;
            box-shadow: var(--accent-glow);
        }

        .gen-btn:hover {
            opacity: 0.9;
        }

        .obs-gallery {
            flex: 1;
            padding: 24px;
            overflow-y: auto;
            display: flex;
            flex-direction: column;
            min-width: 0;
            min-height: 0;
            -webkit-overflow-scrolling: touch;
            overscroll-behavior: contain;
        }

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(var(--gallery-card-size, 220px), var(--gallery-card-size, 220px)));
    justify-content: flex-start;
    align-content: flex-start;
    align-items: start;
    grid-auto-flow: row;
    column-gap: 16px;
    row-gap: 0;
}


#obs-gallery-list.gallery-grid {
    display: flex !important;
    flex-wrap: wrap;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 16px;
}

#obs-gallery-list.gallery-grid > .g-card {
    flex: 0 0 var(--gallery-card-size, 220px);
    width: var(--gallery-card-size, 220px);
    margin-bottom: 0;
}

        .g-card {
            background: var(--bg-2);
            border: 1px solid var(--border);
            border-radius: var(--radius);
            overflow: hidden;
            cursor: pointer;
            transition: 0.2s;
            display: block;
            position: relative;
            width: 100%;
            min-width: 0;
            min-height: 0;
            margin-bottom: 16px;
            break-inside: avoid;
            content-visibility: auto;
            contain: layout paint style;
            contain-intrinsic-size: 220px 320px;
        }

        .g-card.loading {
            background: #050505;
            border-color: #161616;
        }

        .g-card:hover {
            border-color: var(--accent-mid);
            box-shadow: var(--accent-glow);
        }

.g-card:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    border-color: var(--accent);
    box-shadow: var(--accent-glow);
}

        .g-media-container {
            width: 100%;
            aspect-ratio: 1 / 1;
            position: relative;
            background: var(--bg-3);
            overflow: hidden;
        }

        .g-media-container img,
        .g-media-container video,
        .g-loading-thumb {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
            display: block;
        }

@media (max-width: 820px) {
    #obs-image .topbar-actions {
        flex: 0 0 auto;
        display: inline-flex;
        align-items: center;
        justify-content: flex-end;
        gap: 6px;
        min-width: 0;
        margin-left: auto;
    }

    #obs-image .topbar-actions .obs-report-issue-btn {
        display: none !important;
    }

    #obs-image .topbar .credits-chip {
        flex: 0 0 auto;
        max-width: min(48vw, 160px);
        min-height: 36px;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        padding: 0 11px;
        gap: 0;
        border-radius: 999px;
    }

    #obs-image .topbar .credits-chip-main {
        min-width: 0;
        gap: 6px;
    }

    #obs-image .topbar .credits-chip-label {
        font-size: 9px;
    }

    #obs-image .topbar .credits-chip-value {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 12px;
    }

    #obs-image .topbar .credits-chip-plan {
        display: none !important;
    }
}
        .g-media-container.g-media-missing {
            display: grid;
            place-items: center;
            background:
                radial-gradient(circle at 50% 38%, rgba(235, 75, 116, 0.12), transparent 48%),
                linear-gradient(180deg, #191b21, #101217);
        }

        .g-media-container.g-media-missing::after {
            content: attr(data-missing-label);
            max-width: calc(100% - 32px);
            padding: 8px 12px;
            border: 1px solid rgba(255, 255, 255, 0.12);
            border-radius: 999px;
            background: rgba(10, 12, 17, 0.7);
            color: rgba(255, 255, 255, 0.68);
            font-size: 11px;
            font-weight: 800;
            text-align: center;
            text-transform: uppercase;
            letter-spacing: 0.08em;
        }

        .g-media-type-badge {
            position: absolute;
            top: 10px;
            left: 10px;
            z-index: 4;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 58px;
            padding: 6px 10px;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.14);
            background: rgba(14, 18, 24, 0.72);
            backdrop-filter: blur(8px);
            color: rgba(255, 255, 255, 0.96);
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.12em;
            text-transform: uppercase;
            box-shadow: 0 8px 20px rgba(0, 0, 0, 0.28);
            pointer-events: none;
        }

        .g-media-type-badge.is-image {
            border-color: rgba(255, 255, 255, 0.14);
            background: rgba(18, 22, 28, 0.72);
        }

        .g-media-type-badge.is-video {
            border-color: rgba(236, 72, 153, 0.28);
            background: rgba(54, 18, 38, 0.76);
        }

        .g-media-type-badge.is-pending {
            border-color: rgba(255, 255, 255, 0.18);
            background: rgba(22, 24, 30, 0.82);
        }
        
        .g-loading-thumb {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 16px;
            box-sizing: border-box;
            background:
                radial-gradient(circle at center, rgba(255, 255, 255, 0.04), transparent 54%),
                linear-gradient(180deg, #020202, #0a0a0b);
            z-index: 1;
        }

        .g-thumb {
            aspect-ratio: 1;
            background: var(--bg-3);
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--text-3);
            font-size: 12px;
        }

        .g-loading-thumb {
            background: linear-gradient(180deg, #040404, #101010);
            position: relative;
            overflow: hidden;
        }

        .g-loading-thumb::before {
            content: "";
            position: absolute;
            inset: 0;
            background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.08), transparent);
            transform: translateX(-100%);
            animation: galleryShimmer 1.6s linear infinite;
        }

        .g-loading-thumb::after {
            content: "";
            position: absolute;
            inset: auto auto -28% 50%;
            transform: translateX(-50%);
            width: 200px;
            height: 200px;
            border-radius: 999px;
            background: radial-gradient(circle, rgba(255, 91, 125, 0.18), transparent 68%);
            opacity: 0.54;
            filter: blur(14px);
            pointer-events: none;
        }

        .g-loading-orb {
            display: none;
        }

        .g-loading-core {
            position: relative;
            z-index: 2;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 12px;
            max-width: 100%;
            text-align: center;
        }

        .g-loading-spinner {
            width: 36px;
            height: 36px;
            border-radius: 999px;
            border: 3px solid rgba(255, 255, 255, 0.14);
            border-top-color: rgba(255, 255, 255, 0.9);
            animation: gallerySpin 0.9s linear infinite;
            z-index: 2;
            box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.03);
        }

        .g-loading-label {
            position: relative;
            left: auto;
            right: auto;
            bottom: auto;
            font-size: 12px;
            text-transform: uppercase;
            letter-spacing: 0.18em;
            color: rgba(255, 255, 255, 0.86);
            text-align: center;
            z-index: 2;
        }

        .g-loading-copy {
            display: none;
        }

        .g-loading-prompt {
            display: none;
        }

        @keyframes gallerySpin {
            to {
                transform: rotate(360deg);
            }
        }

        @keyframes galleryShimmer {
            to {
                transform: translateX(100%);
            }
        }

        @keyframes galleryCardAppear {
            from {
                opacity: 0;
                transform: translateY(18px) scale(0.972);
            }

            to {
                opacity: 1;
                transform: translateY(0) scale(1);
            }
        }

        .g-card.fresh {
            animation: galleryCardAppear 0.56s cubic-bezier(0.16, 1, 0.3, 1) both;
            animation-delay: var(--gallery-appear-delay, 0ms);
        }

        .g-info {
            position: absolute;
            left: 0;
            right: 0;
            bottom: 0;
            background: linear-gradient(to top, rgba(0, 0, 0, 0.95) 0%, rgba(0, 0, 0, 0.7) 60%, transparent 100%);
            padding: 40px 12px 12px 12px;
            font-size: 13px;
            color: #fff;
            display: flex;
            flex-direction: column;
            justify-content: flex-end;
            transform: translateY(100%);
            opacity: 0;
            transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
            z-index: 3;
            max-height: 100%;
    gap: 8px;
        }

.g-card:hover .g-info,
.g-card:focus-visible .g-info {
            transform: translateY(0);
            opacity: 1;
        }

        .g-card-action-cluster {
            position: absolute;
            top: 10px;
            right: 10px;
            z-index: 5;
            display: inline-flex;
            flex-direction: column;
            align-items: center;
            gap: 7px;
        }

        .g-favorite-btn,
        .g-community-share-btn {
            width: 34px;
            height: 34px;
            min-width: 34px;
            min-height: 34px;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.12);
            background: rgba(18, 22, 28, 0.28);
            backdrop-filter: blur(10px);
            color: rgba(255, 255, 255, 0.88);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 0;
            cursor: pointer;
            transition: 0.18s ease;
            box-shadow: 0 10px 22px rgba(0, 0, 0, 0.14);
        }

        .g-favorite-btn:hover,
        .g-community-share-btn:hover {
            border-color: rgba(255, 255, 255, 0.22);
            background: rgba(20, 24, 30, 0.7);
            color: #fff;
        }

        .g-favorite-btn.is-active {
            color: #ffd479;
            border-color: rgba(255, 212, 121, 0.34);
            background: rgba(74, 52, 10, 0.58);
        }

        .g-favorite-btn-icon,
        .g-community-share-btn-icon {
            font-size: 14px;
            line-height: 1;
        }

        .g-favorite-btn-label,
        .g-community-share-btn-label {
            display: none;
        }

        .g-title {
            font-size: 14px;
            line-height: 1.5;
            color: #fff;
            margin-bottom: 8px;
            display: -webkit-box;
            -webkit-line-clamp: 4;
            line-clamp: 4;
            -webkit-box-orient: vertical;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: normal;
        }

.g-meta {
            display: flex;
    flex-wrap: wrap;
    gap: 6px;
        }

.g-meta-pill {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
            color: #fff;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.02em;
        }

        .g-tag {
            display: inline-block;
            background: rgba(255, 255, 255, 0.15);
            color: #fff;
            padding: 4px 8px;
            border-radius: 999px;
            font-size: 11px;
            font-weight: 600;
            margin-bottom: 12px;
            align-self: flex-start;
        }

@media (hover: none) {
    #obs-image #obs-gallery-list.gallery-grid .g-info {
        transform: translateY(100%) !important;
        opacity: 0 !important;
        padding-top: 40px !important;
    }

    #obs-image #obs-gallery-list.gallery-grid .g-card:focus-visible .g-info,
    #obs-image #obs-gallery-list.gallery-grid .g-card:focus-within .g-info,
    #obs-image #obs-gallery-list.gallery-grid .g-card.selected .g-info {
        transform: translateY(0) !important;
        opacity: 1 !important;
    }
}

        .gallery-empty-main {
            min-height: 100%;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            text-align: center;
            padding: 60px 20px;
            color: var(--text-3);
            font-size: 14px;
        }

        /* ── IMAGE STUDIO QUEUE PANEL ── */
        .img-queue-panel {
            width: 320px;
            border-right: 1px solid var(--border);
            display: flex;
            flex-direction: column;
            background: var(--bg-1);
            overflow: hidden;
            transition: width 0.18s ease;
        }

        .img-queue-header {
            padding: 16px 20px 12px;
            font-size: 13px;
            font-weight: 600;
            color: var(--text);
            border-bottom: 1px solid var(--border);
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .img-queue-header-actions {
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .img-panel-toggle {
            width: 30px;
            height: 30px;
            border-radius: 8px;
            border: 1px solid var(--border);
            background: var(--bg-2);
            color: var(--text-2);
            cursor: pointer;
            transition: 0.18s ease;
        }

        .img-panel-toggle:hover {
            color: var(--accent);
            border-color: var(--accent-mid);
        }

        .img-split.queue-collapsed .img-queue-panel {
            width: 72px;
        }

        .img-split.queue-collapsed .queue-header-label,
        .img-split.queue-collapsed .img-queue-content,
        .img-split.queue-collapsed .img-queue-footer,
        .img-split.queue-collapsed .image-queue-clear-btn {
            display: none !important;
        }

        .img-split.queue-collapsed .img-queue-header {
            justify-content: center;
            padding: 16px 8px;
        }

        #obs-image .img-split.queue-collapsed {
            grid-template-columns: 72px minmax(0, 1fr);
        }

        #obs-image .img-split.queue-collapsed .img-queue-header-actions {
            width: 100%;
            justify-content: center;
        }

        .img-queue-content {
            flex: 1;
            overflow-y: auto;
            padding: 12px;
        }

        #obs-image .img-queue-footer {
            padding: 10px 12px 12px;
            border-top: 1px solid rgba(255, 255, 255, 0.05);
            background: linear-gradient(180deg, rgba(13, 14, 18, 0), rgba(13, 14, 18, 0.94) 28%);
        }

        #obs-image .img-source-slot {
            display: block;
        }

        #obs-image .img-source-slot-title {
            font-size: 9px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.12em;
            color: var(--text-3);
        }

        #obs-image .img-source-slot-card {
            position: relative;
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 10px;
            border-radius: 16px;
            border: 1px solid rgba(255, 255, 255, 0.08);
            background:
                radial-gradient(circle at top right, rgba(255, 91, 125, 0.1), transparent 38%),
                linear-gradient(180deg, rgba(20, 21, 27, 0.96), rgba(12, 13, 18, 0.96));
            box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
            overflow: hidden;
        }

        #obs-image .img-source-slot-card.is-empty {
            border-color: rgba(255, 255, 255, 0.06);
            background:
                radial-gradient(circle at top right, rgba(255, 255, 255, 0.04), transparent 36%),
                linear-gradient(180deg, rgba(16, 17, 22, 0.94), rgba(10, 11, 15, 0.94));
        }

        #obs-image .img-source-slot-preview {
            position: relative;
            width: 48px;
            height: 48px;
            flex: 0 0 48px;
            border-radius: 14px;
            overflow: hidden;
            display: flex;
            align-items: center;
            justify-content: center;
            background:
                linear-gradient(180deg, rgba(26, 27, 34, 0.98), rgba(14, 15, 20, 0.98)),
                linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent);
            border: 1px solid rgba(255, 255, 255, 0.06);
        }

        #obs-image .img-source-thumb {
            width: 100%;
            height: 100%;
            object-fit: cover;
            display: block;
        }

        #obs-image .img-source-slot-empty-art {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 28px;
            height: 28px;
            border-radius: 10px;
            background: rgba(255, 255, 255, 0.04);
            border: 1px dashed rgba(255, 255, 255, 0.14);
            color: rgba(255, 255, 255, 0.48);
            font-size: 18px;
            line-height: 1;
        }

        #obs-image .img-source-slot-body {
            display: flex;
            flex-direction: column;
            gap: 2px;
            min-width: 0;
            flex: 1 1 auto;
        }

        #obs-image .img-source-slot-label {
            font-size: 11px;
            font-weight: 600;
            color: #fff;
            line-height: 1.4;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        #obs-image .img-source-slot-note {
            font-size: 10px;
            color: var(--text-3);
            line-height: 1.35;
            display: -webkit-box;
            -webkit-line-clamp: 1;
            line-clamp: 1;
            -webkit-box-orient: vertical;
            overflow: hidden;
        }

        #obs-image .img-source-clear {
            position: relative;
            top: auto;
            right: auto;
            width: 24px;
            height: 24px;
            flex: 0 0 auto;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.12);
            background: rgba(10, 14, 18, 0.5);
            color: rgba(255, 255, 255, 0.86);
            cursor: pointer;
            transition: 0.18s ease;
        }

        #obs-image .img-source-clear:hover {
            border-color: rgba(255, 255, 255, 0.22);
            background: rgba(14, 18, 24, 0.76);
            color: #fff;
        }

        .img-queue-empty {
            text-align: center;
            padding: 40px 20px;
            color: var(--text-3);
            font-size: 13px;
        }

        #obs-image #obs-image-queue-list {
            display: flex;
            flex-direction: column;
            gap: 10px !important;
        }

        #obs-image .image-queue-item {
            position: relative;
            display: flex;
            flex-direction: column;
            gap: 8px;
            padding: 12px;
            border-radius: 18px;
            border: 1px solid rgba(255, 255, 255, 0.07);
            background:
                linear-gradient(180deg, rgba(10, 11, 14, 0.985), rgba(6, 6, 8, 0.985)),
                radial-gradient(circle at top right, rgba(255, 255, 255, 0.03), transparent 28%);
            box-shadow: 0 16px 30px rgba(0, 0, 0, 0.22);
            color: var(--text);
            transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
        }

        #obs-image .image-queue-item.running {
            border-color: rgba(255, 91, 125, 0.22);
            box-shadow: 0 18px 34px rgba(0, 0, 0, 0.22), 0 0 0 1px rgba(255, 91, 125, 0.08) inset;
        }

        #obs-image .image-queue-item.done {
            border-color: rgba(34, 197, 94, 0.18);
        }

        #obs-image .image-queue-item.failed {
            border-color: rgba(248, 113, 113, 0.2);
        }

        #obs-image .image-queue-item.drag-over {
            transform: translateY(-2px);
            border-color: var(--accent);
        }

        #obs-image .image-queue-item.dragging {
            opacity: 0.56;
        }

        #obs-image .image-queue-head {
            display: flex;
            flex-direction: column;
            gap: 6px;
        }

        #obs-image .image-queue-topline {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
        }

        #obs-image .image-queue-eyebrow {
            display: inline-flex;
            align-items: center;
            flex-wrap: wrap;
            gap: 8px;
            min-width: 0;
        }

        #obs-image .image-queue-kind,
        #obs-image .image-queue-cost,
        #obs-image .image-queue-pill {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 24px;
            padding: 0 10px;
            border-radius: 999px;
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            white-space: nowrap;
        }

        #obs-image .image-queue-kind {
            background: rgba(255, 255, 255, 0.06);
            color: rgba(255, 255, 255, 0.84);
            border: 1px solid rgba(255, 255, 255, 0.08);
        }

        #obs-image .image-queue-cost {
            background: rgba(255, 91, 125, 0.12);
            color: #ffd8df;
            border: 1px solid rgba(255, 91, 125, 0.16);
        }

        #obs-image .image-queue-status {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 26px;
            padding: 0 12px;
            border-radius: 999px;
            font-size: 11px;
            font-weight: 700;
            white-space: nowrap;
            border: 1px solid rgba(255, 255, 255, 0.08);
            background: rgba(255, 255, 255, 0.04);
            color: rgba(255, 255, 255, 0.82);
        }

        #obs-image .image-queue-status.running {
            border-color: rgba(255, 91, 125, 0.18);
            background: rgba(255, 91, 125, 0.12);
            color: #ffd0da;
        }

        #obs-image .image-queue-status.done {
            border-color: rgba(34, 197, 94, 0.18);
            background: rgba(34, 197, 94, 0.12);
            color: #c3f6d3;
        }

        #obs-image .image-queue-status.failed {
            border-color: rgba(248, 113, 113, 0.18);
            background: rgba(248, 113, 113, 0.12);
            color: #ffd1d1;
        }

        #obs-image .image-queue-status.queued {
            border-color: rgba(255, 255, 255, 0.08);
            background: rgba(255, 255, 255, 0.04);
            color: rgba(255, 255, 255, 0.74);
        }

        #obs-image .image-queue-prompt {
            font-size: 15px;
            font-weight: 600;
            line-height: 1.45;
            color: #fff;
            word-break: break-word;
        }

        #obs-image .image-queue-model-row {
            display: flex;
            align-items: center;
            flex-wrap: wrap;
            gap: 6px;
            min-width: 0;
        }

        #obs-image .image-queue-model {
            font-size: 12px;
            color: var(--text-2);
            line-height: 1.45;
            flex: 1 1 140px;
            min-width: 0;
            word-break: break-word;
        }

        #obs-image .image-queue-pill {
            background: rgba(255, 255, 255, 0.05);
            color: rgba(255, 255, 255, 0.74);
            border: 1px solid rgba(255, 255, 255, 0.07);
        }

        #obs-image .image-queue-loading {
            display: inline-flex;
            align-items: center;
            gap: 10px;
            min-height: 34px;
            padding: 0 12px;
            border-radius: 14px;
            border: 1px solid rgba(255, 255, 255, 0.08);
            background: rgba(255, 255, 255, 0.03);
            width: fit-content;
            max-width: 100%;
        }

        #obs-image .image-queue-loading--loading {
            background: rgba(0, 0, 0, 0.46);
            border-color: rgba(255, 255, 255, 0.08);
        }

        #obs-image .image-queue-loading--done {
            border-color: rgba(34, 197, 94, 0.2);
            background: rgba(34, 197, 94, 0.08);
        }

        #obs-image .image-queue-loading--failed {
            border-color: rgba(248, 113, 113, 0.2);
            background: rgba(248, 113, 113, 0.08);
        }

        #obs-image .image-queue-loading-spinner {
            width: 16px;
            height: 16px;
            border-radius: 999px;
            border: 2px solid rgba(255, 255, 255, 0.16);
            border-top-color: rgba(255, 255, 255, 0.92);
            animation: gallerySpin 0.9s linear infinite;
            flex: 0 0 auto;
        }

        #obs-image .image-queue-loading--done .image-queue-loading-spinner,
        #obs-image .image-queue-loading--failed .image-queue-loading-spinner {
            animation: none;
            border-top-color: currentColor;
        }

        #obs-image .image-queue-loading-label {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: 0.14em;
            text-transform: uppercase;
            color: rgba(255, 255, 255, 0.8);
        }

        #obs-image .image-queue-note {
            font-size: 12px;
            line-height: 1.45;
            color: var(--text-3);
            display: grid;
            gap: 4px;
        }

        #obs-image .image-queue-note-title {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: 0.12em;
            text-transform: uppercase;
            color: rgba(255, 214, 222, 0.9);
        }

        #obs-image .image-queue-note-hint {
            font-size: 12px;
            line-height: 1.45;
            color: var(--text-3);
        }

        #obs-image .image-queue-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }

        #obs-image .image-queue-action-btn {
            min-height: 30px;
            padding: 0 12px;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.08);
            background: rgba(255, 255, 255, 0.04);
            color: rgba(255, 255, 255, 0.82);
            font-size: 11px;
            font-weight: 700;
            cursor: pointer;
            transition: 0.18s ease;
        }

        #obs-image .image-queue-action-btn:hover {
            border-color: rgba(255, 255, 255, 0.16);
            background: rgba(255, 255, 255, 0.08);
            color: #fff;
        }

        .img-prompt-bar {
            padding: 12px 16px;
            border-top: 1px solid var(--border);
            background: var(--bg-1);
        }

        .img-reuse-strip {
            display: flex;
            align-items: center;
            gap: 10px;
            margin-bottom: 10px;
            padding: 10px 12px;
            border-radius: 16px;
            border: 1px solid rgba(255, 255, 255, 0.08);
            background:
                linear-gradient(180deg, rgba(23, 24, 30, 0.96), rgba(12, 13, 18, 0.96)),
                radial-gradient(circle at top right, rgba(255, 91, 125, 0.1), transparent 40%);
        }

        .img-reuse-thumb {
            width: 40px;
            height: 40px;
            border-radius: 12px;
            object-fit: cover;
            flex: 0 0 auto;
            display: block;
            border: 1px solid rgba(255, 255, 255, 0.08);
        }

        .img-reuse-copy {
            min-width: 0;
            display: flex;
            flex-direction: column;
            gap: 2px;
        }

        .img-reuse-label {
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.12em;
            text-transform: uppercase;
            color: var(--text-3);
        }

        .img-reuse-name {
            font-size: 12px;
            font-weight: 600;
            color: #fff;
            line-height: 1.4;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .img-reuse-clear {
            width: 28px;
            height: 28px;
            border-radius: 999px;
            border: 1px solid rgba(255, 255, 255, 0.1);
            background: rgba(255, 255, 255, 0.04);
            color: rgba(255, 255, 255, 0.78);
            cursor: pointer;
            flex: 0 0 auto;
            transition: 0.18s ease;
        }

        .img-reuse-clear:hover {
            border-color: rgba(255, 255, 255, 0.2);
            background: rgba(255, 255, 255, 0.08);
            color: #fff;
        }

        .img-prompt-box {
            background: var(--bg-0);
            border: 1px solid var(--border-bright);
            border-radius: 12px;
            padding: 10px 12px;
            display: flex;
            align-items: flex-end;
            gap: 10px;
            transition: 0.2s;
        }

        .img-prompt-box:focus-within {
            border-color: var(--accent);
            box-shadow: var(--accent-glow);
        }

        .img-prompt-box textarea {
            flex: 1;
            background: transparent;
            border: none;
            outline: none;
            resize: none;
            min-height: 20px;
            max-height: 80px;
            font-family: inherit;
            font-size: 13px;
            color: var(--text);
            line-height: 1.4;
        }

        .img-prompt-box textarea::placeholder {
            color: var(--text-3);
        }

        .img-send-btn {
            background: var(--accent);
            color: var(--bg-0);
            border: none;
            border-radius: 6px;
            width: 28px;
            height: 28px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 14px;
            transition: 0.2s;
            flex-shrink: 0;
        }

        .img-send-btn:hover {
            opacity: 0.85;
        }


        #obs-image .img-split {
            display: grid;
            grid-template-columns: minmax(264px, 328px) minmax(0, 1fr);
            gap: 0;
            min-height: 0;
        }

        #obs-image .img-queue-panel {
            width: auto;
            min-width: 0;
            min-height: 0;
            display: flex;
            flex-direction: column;
        }

        #obs-image .obs-gallery {
            display: grid !important;
            grid-template-columns: minmax(0, 1fr);
            grid-template-rows: auto minmax(0, 1fr) auto;
            gap: 18px;
            padding: 18px 18px 16px;
            overflow: visible;
            min-width: 0;
            min-height: 0;
            align-items: stretch;
        }

        #obs-image .gallery-toolbar,
        #obs-image .gallery-empty-main,
        #obs-image #obs-gallery-list.gallery-grid,
        #obs-image .img-prompt-bar {
            grid-column: 1 / -1;
            width: 100%;
            align-self: stretch;
        }

        #obs-image .gallery-toolbar {
            grid-row: 1;
        }

        #obs-image .gallery-empty-main,
        #obs-image #obs-gallery-list.gallery-grid {
            grid-row: 2;
            min-height: 0;
        }

        #obs-image #obs-gallery-list.gallery-grid {
            flex: 1 1 auto;
            min-height: 0;
            overflow: auto;
            padding-right: 2px;
            margin-right: -2px;
        }

        #obs-image .img-prompt-bar {
            grid-row: 3;
            order: initial;
            flex: 0 0 auto;
            justify-self: stretch;
            margin: 0;
            padding: 0;
            border-top: none;
            background: transparent;
            position: static !important;
            inset: auto !important;
            width: 100%;
            max-width: none !important;
            min-width: 0;
            z-index: 2;
        }

        #obs-image .img-prompt-box {
            width: 100%;
            max-width: none !important;
            min-width: 0;
            display: flex;
            flex-direction: column;
            align-items: stretch;
            gap: 10px;
            padding: 9px 12px;
            border-radius: 18px;
            background:
                linear-gradient(180deg, rgba(23, 24, 30, 0.98), rgba(12, 13, 18, 0.98)),
                radial-gradient(circle at top left, rgba(255, 91, 125, 0.08), transparent 26%);
            box-shadow: 0 18px 38px rgba(0, 0, 0, 0.22);
        }

        .image-mobile-control-row {
            display: none !important;
        }

        #obs-image .img-compose-main {
            width: 100%;
            min-width: 0;
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto auto auto;
            align-items: center;
            gap: 10px;
        }

        #obs-image .img-upload-btn {
            width: 38px;
            height: 38px;
            min-width: 38px;
            min-height: 38px;
            border-radius: 12px;
            border: 1px solid rgba(255, 255, 255, 0.08);
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015));
            color: var(--text-2);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 0;
            cursor: pointer;
            transition: 0.18s ease;
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
        }

        #obs-image .img-upload-btn:hover,
        #obs-image .img-upload-btn:focus-visible {
            color: var(--text);
            border-color: var(--accent-mid);
            background: rgba(255, 255, 255, 0.045);
        }

        #obs-image .img-upload-btn.is-active,
        #obs-image .img-upload-btn[aria-pressed="true"] {
            color: var(--accent);
            border-color: rgba(244, 63, 94, 0.35);
            background: rgba(244, 63, 94, 0.12);
            box-shadow: 0 0 0 1px rgba(244, 63, 94, 0.14), var(--accent-glow);
        }

        #obs-image .img-upload-btn:disabled {
            opacity: 0.66;
            cursor: progress;
        }

        #obs-image .img-upload-btn .chat-tool-icon,
        #obs-image .img-upload-btn .chat-tool-icon svg {
            width: 17px;
            height: 17px;
            display: block;
        }

        #obs-image .img-compose-side-controls {
            display: inline-flex;
            align-items: center;
            justify-content: flex-end;
            gap: 8px;
            flex: 0 0 auto;
        }

        #obs-image .img-upload-preview {
            margin-top: 0;
        }

        #obs-image .img-upload-preview .attach-chip {
            max-width: 100%;
            width: 100%;
        }

        #obs-image .img-prompt-box textarea {
            min-width: 0;
            width: 100%;
            min-height: 18px;
            max-height: 72px;
            padding: 2px 0;
            font-size: 13px;
            line-height: 1.45;
        }

        #obs-image .img-batch-control {
            display: inline-flex;
            align-items: center;
            gap: 8px;
        }

        #obs-image .img-batch-control.is-disabled {
            opacity: 0.46;
        }

        #obs-image .img-batch-control.is-disabled .img-batch-step-btn {
            cursor: default;
        }

        #obs-image .img-batch-label {
            font-size: 11px;
            color: var(--text-3);
            text-transform: uppercase;
            letter-spacing: 0.08em;
        }

        #obs-image .img-batch-stepper {
            display: inline-flex;
            align-items: center;
            border: 1px solid var(--border);
            border-radius: 12px;
            overflow: hidden;
            background: color-mix(in srgb, var(--bg-2) 90%, #fff 10%);
        }

        #obs-image .img-batch-step-btn {
            width: 30px;
            height: 30px;
            border: none;
            background: transparent;
            color: var(--text-2);
            cursor: pointer;
            transition: 0.18s ease;
        }

        .img-batch-step-btn:hover {
            color: var(--text);
            background: rgba(255, 255, 255, 0.05);
        }

        #obs-image .img-batch-input {
            width: 34px;
            min-width: 34px;
            height: 30px;
            border: none;
            background: transparent;
            color: var(--text);
            text-align: center;
            font-size: 13px;
            font-weight: 600;
            pointer-events: none;
        }

        #obs-image .img-cost-pill {
            min-height: 30px;
            padding: 0 12px;
            border-radius: 999px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            background: rgba(255, 91, 125, 0.12);
            border: 1px solid rgba(255, 91, 125, 0.16);
            color: #ffd5de;
            font-size: 12px;
            font-weight: 700;
        }

        #obs-image .img-send-btn {
            width: 38px;
            height: 38px;
            min-width: 38px;
            border-radius: 14px;
            font-size: 15px;
            box-shadow: 0 12px 28px rgba(255, 71, 115, 0.22);
        }

        #obs-image .g-card-action-cluster {
            top: 10px;
            right: 10px;
            display: inline-flex;
            flex-direction: column;
            align-items: center;
            gap: 7px;
        }

        #obs-image .g-favorite-btn,
        #obs-image .g-community-share-btn {
            width: 32px;
            min-width: 32px;
            height: 32px;
            min-height: 32px;
            border-radius: 999px;
            font-size: 0 !important;
            line-height: 0 !important;
        }

        #obs-image .g-favorite-btn-label,
        #obs-image .g-community-share-btn-label {
            display: none !important;
        }

        #obs-image .g-favorite-btn-icon,
        #obs-image .g-community-share-btn-icon {
            font-size: 13px;
            line-height: 1;
        }

        #obs-image-model-menu.obs-model-menu--floating,
        #obs-image-route-menu.obs-model-menu--floating {
            position: fixed !important;
            top: var(--obs-model-menu-top, 72px) !important;
            left: var(--obs-model-menu-left, 16px) !important;
            right: auto !important;
            width: var(--obs-model-menu-width, min(640px, calc(100vw - 32px))) !important;
            max-width: calc(100vw - 32px);
            max-height: var(--obs-model-menu-max-height, min(72vh, 760px)) !important;
            overflow: auto;
            z-index: 5600 !important;
        }

        #obs-image-route-menu.obs-model-menu--floating {
            width: min(var(--obs-model-menu-width, 460px), calc(100vw - 36px)) !important;
            max-width: calc(100vw - 36px);
        }

        .img-cost-pill {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 56px;
            height: 32px;
            padding: 0 10px;
            border-radius: 999px;
            border: 1px solid var(--border);
            background: color-mix(in srgb, var(--bg-2) 92%, #fff 8%);
            color: var(--text);
            font-size: 12px;
            font-weight: 700;
            letter-spacing: 0.02em;
            white-space: nowrap;
        }

        .img-send-btn {
            width: 38px;
            height: 38px;
            border-radius: 12px;
            font-size: 16px;
            box-shadow: var(--accent-glow);
        }

        .g-card-action-cluster {
            gap: 7px;
            flex-direction: column;
            padding: 4px;
            border-radius: 999px;
            background: rgba(10, 14, 18, 0.14);
            backdrop-filter: blur(10px);
            box-shadow: 0 12px 26px rgba(0, 0, 0, 0.14);
        }

        .g-favorite-btn,
        .g-community-share-btn {
            width: 30px;
            height: 30px;
            min-width: 30px;
            min-height: 30px;
            font-size: 0 !important;
            background: rgba(18, 22, 28, 0.24);
            box-shadow: none;
        }

        .g-favorite-btn-icon,
        .g-community-share-btn-icon {
            font-size: 13px;
        }

        .gallery-sort-select,
        .gallery-sort-select option {
            color: var(--text);
            background: var(--bg-1);
        }

/* ── IMAGE MODEL CARDS (rendered by the split frontend modules) ── */
        .image-section-heading {
            font-size: 11px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1.5px;
            color: var(--text-3);
            padding: 16px 0 8px;
            margin-top: 8px;
        }

        .image-section-heading:first-child {
            margin-top: 0;
        }

        .image-family-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
            gap: 10px;
            margin-bottom: 12px;
        }

        .image-family-card {
            background: var(--bg-2);
            border: 1px solid var(--border);
            border-radius: var(--radius);
            padding: 14px;
            cursor: pointer;
            transition: 0.2s;
            text-align: center;
        }

        .image-family-card:hover {
            border-color: var(--accent-mid);
            background: var(--bg-hover);
        }

        .image-family-card.selected {
            border-color: var(--accent);
            background: var(--accent-dim);
            box-shadow: var(--accent-glow);
        }

        .image-family-title {
            font-weight: 600;
            font-size: 13px;
            color: var(--text);
            margin-bottom: 4px;
        }

        .image-family-model {
            font-size: 11px;
        }

        .image-family-model.ready {
            color: #22c55e;
        }

        .image-family-model.not-ready {
            color: var(--text-3);
        }

        @media (max-width: 820px) {
            #obs-image.obs-view.active {
                overflow-y: auto;
                -webkit-overflow-scrolling: touch;
            }

            #obs-image .img-split {
                display: block !important;
                grid-template-columns: minmax(0, 1fr) !important;
                min-height: auto;
                overflow: visible;
            }

            #obs-image .img-queue-panel {
                position: fixed;
                left: 10px;
                right: 10px;
                bottom: calc(82px + env(safe-area-inset-bottom));
                width: auto;
                border: none;
                background: transparent;
                backdrop-filter: none;
                z-index: 35;
                max-height: none;
                pointer-events: none;
            }

            #obs-image .img-queue-header,
            #obs-image .img-queue-content,
            #obs-image .img-queue-footer,
            #obs-image .img-panel-toggle,
            #obs-image .image-queue-clear-btn,
            #obs-image .queue-header-label {
                display: none !important;
            }

            #obs-image .obs-gallery {
                display: block !important;
                width: 100%;
                padding: 10px 10px calc(206px + env(safe-area-inset-bottom, 0px)) !important;
                height: auto;
                min-height: auto;
                overflow: visible;
                box-sizing: border-box;
            }

            #obs-image .gallery-toolbar {
                position: sticky;
                top: 0;
                z-index: 8;
                width: calc(100% + 20px);
                margin: -10px -10px 10px;
                padding: 10px 12px 10px;
                border-radius: 0 0 18px 18px;
                background: linear-gradient(180deg, rgba(13, 13, 13, 0.96), rgba(13, 13, 13, 0.82));
                border: 1px solid rgba(255, 255, 255, 0.08);
                border-top: none;
                border-left: none;
                border-right: none;
                box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
                grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
                grid-template-areas:
                    'actions center .'
                    'sort sort sort';
                gap: 8px 10px;
                justify-items: stretch;
                align-items: center;
            }

            #obs-image .gallery-toolbar-copy,
            #obs-image .gallery-sort-label {
                display: none;
            }

            #obs-image .gallery-toolbar-center {
                grid-area: center;
                min-width: 0;
                display: grid;
                align-items: flex-start;
                justify-self: center;
                justify-items: center;
                text-align: center;
                gap: 2px;
            }

            #obs-image .gallery-toolbar-actions {
                grid-area: actions;
                justify-self: start;
                justify-content: flex-start;
                gap: 6px;
                align-items: center;
            }

            #obs-image .gallery-toolbar-sort {
                grid-area: sort;
                display: grid;
                grid-template-columns: repeat(2, minmax(0, 1fr));
                justify-self: stretch;
                gap: 6px;
                align-items: center;
            }

            #obs-image .gallery-toolbar-btn,
            #obs-image .gallery-sort-select {
                min-width: 0;
                min-height: 40px;
                height: 40px;
                border-radius: 14px;
                font-size: 12px;
                padding: 0 12px;
            }

            #obs-image .gallery-toolbar-btn {
                width: auto;
                min-width: 88px;
            }

            #obs-image .gallery-sort-select {
                width: 100%;
                max-width: none;
                padding-right: 34px;
            }

            #obs-image #obs-gallery-list.gallery-grid {
                display: grid !important;
                grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
                gap: 8px !important;
                width: 100%;
                overflow: visible !important;
                padding-right: 0 !important;
                padding-bottom: 0 !important;
                margin-right: 0 !important;
            }

            #obs-image #obs-gallery-list.gallery-grid > .g-card {
                width: auto !important;
                min-width: 0 !important;
                flex: none !important;
                margin: 0 !important;
                aspect-ratio: 1 / 1;
            }

            #obs-image .gallery-empty-main {
                min-height: calc(100dvh - 180px);
                padding: 28px 12px calc(228px + env(safe-area-inset-bottom));
            }

            #obs-image .img-prompt-bar {
                display: block !important;
                position: fixed !important;
                left: 50% !important;
                right: auto !important;
                bottom: 0 !important;
                top: auto !important;
                transform: translateX(-50%);
                width: min(calc(100vw - 8px), 560px) !important;
                max-width: min(calc(100vw - 8px), 560px) !important;
                z-index: 86;
                pointer-events: auto;
                padding: 0 0 calc(env(safe-area-inset-bottom) + 2px);
                border-top: none;
                background: transparent;
                backdrop-filter: none;
                box-shadow: none;
                margin: 0;
                visibility: visible !important;
                opacity: 1 !important;
            }

            #obs-image .img-prompt-box {
                width: 100%;
                max-width: none !important;
                min-width: 0;
                display: flex;
                flex-direction: column;
                align-items: stretch;
                flex-wrap: wrap;
                gap: 8px;
                border-radius: 20px;
                padding: 9px 10px 10px;
                background: linear-gradient(180deg, rgba(20, 21, 28, 0.96), rgba(13, 14, 18, 0.98));
                border: 1px solid rgba(255, 255, 255, 0.08);
                box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34);
            }

            #obs-image .image-mobile-control-row {
                display: grid !important;
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: 6px;
                width: 100%;
                visibility: visible !important;
                opacity: 1 !important;
            }

            #obs-image .img-prompt-box .mobile-composer-model-slot {
                order: 1;
                flex: 1 1 auto;
                min-width: 0;
                display: block !important;
                visibility: visible !important;
                opacity: 1 !important;
            }

            #obs-image .img-compose-main {
                width: 100%;
                display: grid;
                grid-template-columns: minmax(0, 1fr) auto auto;
                grid-template-areas:
                    'prompt upload send'
                    'controls controls controls';
                align-items: end;
                gap: 6px;
            }

            #obs-image .img-prompt-box textarea,
            #obs-image .img-compose-main textarea {
                grid-area: prompt;
                order: 2;
                width: 100%;
                min-height: 38px;
                max-height: 96px;
                padding: 4px 0;
                font-size: 13.5px;
            }

            #obs-image .img-upload-btn {
                grid-area: upload;
                width: 40px;
                min-width: 40px;
                height: 40px;
                padding: 0;
                border-radius: 14px;
            }

            #obs-image .img-compose-side-controls {
                grid-area: controls;
                width: 100%;
                display: flex;
                justify-content: space-between;
                align-items: center;
                gap: 8px;
            }

            #obs-image .img-send-btn {
                grid-area: send;
                align-self: end;
                width: 40px;
                min-width: 40px;
                height: 40px;
                padding: 0;
                border-radius: 14px;
            }

            #obs-image .mobile-model-button {
                display: flex !important;
                align-items: center;
                justify-content: space-between;
                gap: 8px;
                min-height: 40px;
                padding: 8px 10px;
                border-radius: 14px;
                visibility: visible !important;
                opacity: 1 !important;
                width: 100%;
            }

            #obs-image-model-menu:not([hidden]),
            #obs-image-route-menu:not([hidden]) {
                position: fixed;
                top: auto;
                right: 10px;
                bottom: calc(12px + env(safe-area-inset-bottom));
                left: 10px;
                width: auto !important;
                min-height: 188px;
                max-height: min(72dvh, calc(100dvh - 118px - env(safe-area-inset-top) - env(safe-area-inset-bottom))) !important;
                overflow-y: auto;
                overscroll-behavior: contain;
                -webkit-overflow-scrolling: touch;
                display: flex;
                flex-direction: column;
                padding: 10px 10px calc(12px + env(safe-area-inset-bottom));
                border-radius: 18px;
                z-index: 7600 !important;
                box-shadow: 0 28px 68px rgba(0, 0, 0, 0.5);
                pointer-events: auto;
                touch-action: manipulation;
            }

            #obs-image-model-menu .obs-model-menu-grid,
            #obs-image-route-menu .obs-model-menu-grid {
                grid-template-columns: 1fr;
                gap: 8px;
            }

            #obs-image-model-menu .obs-model-card,
            #obs-image-route-menu .obs-model-card {
                min-height: 0;
                padding: 10px;
                gap: 6px;
                border-radius: 12px;
            }

            #obs-image-model-menu .obs-model-card-meta,
            #obs-image-route-menu .obs-model-card-meta {
                margin-top: 6px;
                gap: 6px;
            }
        }

