/* 12315 modal styles */

#operation-log-modal-12315 .app-inline-overlay > div > div:first-child {
    border-radius: 12px 12px 0 0;
    overflow: hidden;
}

#operation-log-modal-12315 .app-inline-overlay > div > div:first-child > div:first-child {
    margin: 0 !important;
    font-family: var(--app-brand-dialog-title-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', sans-serif) !important;
    font-size: var(--app-brand-dialog-title-font-size, 18px) !important;
    font-weight: var(--app-brand-dialog-title-font-weight, 700) !important;
    line-height: var(--app-brand-dialog-title-line-height, 1.2) !important;
    letter-spacing: var(--app-brand-dialog-title-letter-spacing, 0.01em) !important;
    color: var(--app-brand-modal-header-fg, #1E2329) !important;
}

.case-12315-manual-notice-modal .case-12315-manual-notice__panel {
    width: min(640px, 94vw);
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 20px 48px rgba(15, 23, 42, 0.25);
    overflow: hidden;
}

.case-12315-manual-notice__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    background: var(--modal-header-bg, linear-gradient(135deg, #F0B90B 0%, #F8D12F 100%));
    color: var(--modal-header-fg, #1E2329);
    border-bottom: 1px solid var(--modal-header-border, #F0B90B);
    --app-close-btn-color: #FFFFFF;
    --app-close-btn-bg: rgba(255, 255, 255, 0.10);
    --app-close-btn-bg-hover: rgba(255, 255, 255, 0.18);
}

.case-12315-manual-notice__header h3 {
    margin: 0;
    font-size: 18px;
    color: inherit;
}

.case-12315-manual-notice__meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 12px 18px;
    border-bottom: 1px solid #f1f5f9;
    color: #334155;
    font-size: 13px;
}

.case-12315-manual-notice__body {
    padding: 14px 18px;
    display: grid;
    gap: 12px;
}

.case-12315-manual-notice__field {
    display: grid;
    gap: 6px;
}

.case-12315-manual-notice__field span {
    font-size: 13px;
    color: #334155;
}

.case-12315-manual-notice__field input[type="date"],
.case-12315-manual-notice__field input[type="text"],
.case-12315-manual-notice__field select,
.case-12315-manual-notice__field textarea {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    padding: 9px 11px;
    font-size: 14px;
    background: #fff;
}

.case-12315-manual-notice__choice-list,
.case-12315-manual-notice__type-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
    box-sizing: border-box;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    padding: 10px;
    background: #fff;
}

.case-12315-manual-notice__choice-item,
.case-12315-manual-notice__type-item {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 4px 6px;
    border-radius: 6px;
    cursor: pointer;
    user-select: none;
    transition: background-color 0.15s ease;
}

.case-12315-manual-notice__choice-item:hover,
.case-12315-manual-notice__type-item:hover {
    background: rgba(240, 185, 11, 0.1);
}

.case-12315-manual-notice__choice-item.is-checked,
.case-12315-manual-notice__type-item.is-checked {
    background: transparent;
}

.case-12315-manual-notice__choice-item input[type="checkbox"],
.case-12315-manual-notice__type-item input[type="checkbox"] {
    position: absolute !important;
    opacity: 0 !important;
    width: 1px !important;
    height: 1px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
}

.case-12315-manual-notice__choice-item input[type="checkbox"]:focus-visible,
.case-12315-manual-notice__type-item input[type="checkbox"]:focus-visible {
    box-shadow: none;
}

.case-12315-manual-notice__choice-text,
.case-12315-manual-notice__type-text {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #1f2937;
    font-weight: 600;
    white-space: nowrap;
    line-height: 1.15;
}

.case-12315-manual-notice__choice-text::before,
.case-12315-manual-notice__type-text::before {
    content: "";
    box-sizing: border-box;
    width: 10px;
    height: 10px;
    flex: 0 0 10px;
    border: 1px solid #9CA3AF;
    border-radius: 2px;
    background: #FFFFFF;
    transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.case-12315-manual-notice__choice-item input[type="checkbox"]:checked + .case-12315-manual-notice__choice-text::before,
.case-12315-manual-notice__type-item input[type="checkbox"]:checked + .case-12315-manual-notice__type-text::before {
    border-color: #D4A106;
    background: #F0B90B;
    box-shadow: inset 0 0 0 999px #F0B90B;
}

.case-12315-manual-notice__choice-item input[type="checkbox"]:checked + .case-12315-manual-notice__choice-text::after,
.case-12315-manual-notice__type-item input[type="checkbox"]:checked + .case-12315-manual-notice__type-text::after {
    content: "";
    position: absolute;
    left: 9px;
    top: 50%;
    width: 2px;
    height: 5px;
    margin-top: -3px;
    border-right: 1.25px solid #1E2329;
    border-bottom: 1.25px solid #1E2329;
    transform: rotate(45deg);
}

.case-12315-manual-notice__choice-item input[type="checkbox"]:focus-visible + .case-12315-manual-notice__choice-text::before,
.case-12315-manual-notice__type-item input[type="checkbox"]:focus-visible + .case-12315-manual-notice__type-text::before {
    box-shadow: 0 0 0 2px rgba(240, 185, 11, 0.18);
}

.case-12315-manual-notice__images-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.case-12315-manual-notice__images-toolbar small {
    color: #64748b;
    font-size: 12px;
}

.case-12315-manual-notice__images-list {
    border: 1px dashed #d1d5db;
    border-radius: 8px;
    padding: 10px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    min-height: 96px;
    background: #fff;
}

.case-12315-manual-notice__image-item {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 8px;
    display: grid;
    gap: 6px;
    background: #f8fafc;
}

.case-12315-manual-notice__image-item img {
    width: 100%;
    height: 80px;
    object-fit: cover;
    border-radius: 6px;
    display: block;
}

.case-12315-manual-notice__image-name {
    font-size: 12px;
    color: #334155;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.case-12315-manual-notice__images-empty {
    grid-column: 1 / -1;
    color: #94a3b8;
    font-size: 13px;
    align-self: center;
}

@media (max-width: 640px) {
    .case-12315-manual-notice__choice-list,
    .case-12315-manual-notice__type-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .case-12315-manual-notice__images-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .case-12315-manual-notice__images-toolbar {
        flex-direction: column;
        align-items: flex-start;
    }
}

.case-12315-manual-notice__field textarea {
    resize: vertical;
    min-height: 82px;
}

.case-12315-manual-notice__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 14px 18px;
    border-top: 1px solid #e5e7eb;
}

.case-12315-manual-notice__footer-left {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.case-12315-manual-notice__footer-right {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

@media (max-width: 640px) {
    .case-12315-manual-notice__footer {
        flex-direction: column;
        align-items: stretch;
    }

    .case-12315-manual-notice__footer-left,
    .case-12315-manual-notice__footer-right {
        justify-content: flex-end;
        flex-wrap: wrap;
    }
}

.case-detail-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--app-modal-mask-bg, rgba(11, 14, 17, 0.62));
    backdrop-filter: var(--app-modal-mask-filter, blur(16px) saturate(1.04));
    -webkit-backdrop-filter: var(--app-modal-mask-filter, blur(16px) saturate(1.04));
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-modal-max, 2147483210);
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.case-detail-modal.active {
    opacity: 1;
    visibility: visible;
}

.case-detail-modal-content {
    background: var(--bg-card, var(--bg-primary, #FFFFFF));
    border-radius: 12px;
    max-width: 900px;
    width: 90%;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    transform: scale(0.9);
    transition: transform 0.3s ease;
}

.case-detail-modal.active .case-detail-modal-content {
    transform: scale(1);
}

.case-detail-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 32px;
    border-bottom: 1px solid rgba(11, 14, 17, 0.12);
    position: sticky;
    top: 0;
    background: linear-gradient(135deg, var(--brand-primary, #F0B90B) 0%, #FCD535 100%);
    color: #0B0E11;
    z-index: 10;
}

.case-detail-modal-body {
    padding: 32px;
}

.case-detail-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 20px 32px;
    border-top: 1px solid var(--border-color, #E5E7EB);
    position: sticky;
    bottom: 0;
    background: var(--bg-card, var(--bg-primary, #FFFFFF));
}

@media (max-width: 768px) {

    .case-detail-modal-content {
        width: 95%;
        max-height: 90vh;
    }

}

.case-12315-detail-modal {
    position: fixed;
    inset: 0;
    background: var(--app-modal-mask-bg, rgba(11, 14, 17, 0.62));
    backdrop-filter: var(--app-modal-mask-filter, blur(16px) saturate(1.04));
    -webkit-backdrop-filter: var(--app-modal-mask-filter, blur(16px) saturate(1.04));
    z-index: var(--z-modal-max, 2147483210);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}

.case-12315-detail__container {
    background: var(--bg-card, #FFFFFF);
    border-radius: 12px;
    width: min(900px, 92vw);
    max-height: 90vh;
    overflow: visible;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    position: relative;
}

.case-12315-detail__header {
    padding: 16px 20px;
    flex-shrink: 0;
    color: #FFFFFF;
    border-radius: 12px 12px 0 0;
}

.case-12315-detail__header--complaint {
    background: #0ECB81;
}

.case-12315-detail__header--report {
    background: #F0B90B;
}

.case-12315-detail__header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    --case-12315-detail-header-control-height: 34px;
}

.case-12315-detail__title {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.case-12315-detail__title h3 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #FFFFFF;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.case-12315-detail__status-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    min-height: var(--case-12315-detail-header-control-height);
    height: var(--case-12315-detail-header-control-height);
    background: rgba(255, 255, 255, 0.9);
    padding: 6px 12px;
    border-radius: 8px;
    color: #1E2329;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.case-12315-detail__updated-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    min-height: var(--case-12315-detail-header-control-height);
    height: var(--case-12315-detail-header-control-height);
    gap: 6px;
    padding: 6px 10px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.42);
    background: rgba(255, 255, 255, 0.16);
    color: rgba(255, 255, 255, 0.98);
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
}

.case-12315-detail__updated-chip i {
    font-size: 11px;
    opacity: 0.95;
}

.case-12315-detail__updated-chip.is-empty {
    opacity: 0.78;
}

.case-12315-detail__manual-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    min-height: var(--case-12315-detail-header-control-height);
    height: var(--case-12315-detail-header-control-height);
    gap: 6px;
    padding: 6px 10px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.42);
    background: rgba(255, 255, 255, 0.9);
    color: #1E2329;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.case-12315-detail__manual-chip i {
    font-size: 11px;
}

.case-12315-detail__actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.case-12315-detail__refresh-wrap {
    position: relative;
    display: inline-flex;
    align-items: stretch;
}

.case-12315-detail__refresh-mascot {
    display: none;
    position: absolute;
    top: -20px;
    right: -14px;
    width: 40px;
    height: 40px;
    z-index: 8;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    filter: none;
}

.case-12315-detail__refresh-mascot img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    user-select: none;
    -webkit-user-drag: none;
    pointer-events: none;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    transform: translateZ(0);
    backface-visibility: hidden;
}

.case-12315-detail-modal.is-refreshing .case-12315-detail__refresh-mascot {
    display: inline-flex;
    animation: case12315RefreshMascotPulse 1.3s ease-in-out infinite;
}

@keyframes case12315RefreshMascotPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.92; }
}

.case-12315-detail__recon-btn {
    height: 34px;
    padding: 0 12px;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 800;
    border: 1px solid rgba(17, 24, 39, 0.25);
    background: rgba(255, 255, 255, 0.92);
    color: #111827;
    cursor: pointer;
    transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease;
}

.case-12315-detail__recon-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
}

