.report-button {opacity: 0.7}
.report-button:hover {opacity: 1}
.violation-modal-overlay {position: fixed;top: 0;left: 0;right: 0;bottom: 0;background: rgba(0, 0, 0, 0.45);display: flex;align-items: center;justify-content: center;z-index: 1000;padding: 16px;animation: violation-fade-in 0.15s ease}
@keyframes violation-fade-in {from { opacity: 0; }
to { opacity: 1; }}
.violation-modal-content {background: #fff;border-radius: 14px;width: 100%;max-width: 420px;max-height: 85vh;overflow-y: auto;box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);animation: violation-slide-up 0.2s ease}
@keyframes violation-slide-up {from { opacity: 0; transform: translateY(12px); }
to { opacity: 1; transform: translateY(0); }}
.violation-modal-header {display: flex;align-items: center;justify-content: space-between;padding: 14px 16px;border-bottom: 1px solid #f0f0f0}
.violation-modal-header h3 {display: flex;align-items: center;gap: 6px;margin: 0;font-size: 15px;font-weight: 600;color: #333}
.violation-modal-header h3 svg {color: #e53935;flex-shrink: 0}
.violation-close-button {display: flex;align-items: center;justify-content: center;width: 32px;height: 32px;border: none;border-radius: 50%;background: none;color: #999;cursor: pointer;transition: background 0.15s}
.violation-close-button:hover {background: #f5f5f5;color: #333}
.violation-modal-body {padding: 16px}
.violation-category-group {margin-bottom: 14px}
.violation-category-heading {font-size: 12px;font-weight: 600;color: #888;text-transform: uppercase;letter-spacing: 0.03em;margin: 0 0 8px 2px}
.violation-category-options {display: flex;flex-direction: column;gap: 6px}
.violation-category-option {display: flex;align-items: flex-start;gap: 10px;padding: 10px 12px;border: 1.5px solid #e8e8e8;border-radius: 10px;cursor: pointer;transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;user-select: none}
.violation-category-option:hover {border-color: #ef9a9a;background: #fef5f5}
.violation-category-option:has(input:checked) {border-color: #e53935;background: #fff5f5;box-shadow: 0 0 0 1px #e53935}
.violation-category-option.disabled {opacity: 0.45;cursor: not-allowed;pointer-events: none}
.violation-category-option.reported {background: #fafafa}
.violation-category-option input[type="radio"] {accent-color: #e53935;margin-top: 2px;flex-shrink: 0}
.violation-category-body {display: flex;flex-direction: column;gap: 2px;flex: 1;min-width: 0}
.violation-category-name {display: flex;align-items: center;gap: 6px;font-size: 13px;font-weight: 600;color: #333;line-height: 1.4}
.violation-category-desc {font-size: 11px;color: #999;line-height: 1.5}
.violation-already-reported {font-size: 10px;color: #e53935;background: #ffebee;padding: 1px 6px;border-radius: 3px;font-weight: 500;white-space: nowrap}
.violation-reason-group {margin-bottom: 14px}
.violation-form-label {display: block;font-size: 12px;font-weight: 600;color: #888;margin-bottom: 6px;margin-left: 2px}
.violation-reason-textarea {width: 100%;min-height: 72px;padding: 10px 12px;border: 1.5px solid #e8e8e8;border-radius: 10px;font-size: 13px;line-height: 1.5;resize: vertical;box-sizing: border-box;max-width: 100%;font-family: inherit;transition: border-color 0.15s}
.violation-reason-hint {font-size: 11px;color: #e53935;margin: 6px 0 0 2px}
.violation-reason-textarea:focus {outline: none;border-color: #e53935;box-shadow: 0 0 0 2px rgba(229, 57, 53, 0.08)}
.violation-form-actions {display: flex;gap: 8px}
.violation-cancel-button {flex: 1;padding: 10px 16px;border: 1.5px solid #e0e0e0;border-radius: 10px;background: #fff;color: #666;font-size: 13px;font-weight: 500;cursor: pointer;transition: background 0.15s}
.violation-cancel-button:hover {background: #f5f5f5}
.violation-submit-button {flex: 1;padding: 10px 16px;border: none;border-radius: 10px;background: #e53935;color: #fff;font-size: 13px;font-weight: 600;cursor: pointer;transition: background 0.15s}
.violation-submit-button:hover {background: #c62828}
.violation-notice-text {font-size: 11px;color: #bbb;line-height: 1.5;margin: 12px 0 0;text-align: center}
.violation-errors {background: #fff5f5;border: 1px solid #ffcdd2;border-radius: 8px;padding: 8px 12px;margin-bottom: 12px}
.violation-error-message {color: #d32f2f;font-size: 13px;margin: 4px 0}
.violation-success-message {display: flex;align-items: center;gap: 8px;padding: 12px 16px;background: #e8f5e9;border: 1px solid #c8e6c9;border-radius: 8px;color: #2e7d32;font-size: 14px;margin: 8px 0}
.violation-hidden-text {display: inline-flex;align-items: center;gap: 4px;color: #bbb;font-size: 12px;font-style: italic}
.violation-hidden-text svg {opacity: 0.6;flex-shrink: 0}
.violation-hidden-comment {display: flex;align-items: center;gap: 8px;padding: 12px 16px;background: #f5f5f5;border-radius: 8px;color: #bbb;font-size: 13px}
.violation-hidden-comment svg {opacity: 0.5;flex-shrink: 0}
.violation-hidden-comment p {margin: 0}
.violation-hidden-image {display: flex;flex-direction: column;align-items: center;justify-content: center;gap: 8px;background: #f0f0f0;color: #aaa;text-align: center;width: 100%;height: 100%}
.violation-hidden-image svg {opacity: 0.5}
.violation-hidden-image p {font-size: 12px;margin: 0}
.violation-owner-notice {padding: 12px 16px;background: #fff3e0;border: 1px solid #ffe0b2;border-radius: 8px;color: #e65100;font-size: 13px;margin: 8px 16px}
.violation-owner-notice-header {display: flex;align-items: center;gap: 8px;font-weight: 600}
.violation-owner-notice-list {margin: 8px 0 8px 24px;padding: 0;list-style: disc;font-size: 12px;color: #bf360c}
.violation-owner-notice-list li {margin: 4px 0;line-height: 1.6}
.violation-owner-notice-comment {display: block;margin-top: 6px;padding: 8px 10px;background: #fff8e1;border-left: 3px solid #ffb74d;border-radius: 4px}
.violation-owner-notice-comment-label {display: block;font-size: 10px;font-weight: 600;color: #f57c00;margin-bottom: 2px}
.violation-owner-notice-comment-text {font-size: 12px;color: #5d4037;line-height: 1.5}
@media (max-width: 390px) {.violation-modal-overlay {padding: 12px;align-items: flex-end}
.violation-modal-content {max-width: 100%;max-height: 88vh;border-radius: 14px 14px 0 0}
.violation-category-option {padding: 10px}}