/* ============================================
   Drone Dashboard - Modal Styles
   ============================================ */

/* Large Modal */
.modal.modal-large { max-width: 800px; }
.modal.modal-xlarge { max-width: 1000px; }
.modal.modal-fullscreen { max-width: 95vw; max-height: 95vh; width: 95vw; height: 95vh; }

/* Confirmation Dialog */
.confirm-dialog .modal { max-width: 420px; }
.confirm-dialog .modal-body { text-align: center; padding: var(--space-lg); }
.confirm-dialog .confirm-icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-lg);
    font-size: 1.5rem;
}
.confirm-dialog .confirm-icon.warning { background: var(--warning-dim); color: var(--warning); }
.confirm-dialog .confirm-icon.danger { background: var(--error-dim); color: var(--error); }
.confirm-dialog .confirm-icon.info { background: var(--info-dim); color: var(--info); }
.confirm-dialog .confirm-title { font-size: var(--font-size-lg); font-weight: 600; margin-bottom: var(--space-sm); }
.confirm-dialog .confirm-text { color: var(--text-muted); font-size: var(--font-size-md); }

/* Embed Builder Modal */
.embed-modal .modal { max-width: 900px; }
.embed-modal .modal-body { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); padding: var(--space-md); }
.embed-modal .embed-form { display: flex; flex-direction: column; gap: var(--space-md); max-height: 60vh; overflow-y: auto; padding-right: var(--space-sm); }
.embed-modal .embed-preview-wrapper {
    position: sticky;
    top: 0;
    background: #36393f;
    border-radius: var(--radius-md);
    padding: var(--space-md);
    max-height: 60vh;
    overflow-y: auto;
}
.embed-form .field-row {
    display: flex;
    gap: var(--space-sm);
    align-items: flex-end;
}
.embed-form .field-row .form-group { flex: 1; margin-bottom: 0; }
.embed-form .add-field-btn {
    margin-top: var(--space-sm);
}
.embed-form .field-item {
    background: var(--bg-medium);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    position: relative;
}
.embed-form .field-item .remove-field {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 24px;
    height: 24px;
    border: none;
    background: var(--error-dim);
    color: var(--error);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 0.7rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.embed-form .field-item .remove-field:hover { background: var(--error); color: #fff; }

/* Case Detail Modal */
.case-detail-modal .modal { max-width: 700px; }
.case-detail-header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}
.case-detail-id {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--accent-primary);
    font-family: var(--font-mono);
}
.case-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}
.case-detail-field { }
.case-detail-field .field-label { font-size: var(--font-size-sm); color: var(--text-muted); margin-bottom: 2px; }
.case-detail-field .field-value { font-size: var(--font-size-md); }
.case-detail-reason {
    background: var(--bg-medium);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    margin-bottom: var(--space-lg);
}
.case-detail-reason .field-label { font-size: var(--font-size-sm); color: var(--text-muted); margin-bottom: var(--space-xs); }
.case-detail-reason .field-value { color: var(--text-secondary); font-size: var(--font-size-md); line-height: 1.5; }
.case-detail-notes { margin-top: var(--space-lg); }
.case-note {
    background: var(--bg-medium);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    margin-bottom: var(--space-sm);
}
.case-note-header { display: flex; justify-content: space-between; margin-bottom: var(--space-xs); }
.case-note-author { font-size: var(--font-size-sm); font-weight: 500; }
.case-note-time { font-size: var(--font-size-xs); color: var(--text-muted); }
.case-note-text { font-size: var(--font-size-md); color: var(--text-secondary); }

/* Ticket Viewer Modal */
.ticket-viewer-modal .modal { max-width: 800px; max-height: 85vh; }
.ticket-messages {
    max-height: 400px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding: var(--space-md);
    background: #36393f;
    border-radius: var(--radius-md);
}
.ticket-message {
    display: flex;
    gap: var(--space-sm);
    padding: var(--space-sm) 0;
}
.ticket-message-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    flex-shrink: 0;
    background: var(--bg-medium);
}
.ticket-message-content { flex: 1; }
.ticket-message-author { font-size: var(--font-size-md); font-weight: 600; margin-bottom: 2px; }
.ticket-message-author .timestamp { font-size: var(--font-size-xs); color: #72767d; font-weight: 400; margin-left: var(--space-sm); }
.ticket-message-text { font-size: var(--font-size-md); color: #dcddde; line-height: 1.4; }

/* Form Modal */
.form-modal .modal-body { max-height: 65vh; overflow-y: auto; }

/* Poll Results Modal */
.poll-results {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}
.poll-option-result {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}
.poll-option-label { width: 120px; font-size: var(--font-size-md); color: var(--text-secondary); flex-shrink: 0; }
.poll-option-bar { flex: 1; }
.poll-option-count { width: 60px; text-align: right; font-size: var(--font-size-md); color: var(--text-muted); flex-shrink: 0; }

/* Giveaway modal */
.giveaway-form-modal .form-group .form-hint { display: flex; align-items: center; gap: 4px; }
.giveaway-form-modal .winners-preview {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-sm);
}

/* Command Editor Modal */
.command-editor-modal .modal { max-width: 700px; }
.command-triggers {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-sm);
}
.response-type-selector {
    display: flex;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

@media (max-width: 768px) {
    .modal { width: 95%; max-width: 95% !important; }
    .modal.modal-large,
    .modal.modal-xlarge { max-width: 95% !important; }
    .embed-modal .modal-body { grid-template-columns: 1fr; }
    .case-detail-grid { grid-template-columns: 1fr; }
}

/* ============================================
   Mobile Modal Overrides
   ============================================ */
@media (max-width: 768px) {
    .modal-backdrop { align-items: flex-end; padding: 0; }
    .modal {
        width: 100% !important;
        max-width: 100% !important;
        max-height: 90vh;
        border-radius: 16px 16px 0 0;
        animation: slideUp 0.25s ease;
    }
    .modal.modal-large,
    .modal.modal-xlarge,
    .modal.modal-fullscreen {
        max-width: 100% !important;
        width: 100% !important;
        max-height: 95vh;
        height: 95vh;
    }
    .modal-header { padding: 14px 16px; }
    .modal-header h3 { font-size: 16px; }
    .modal-close { width: 36px; height: 36px; min-width: 36px; }
    .modal-body { padding: 12px 16px; max-height: 60vh; overflow-y: auto; -webkit-overflow-scrolling: touch; }
    .modal-footer { padding: 12px 16px; flex-wrap: wrap; gap: 8px; }
    .modal-footer .btn { flex: 1; min-width: 0; justify-content: center; }

    /* Embed modal - single column */
    .embed-modal .modal-body { grid-template-columns: 1fr; }
    .embed-modal .embed-preview-wrapper { max-height: 200px; }
    .embed-form .field-row { flex-direction: column; }

    /* Ticket viewer */
    .ticket-messages { max-height: 300px; }
    .ticket-message-avatar { width: 28px; height: 28px; }

    /* Case detail */
    .case-detail-grid { grid-template-columns: 1fr; }
    .case-detail-header { flex-wrap: wrap; }

    /* Confirm dialog */
    .confirm-dialog .modal { border-radius: 16px 16px 0 0; }
    .confirm-dialog .confirm-icon { width: 48px; height: 48px; font-size: 1.2rem; }
}

@keyframes slideUp {
    from { transform: translateY(100%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}