.case-12315-detail__recon-btn--danger {
    border-color: rgba(246, 70, 93, 0.45);
    background: rgba(246, 70, 93, 0.08);
    color: rgba(246, 70, 93, 1);
}

.case-12315-detail__refresh-btn {
    background: #FFFFFF;
    border: none;
    color: #1E2329;
    box-sizing: border-box;
    min-height: var(--case-12315-detail-header-control-height);
    height: var(--case-12315-detail-header-control-height);
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    line-height: 1;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
}

.case-12315-detail__refresh-main {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    line-height: 1;
}

.case-12315-detail__refresh-logo {
    width: 14px;
    height: 14px;
    object-fit: contain;
    display: none;
}

.case-12315-detail__refresh-btn.is-loading .case-12315-detail__refresh-logo {
    display: inline-block;
    animation: pulse 1.2s ease-in-out infinite;
}

.case-12315-detail__refresh-btn.is-loading {
    cursor: wait;
    opacity: 0.92;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    min-width: 116px;
    height: auto;
    min-height: 42px;
    padding: 6px 12px 7px;
}

.case-12315-detail__refresh-progress-track {
    display: none;
    width: 100%;
    height: 3px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--text-primary, #1E2329) 16%, transparent);
    overflow: hidden;
}

.case-12315-detail__refresh-progress {
    display: block;
    width: var(--case-12315-refresh-progress, 0%);
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, #F0B90B 0%, #F59E0B 100%);
    transition: width 0.24s linear;
    pointer-events: none;
}

