/* ===================================================================
   CHART DATA MODAL - EXACT STORYDOC REPLICA
   Chart data editing interface matching StorydDoc design
   ================================================================== */

/* Chart Data Modal Container */
.chart-data-modal {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

.chart-data-modal .modal-dialog {
    max-width: 1200px !important;
    margin: 1.75rem auto !important;
}

/* Modal Header */
.chart-data-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 1rem 1.5rem !important;
    border-bottom: 1px solid #e5e7eb !important;
    background: #ffffff !important;
}

.chart-data-title-section {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.chart-data-title-section h5 {
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #1f2937 !important;
    margin: 0 !important;
}

.chart-data-title-section i {
    font-size: 18px !important;
    color: #6b7280 !important;
}

.chart-data-actions {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.chart-data-actions .btn {
    height: 32px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
}

.chart-data-actions .btn-primary {
    background: #7c3aed !important;
    border-color: #7c3aed !important;
    color: white !important;
}

.chart-data-actions .btn-outline-secondary {
    border-color: #d1d5db !important;
    color: #6b7280 !important;
}

/* Modal Body */
.chart-data-body {
    padding: 0 !important;
    background: #f8fafc !important;
}

.chart-editor-layout {
    display: flex !important;
    height: 600px !important;
}

/* Left Side - Chart Preview */
.chart-editor-left {
    width: 400px !important;
    background: #ffffff !important;
    border-right: 1px solid #e5e7eb !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 1.5rem !important;
}

.chart-type-selector {
    margin-bottom: 1.5rem !important;
}

.chart-type-selector .form-select {
    height: 40px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 6px !important;
    background: #ffffff !important;
    color: #1f2937 !important;
}

.chart-preview-container {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

.chart-preview {
    flex: 1 !important;
    background: #ffffff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    padding: 1rem !important;
    margin-bottom: 1rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.preview-chart-container {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.preview-chart {
    max-width: 100% !important;
    max-height: 100% !important;
}

.chart-settings {
    display: flex !important;
    justify-content: center !important;
}

.chart-settings .btn {
    height: 32px !important;
    font-size: 13px !important;
    padding: 0 12px !important;
}

/* Right Side - Data Table */
.chart-editor-right {
    flex: 1 !important;
    background: #ffffff !important;
    padding: 1.5rem !important;
    overflow-y: auto !important;
}

.data-table-container {
    width: 100% !important;
}

.data-edit-table {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    background: #ffffff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    overflow: hidden !important;
}

.data-edit-table thead th {
    background: #f8fafc !important;
    border-bottom: 1px solid #e5e7eb !important;
    padding: 12px 16px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #374151 !important;
    text-align: left !important;
}

.data-edit-table thead th:first-child {
    width: 120px !important;
}

.data-edit-table thead th.editable-header {
    color: #1f2937 !important;
    cursor: text !important;
    border: none !important;
    outline: none !important;
}

.data-edit-table thead th.editable-header:focus {
    background: #ffffff !important;
    box-shadow: inset 0 0 0 2px #7c3aed !important;
}

.data-edit-table tbody tr {
    border-bottom: 1px solid #f1f5f9 !important;
}

.data-edit-table tbody tr:last-child {
    border-bottom: none !important;
}

.data-edit-table tbody td {
    padding: 12px 16px !important;
    font-size: 14px !important;
    color: #1f2937 !important;
    border: none !important;
}

.year-cell {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.color-indicator {
    width: 12px !important;
    height: 12px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
}

.year-cell span[contenteditable] {
    color: #6b7280 !important;
    font-weight: 500 !important;
    border: none !important;
    outline: none !important;
    background: transparent !important;
    cursor: text !important;
}

.year-cell span[contenteditable]:focus {
    color: #1f2937 !important;
    background: #f8fafc !important;
    border-radius: 4px !important;
    padding: 2px 4px !important;
    margin: -2px -4px !important;
}

.value-cell {
    font-weight: 500 !important;
    cursor: text !important;
    border: none !important;
    outline: none !important;
    background: transparent !important;
    width: 100% !important;
}

.value-cell:focus {
    background: #f8fafc !important;
    border-radius: 4px !important;
    outline: 2px solid #7c3aed !important;
    outline-offset: -2px !important;
}

/* Modal Footer */
.chart-data-footer {
    padding: 1rem 1.5rem !important;
    border-top: 1px solid #e5e7eb !important;
    background: #ffffff !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.chart-data-footer .btn {
    height: 36px !important;
    padding: 0 16px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

.chart-data-footer .btn-secondary {
    background: #ffffff !important;
    border-color: #d1d5db !important;
    color: #6b7280 !important;
}

.chart-data-footer .btn-primary {
    background: #7c3aed !important;
    border-color: #7c3aed !important;
    color: white !important;
}

/* Responsive Design */
@media (max-width: 1024px) {
    .chart-data-modal .modal-dialog {
        max-width: 95% !important;
        margin: 1rem auto !important;
    }
    
    .chart-editor-layout {
        height: 500px !important;
    }
    
    .chart-editor-left {
        width: 350px !important;
        padding: 1rem !important;
    }
    
    .chart-editor-right {
        padding: 1rem !important;
    }
}

@media (max-width: 768px) {
    .chart-editor-layout {
        flex-direction: column !important;
        height: auto !important;
    }
    
    .chart-editor-left {
        width: 100% !important;
        border-right: none !important;
        border-bottom: 1px solid #e5e7eb !important;
        height: 300px !important;
    }
    
    .chart-editor-right {
        height: 400px !important;
    }
    
    .chart-data-header {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 1rem !important;
    }
    
    .chart-data-actions {
        width: 100% !important;
        justify-content: flex-end !important;
    }
}

/* Dark Mode Support */
[data-theme="dark"] .chart-data-modal {
    background: #1f2937 !important;
    color: #f9fafb !important;
}

[data-theme="dark"] .chart-data-header,
[data-theme="dark"] .chart-data-footer {
    background: #1f2937 !important;
    border-color: #374151 !important;
}

[data-theme="dark"] .chart-data-body {
    background: #111827 !important;
}

[data-theme="dark"] .chart-editor-left,
[data-theme="dark"] .chart-preview {
    background: #1f2937 !important;
    border-color: #374151 !important;
}

[data-theme="dark"] .chart-editor-right {
    background: #1f2937 !important;
}

[data-theme="dark"] .data-edit-table {
    background: #1f2937 !important;
    border-color: #374151 !important;
}

[data-theme="dark"] .data-edit-table thead th {
    background: #111827 !important;
    border-color: #374151 !important;
    color: #d1d5db !important;
}

[data-theme="dark"] .data-edit-table tbody td {
    color: #f9fafb !important;
}

[data-theme="dark"] .year-cell span[contenteditable] {
    color: #9ca3af !important;
}

[data-theme="dark"] .year-cell span[contenteditable]:focus {
    color: #f9fafb !important;
    background: #374151 !important;
}

[data-theme="dark"] .value-cell:focus {
    background: #374151 !important;
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
    .chart-data-modal * {
        transition: none !important;
        animation: none !important;
    }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
    .chart-data-modal .data-edit-table {
        border-width: 2px !important;
    }
    
    .value-cell:focus,
    .year-cell span[contenteditable]:focus {
        outline-width: 3px !important;
    }
}