.case-12315-detail__refresh-btn.is-loading .case-12315-detail__refresh-progress-track {
    display: block;
}

.case-12315-detail__refresh-btn:hover {
    filter: brightness(0.98);
}

.case-12315-detail__close {
    color: #FFFFFF;
}

.case-12315-detail__meta {
    margin: 6px 0 0;
    color: rgba(255, 255, 255, 0.9);
    font-size: 12px;
}

.case-12315-detail__body {
    padding: 16px 20px;
    background: #F9FAFB;
    overflow-y: auto;
    flex: 1;
    position: relative;
    border-radius: 0 0 12px 12px;
}

.case-12315-detail__refresh-overlay {
    position: absolute;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(249, 250, 251, 0.78);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 7;
    pointer-events: auto;
}

.case-12315-detail-modal.is-refreshing .case-12315-detail__refresh-overlay {
    display: flex;
}

.case-12315-detail__refresh-overlay-card {
    min-width: min(320px, 88%);
    max-width: 420px;
    border-radius: 18px;
    border: 1px solid rgba(240, 185, 11, 0.28);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.14);
    padding: 22px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    text-align: center;
}

.case-12315-detail__refresh-overlay-logo {
    width: 56px;
    height: 56px;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(240, 185, 11, 0.16) 0%, rgba(245, 158, 11, 0.26) 100%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    animation: case12315RefreshMascotPulse 1.2s ease-in-out infinite;
}

.case-12315-detail__refresh-overlay-logo img {
    width: 36px;
    height: 36px;
    object-fit: contain;
}

.case-12315-detail__refresh-overlay-title {
    color: #111827;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.case-12315-detail__refresh-overlay-hint {
    color: #6B7280;
    font-size: 13px;
    line-height: 1.6;
    max-width: 280px;
}

.case-12315-detail__section {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    border-radius: 8px;
    margin-bottom: 16px;
    padding: 16px;
    transition: border-color var(--transition-fast, 150ms ease), box-shadow var(--transition-fast, 150ms ease);
}

.case-12315-detail__section:hover,
.case-12315-detail__section:focus-within {
    border-color: var(--detail-card-hover-border, var(--color-primary, #F0B90B));
    box-shadow: var(--detail-card-hover-shadow, 0 0 0 1px rgba(240, 185, 11, 0.28), 0 8px 18px rgba(240, 185, 11, 0.18));
}

.case-12315-detail__section-title {
    margin: 0 0 12px 0;
    color: var(--text-primary, #374151);
    font-size: 14px;
    font-weight: 600;
}

.case-12315-detail__section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.case-12315-detail__section--with-actions .case-12315-detail__section-title {
    margin-bottom: 0;
}

.case-12315-detail__section-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.case-12315-detail__close-meta {
    margin-top: 12px;
}

.case-12315-detail__close-attachments {
    margin-top: 10px;
}

.case-12315-detail__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

.case-12315-detail__field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.case-12315-detail__label {
    color: #9CA3AF;
    font-size: 12px;
}

.case-12315-detail__value {
    color: var(--text-primary, #111827);
    font-size: 14px;
    word-break: break-all;
}

.case-12315-detail__value--rich {
    word-break: normal;
}

.case-12315-detail__value--rich .case-12315-notice-line {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin: 0 0 4px;
}

.case-12315-detail__value--rich .case-12315-notice-line:last-child {
    margin-bottom: 0;
}

.case-12315-detail__value--rich .case-12315-notice-main {
    white-space: nowrap;
}

.case-12315-detail__value--rich .case-12315-notice-tag {
    display: inline-flex;
    align-items: center;
    padding: 0 6px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.4;
    border: 1px solid transparent;
}

.case-12315-detail__value--rich .case-12315-notice-tag--ontime {
    color: #047857;
    background: rgba(16, 185, 129, 0.12);
    border-color: rgba(16, 185, 129, 0.3);
}

.case-12315-detail__value--rich .case-12315-notice-tag--overdue {
    color: #B91C1C;
    background: rgba(239, 68, 68, 0.12);
    border-color: rgba(239, 68, 68, 0.3);
}

.case-12315-detail__value--rich .case-12315-notice-tag--manual {
    color: #1D4ED8;
    background: rgba(59, 130, 246, 0.12);
    border-color: rgba(59, 130, 246, 0.3);
}

.case-12315-detail__value--file {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.case-12315-detail__file-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    min-width: 0;
}

.case-12315-detail__file-name {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 600;
}

.case-12315-detail__file-open.app-action-btn {
    flex-shrink: 0;
    min-width: 60px;
}

.case-12315-detail__file-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.case-12315-detail__file-delete.app-action-btn,
.case-12315-detail__clear-close.app-action-btn {
    flex-shrink: 0;
    min-width: 60px;
}

.case-12315-detail__file-path {
    font-size: 12px;
    color: var(--text-secondary, #6B7280);
    word-break: break-all;
}

.case-12315-detail__text {
    color: #374151;
    font-size: 14px;
    line-height: 1.6;
    white-space: pre-wrap;
}

.case-12315-detail__attachments {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 10px;
}

.case-12315-detail__workspace {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border: 1px solid #E5E7EB;
    border-radius: 8px;
    background: #F9FAFB;
}

.case-12315-detail__workspace-label {
    font-size: 12px;
    font-weight: 700;
    color: #6B7280;
    flex-shrink: 0;
}

.case-12315-detail__workspace-path {
    flex: 1;
    min-width: 0;
    font-size: 12px;
    color: #111827;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.case-12315-detail__workspace.is-unset .case-12315-detail__workspace-path {
    color: #9CA3AF;
}

.case-12315-detail__workspace-open:not(.app-action-btn):not(.btn) {
    border: 1px solid #F0B90B;
    background: #FFFFFF;
    color: #A16207;
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    flex-shrink: 0;
}

.case-12315-detail__workspace-open:not(.app-action-btn):not(.btn):hover:not(:disabled) {
    background: #FFFBEB;
}

.case-12315-detail__workspace-open:not(.app-action-btn):not(.btn):disabled {
    border-color: #E5E7EB;
    color: #9CA3AF;
    cursor: not-allowed;
    background: #F9FAFB;
}

.case-12315-detail-modal .case-12315-detail__workspace-open {
    border-color: var(--color-primary, #F0B90B);
    background: var(--color-primary, #F0B90B);
    color: var(--text-primary, #1E2329);
}

.case-12315-detail-modal .case-12315-detail__workspace-open:hover:not(:disabled) {
    border-color: var(--color-primary-hover, #D9A60A);
    background: var(--color-primary-hover, #D9A60A);
}

.case-12315-detail-modal .case-12315-detail__workspace-open:disabled {
    border-color: #E5E7EB;
    color: #9CA3AF;
    cursor: not-allowed;
    background: #F9FAFB;
}

.case-12315-detail__workspace-open.app-action-btn.app-action-btn--quick-open {
    border-color: var(--color-primary, #F0B90B);
    background: var(--color-primary, #F0B90B);
    color: var(--text-primary, #1E2329);
}

.case-12315-detail__workspace-open.app-action-btn.app-action-btn--quick-open:hover:not(:disabled) {
    border-color: var(--color-primary-hover, #D9A60A);
    background: var(--color-primary-hover, #D9A60A);
}

.case-12315-detail__workspace-open.btn {
    flex-shrink: 0;
}

.case-12315-detail__empty {
    color: #9CA3AF;
    font-size: 13px;
}

.case-12315-attachment {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid #FDE68A;
    background: #FFFBEB;
    border-radius: 8px;
}

.case-12315-attachment__info {
    min-width: 0;
}

.case-12315-attachment__name {
    color: #92400E;
    font-size: 13px;
    font-weight: 600;
    word-break: break-all;
}

.case-12315-attachment__meta {
    color: #B45309;
    font-size: 11px;
    margin-top: 2px;
}

.case-12315-attachment__actions {
    margin-left: auto;
    display: flex;
    gap: 6px;
}

.case-12315-attachment__btn {
    border: none;
    border-radius: 6px;
    padding: 0 10px;
    min-height: 28px;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    color: #FFFFFF;
}

.case-12315-attachment__btn--preview {
    background: #F59E0B;
}

[data-theme="dark"] .case-12315-detail__status-chip {
    background: rgba(11, 14, 17, 0.36);
    color: var(--text-primary, #EAECEF);
}

[data-theme="dark"] .case-12315-detail__manual-chip {
    background: rgba(11, 14, 17, 0.28);
    border-color: rgba(183, 189, 198, 0.22);
    color: var(--text-primary, #EAECEF);
}

[data-theme="dark"] .case-12315-detail__recon-btn,
[data-theme="dark"] .case-12315-detail__refresh-btn {
    background: var(--bg-card-secondary, #252A31);
    border-color: var(--border-color, #2B3139);
    color: var(--text-primary, #EAECEF);
}

[data-theme="dark"] .case-12315-detail__body {
    background: var(--bg-secondary, #1E2329);
}

[data-theme="dark"] .case-12315-detail__refresh-overlay {
    background: rgba(17, 24, 39, 0.76);
}

[data-theme="dark"] .case-12315-detail__refresh-overlay-card {
    border-color: rgba(240, 185, 11, 0.24);
    background: rgba(17, 24, 39, 0.94);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.32);
}

[data-theme="dark"] .case-12315-detail__refresh-overlay-title {
    color: #F9FAFB;
}

[data-theme="dark"] .case-12315-detail__refresh-overlay-hint {
    color: rgba(229, 231, 235, 0.84);
}

[data-theme="dark"] .case-12315-detail__section,
[data-theme="dark"] .case-12315-manual-notice__image-item {
    background: var(--bg-card, #1E2329);
    border-color: var(--border-color, #2B3139);
}

[data-theme="dark"] .case-12315-detail__label,
[data-theme="dark"] .case-12315-detail__empty,
[data-theme="dark"] .case-12315-manual-notice__images-empty {
    color: var(--text-tertiary, #848E9C);
}

[data-theme="dark"] .case-12315-detail__value,
[data-theme="dark"] .case-12315-detail__text,
[data-theme="dark"] .case-12315-detail__workspace-path,
[data-theme="dark"] .case-12315-manual-notice__choice-text,
[data-theme="dark"] .case-12315-manual-notice__type-text {
    color: var(--text-primary, #EAECEF);
}

[data-theme="dark"] .case-12315-detail__file-path,
[data-theme="dark"] .case-12315-detail__workspace-label,
[data-theme="dark"] .case-12315-manual-notice__images-toolbar small,
[data-theme="dark"] .case-12315-manual-notice__image-name {
    color: var(--text-secondary, #B7BDC6);
}

[data-theme="dark"] .case-12315-detail__workspace {
    background: var(--bg-card-secondary, #252A31);
    border-color: var(--border-color, #2B3139);
}

[data-theme="dark"] .case-12315-detail__workspace-open:not(.app-action-btn):not(.btn) {
    background: var(--bg-card, #1E2329);
    color: var(--color-warning-text, #FBBF24);
    border-color: var(--color-primary, #F0B90B);
}

[data-theme="dark"] .case-12315-detail__workspace-open:not(.app-action-btn):not(.btn):hover:not(:disabled) {
    background: rgba(240, 185, 11, 0.12);
}

[data-theme="dark"] .case-12315-detail__workspace-open:not(.app-action-btn):not(.btn):disabled,
[data-theme="dark"] .case-12315-detail-modal .case-12315-detail__workspace-open:disabled {
    background: var(--bg-card-secondary, #252A31);
    border-color: var(--border-color, #2B3139);
    color: var(--text-tertiary, #848E9C);
}

[data-theme="dark"] .case-12315-attachment {
    background: rgba(240, 185, 11, 0.12);
    border-color: rgba(240, 185, 11, 0.22);
}

[data-theme="dark"] .case-12315-attachment__name {
    color: #F3C74B;
}

[data-theme="dark"] .case-12315-attachment__meta {
    color: var(--text-secondary, #B7BDC6);
}

[data-theme="dark"] .case-12315-manual-notice__choice-text::before,
[data-theme="dark"] .case-12315-manual-notice__type-text::before {
    background: var(--bg-card-secondary, #252A31);
    border-color: var(--border-hover, #3C4451);
}

[data-theme="dark"] .case-12315-manual-notice__images-list {
    background: var(--bg-card-secondary, #252A31);
    border-color: var(--border-color, #2B3139);
}

[data-theme="dark"] .case-12315-manual-notice__footer {
    border-top-color: var(--border-color, #2B3139);
}

.case-12315-attachment__btn--preview:hover {
    background: #D97706;
}

.case-12315-attachment__btn--download {
    background: #0ECB81;
}

.case-12315-attachment__btn--download:hover {
    background: #059669;
}

.case-12315-attachment__btn--danger {
    background: #F6465D;
    border-color: #F6465D;
    color: #FFFFFF;
    opacity: 1;
}

.case-12315-attachment__btn--danger:hover {
    background: #DC3545;
    border-color: #DC3545;
}

.case-12315-attachment__btn--danger:disabled {
    background: #F6465D;
    border-color: #F6465D;
    color: #FFFFFF;
    opacity: 1;
}

@media (max-width: 768px) {
    .case-12315-detail__header-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .case-12315-detail__title {
        width: 100%;
    }

    .case-12315-detail__updated-chip {
        max-width: 100%;
    }

    .case-12315-detail__actions {
        width: 100%;
        justify-content: flex-end;
    }

    .case-12315-detail__grid {
        grid-template-columns: 1fr;
    }

    .case-12315-detail__workspace {
        flex-wrap: wrap;
    }

    .case-12315-detail__workspace-path {
        flex-basis: 100%;
        order: 3;
    }
}

/* Theme overrides for 12315 detail modal */
.case-12315-detail__container {
    background: var(--bg-card, var(--bg-primary, #FFFFFF));
    border: 1px solid var(--border-color, #E5E7EB);
    box-shadow: var(--shadow-xl, 0 18px 44px rgba(15, 23, 42, 0.22));
}

.case-12315-detail__header {
    color: var(--text-on-primary, #FFFFFF);
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.case-12315-detail__header--complaint {
    background: linear-gradient(135deg, var(--success-color, #0ECB81) 0%, var(--success-hover, #16B87A) 100%);
}

.case-12315-detail__header--report {
    background: linear-gradient(135deg, var(--color-primary, #F0B90B) 0%, var(--color-primary-hover, #D9A60A) 100%);
}

.case-12315-detail__title h3,
.case-12315-detail__close {
    color: inherit;
}

.case-12315-detail__status-chip,
.case-12315-detail__manual-chip,
.case-12315-detail__refresh-btn,
.case-12315-detail__recon-btn {
    background: color-mix(in srgb, var(--bg-card, #FFFFFF) 90%, transparent);
    color: var(--text-primary, #1E2329);
}

.case-12315-detail__status-chip,
.case-12315-detail__manual-chip,
.case-12315-detail__refresh-btn {
    border: 1px solid rgba(255, 255, 255, 0.28);
}

.case-12315-detail__recon-btn {
    border-color: color-mix(in srgb, var(--border-color, #E5E7EB) 72%, rgba(17, 24, 39, 0.28));
}

.case-12315-detail__recon-btn:hover {
    box-shadow: var(--shadow-md, 0 10px 22px rgba(15, 23, 42, 0.18));
}

.case-12315-detail__recon-btn--danger {
    background: var(--color-danger, #F6465D);
    border-color: var(--color-danger, #F6465D);
    color: #FFFFFF;
}

.case-12315-detail__recon-btn--danger:hover {
    background: var(--color-danger-hover, #D63A52);
    border-color: var(--color-danger-hover, #D63A52);
    color: #FFFFFF;
}

.case-12315-detail__body {
    background: var(--bg-secondary, #F9FAFB);
}

.case-12315-detail__section {
    background: var(--bg-card, #FFFFFF);
    border-color: var(--border-color, #E5E7EB);
}

.case-12315-detail__section-title,
.case-12315-detail__value,
.case-12315-detail__text,
.case-12315-detail__workspace-path,
.case-12315-attachment__name {
    color: var(--text-primary, #374151);
}

.case-12315-detail__label,
.case-12315-detail__file-path,
.case-12315-detail__workspace-label,
.case-12315-attachment__meta {
    color: var(--text-secondary, #6B7280);
}

.case-12315-detail__text {
    padding: 12px 14px;
    border-radius: 10px;
    background: var(--bg-secondary, #F9FAFB);
    border: 1px solid var(--border-color, #E5E7EB);
}

.case-12315-detail__workspace {
    border-color: var(--border-color, #E5E7EB);
    background: var(--bg-secondary, #F9FAFB);
}

.case-12315-detail__workspace.is-unset .case-12315-detail__workspace-path,
.case-12315-detail__empty {
    color: var(--text-tertiary, #9CA3AF);
}

.case-12315-detail__workspace-open:not(.app-action-btn):not(.btn) {
    border-color: var(--color-primary, #F0B90B);
    background: var(--bg-card, #FFFFFF);
    color: var(--color-primary-text, #A16207);
}

.case-12315-detail__workspace-open:not(.app-action-btn):not(.btn):hover:not(:disabled) {
    background: color-mix(in srgb, var(--color-primary, #F0B90B) 12%, var(--bg-card, #FFFFFF));
}

.case-12315-detail__workspace-open:not(.app-action-btn):not(.btn):disabled,
.case-12315-detail-modal .case-12315-detail__workspace-open:disabled {
    border-color: var(--border-color, #E5E7EB);
    color: var(--text-tertiary, #9CA3AF);
    background: var(--bg-secondary, #F9FAFB);
}

.case-12315-attachment {
    border-color: color-mix(in srgb, var(--color-primary, #F0B90B) 36%, var(--border-color, #E5E7EB));
    background: color-mix(in srgb, var(--color-primary, #F0B90B) 10%, var(--bg-card, #FFFFFF));
}

.case-12315-attachment__btn {
    color: var(--text-on-primary, #FFFFFF);
}

/* 12315 close-case modal: keep file inputs and upload buttons the same height */
#generic-modal #case12315-close-settlement-file,
#generic-modal #case12315-close-withdrawal-file,
#generic-modal #case12315-detail-settlement-file,
#generic-modal #case12315-detail-withdrawal-file {
    height: 44px;
    min-height: 44px;
}

#generic-modal [data-12315-action="pick-close-file"],
#generic-modal [data-12315-detail-action="pick-close-file"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 44px;
    min-height: 44px;
    padding-top: 0;
    padding-bottom: 0;
    line-height: 1;
    white-space: nowrap;
}

