/* AWS Medical Transcribe Style UI Components */

/* Medora Action Buttons Container - Clean Top Layout */
.aws-action-buttons {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
    padding: 20px 0;
    border-bottom: 2px solid #00BFFF;
    margin-bottom: 20px;
    background: linear-gradient(135deg, #fafcff 0%, #f0f9ff 100%);
    border-radius: 8px 8px 0 0;
}

/* Medora Primary Button Style - Neon Blue Theme */
.medora-primary-btn, .aws-primary-btn {
    background: linear-gradient(135deg, #00BFFF 0%, #0080FF 100%);
    color: white;
    border: none;
    border-radius: 6px;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 500;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    cursor: pointer;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    box-shadow: 0 1px 4px rgba(0, 191, 255, 0.2);
    text-shadow: none;
}

.medora-primary-btn:hover, .aws-primary-btn:hover {
    background: linear-gradient(135deg, #0080FF 0%, #0066CC 100%);
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(0, 191, 255, 0.3);
}

.medora-primary-btn:active, .aws-primary-btn:active {
    background: linear-gradient(135deg, #0066CC 0%, #004499 100%);
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(0, 191, 255, 0.3);
}

.medora-primary-btn:disabled, .aws-primary-btn:disabled {
    background: #f0f0f0;
    color: #999;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
    text-shadow: none;
}

/* Medora Secondary Button Style - Neon Blue Theme */
.medora-secondary-btn, .aws-secondary-btn {
    background: #ffffff;
    color: #00BFFF;
    border: 2px solid #00BFFF;
    border-radius: 8px;
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 500;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 44px;
    box-shadow: 0 2px 6px rgba(0, 191, 255, 0.2);
}

.medora-secondary-btn:hover, .aws-secondary-btn:hover {
    background: #f0f9ff;
    border-color: #0080FF;
    color: #0080FF;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(0, 191, 255, 0.3);
}

.medora-secondary-btn:active, .aws-secondary-btn:active {
    background: #e6f3ff;
    border-color: #0066CC;
    color: #0066CC;
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(0, 191, 255, 0.2);
}

.medora-secondary-btn:disabled, .aws-secondary-btn:disabled {
    background: #f9f9f9;
    color: #999;
    border-color: #e5e5e5;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* Button Icons */
.btn-icon {
    font-size: 16px;
    line-height: 1;
}

/* Medora Processing Indicator - Neon Blue Theme */
.medora-processing-indicator, .aws-processing-indicator {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    background: linear-gradient(135deg, #f0f9ff 0%, #e6f3ff 100%);
    border: 2px solid #00BFFF;
    border-radius: 8px;
    color: #0080FF;
    font-size: 14px;
    font-weight: 500;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    box-shadow: 0 2px 8px rgba(0, 191, 255, 0.2);
    animation: medora-glow 2s ease-in-out infinite alternate;
}

@keyframes medora-glow {
    from {
        box-shadow: 0 2px 8px rgba(0, 191, 255, 0.2);
    }
    to {
        box-shadow: 0 4px 12px rgba(0, 191, 255, 0.4);
    }
}

.spinner-icon {
    animation: aws-spin 1s linear infinite;
}

@keyframes aws-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* AWS-style status indicators */
.aws-status-success {
    color: #16794d;
    background: #d4edda;
    border-color: #16794d;
}

.aws-status-error {
    color: #d13212;
    background: #f8d7da;
    border-color: #d13212;
}

.aws-status-warning {
    color: #8a6d3b;
    background: #fcf4e6;
    border-color: #8a6d3b;
}

/* Responsive design */
@media (max-width: 768px) {
    .aws-action-buttons {
        flex-direction: column;
        align-items: stretch;
    }
    
    .aws-primary-btn,
    .aws-secondary-btn {
        justify-content: center;
        width: 100%;
    }
    
    .aws-processing-indicator {
        justify-content: center;
        width: 100%;
    }
}

/* Clean AWS-style spacing */
.aws-section {
    padding: 20px 0;
    border-bottom: 1px solid #e9ecef;
}

.aws-section:last-child {
    border-bottom: none;
}

/* AWS Console-style headers */
.aws-section-header {
    color: #232f3e;
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 16px;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* Integration with existing styles */
.initial-hidden.show-on-visit .aws-primary-btn,
.initial-hidden.show-on-transcript .aws-secondary-btn {
    display: inline-flex;
}

/* Hide old action buttons container when AWS style is active */
.aws-action-buttons ~ .action-buttons {
    display: none;
}

/* Completely hide problematic streaming buttons to prevent system breaks */
.completely-hidden {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    position: absolute !important;
    left: -9999px !important;
    width: 0 !important;
    height: 0 !important;
    pointer-events: none !important;
}

/* Safety override - hide all unwanted buttons */
#start-listening-btn,
#pause-listening-btn,
#stop-listening-btn,
#soap-generation-btn {
    display: none !important;
}

/* Medical-grade styling for streaming buttons - clean and professional */
button[id*="streaming"],
button[id*="listening"],
button.btn-success,
button[style*="green"],
button[style*="#28a745"],
button[style*="#198754"],
.btn-success {
    background: #f8f9fa !important;
    border: 1px solid #dee2e6 !important;
    color: #495057 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
    border-radius: 4px !important;
    padding: 8px 16px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    transition: all 0.2s ease !important;
    min-height: auto !important;
}

button[id*="streaming"]:hover,
button[id*="listening"]:hover,
button.btn-success:hover,
.btn-success:hover {
    background: #e9ecef !important;
    border-color: #adb5bd !important;
    color: #212529 !important;
    transform: none !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

/* Keep the existing primary button styling for other buttons */
.medora-primary-btn {
    background: linear-gradient(135deg, #00BFFF 0%, #0080FF 100%) !important;
    border: 2px solid #00BFFF !important;
    color: white !important;
    box-shadow: 0 2px 8px rgba(0, 191, 255, 0.3) !important;
    transition: all 0.3s ease !important;
}

/* Clean, minimal status indicators - no boxes, just text */
.status-indicator.connected,
.status-indicator.streaming, 
.status-indicator.processing,
#medical-status.connected,
#medical-status.streaming,
[class*="connected"],
[class*="streaming"],
[style*="background-color: green"],
[style*="color: green"],
div[style*="green"] {
    background: transparent !important;
    color: #00BFFF !important;
    border: none !important;
    padding: 4px 8px !important;
    border-radius: 0 !important;
    font-weight: 500 !important;
    font-size: 12px !important;
    box-shadow: none !important;
}

/* Change green circle emoji to blue circle emoji */
.status-indicator.connected::before,
#medical-status.connected::before {
    content: "🔵" !important;
}

/* Override any inline green styles */
*[style*="color: green"],
*[style*="background: green"],
*[style*="background-color: green"],
*[style*="border-color: green"] {
    color: #00BFFF !important;
    background: rgba(0, 191, 255, 0.1) !important;
    background-color: rgba(0, 191, 255, 0.1) !important;
    border-color: #00BFFF !important;
}

/* Medical-grade button styling for streaming controls */
.medical-btn {
    background: #ffffff !important;
    border: 1px solid #ced4da !important;
    color: #495057 !important;
    padding: 8px 16px !important;
    border-radius: 4px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
}

.medical-btn:hover {
    background: #f8f9fa !important;
    border-color: #adb5bd !important;
    color: #212529 !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.medical-btn:active {
    background: #e9ecef !important;
    border-color: #6c757d !important;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1) !important;
}

/* Fixed Bottom Medical Controls Bar - Tablet/iPad optimized */
.medical-controls-fixed-bar {
    position: fixed !important;
    bottom: 20px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    display: flex !important;
    gap: 16px !important;
    padding: 12px 20px !important;
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
    z-index: 1000 !important;
    max-width: 90vw !important;
}

/* Primary Action Button - Green for Start/Resume, Red for Stop */
.medical-primary-action-btn {
    min-width: 160px !important;
    min-height: 48px !important; /* 48px > 44px minimum touch target */
    padding: 12px 20px !important;
    border: none !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    
    /* Start state - Green */
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    color: white !important;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3) !important;
}

/* Stop state - Red */
.medical-primary-action-btn[data-state="stop"] {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
    box-shadow: 0 2px 8px rgba(239, 68, 68, 0.3) !important;
}

/* Resume state - Green (same as start) */
.medical-primary-action-btn[data-state="resume"] {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3) !important;
}

.medical-primary-action-btn:hover {
    transform: translateY(-1px) !important;
}

.medical-primary-action-btn[data-state="stop"]:hover {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%) !important;
    box-shadow: 0 3px 10px rgba(239, 68, 68, 0.4) !important;
}

.medical-primary-action-btn:hover:not([data-state="stop"]) {
    background: linear-gradient(135deg, #059669 0%, #047857 100%) !important;
    box-shadow: 0 3px 10px rgba(16, 185, 129, 0.4) !important;
}

.medical-primary-action-btn:active {
    transform: translateY(0) !important;
}

/* End Visit Button - Neutral branded color */
.medical-end-visit-btn {
    min-width: 140px !important;
    min-height: 48px !important; /* 48px > 44px minimum touch target */
    padding: 12px 20px !important;
    border: 2px solid #1e40af !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    
    /* Neutral branded - Dark Blue border with Neon Blue text */
    background: #ffffff !important;
    color: #00BFFF !important;
    box-shadow: 0 2px 6px rgba(30, 64, 175, 0.2) !important;
}

.medical-end-visit-btn:hover:not(:disabled) {
    background: #f0f9ff !important;
    border-color: #00BFFF !important;
    color: #0080FF !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 3px 8px rgba(0, 191, 255, 0.3) !important;
}

.medical-end-visit-btn:active:not(:disabled) {
    background: #e6f3ff !important;
    transform: translateY(0) !important;
}

.medical-end-visit-btn:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
    background: #f9fafb !important;
    color: #9ca3af !important;
    border-color: #d1d5db !important;
    box-shadow: none !important;
}

/* End Visit Confirmation Modal */
.medical-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.5) !important;
    backdrop-filter: blur(4px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2000 !important;
}

.medical-modal {
    background: #ffffff !important;
    border-radius: 16px !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2) !important;
    max-width: 420px !important;
    width: 90vw !important;
    max-height: 90vh !important;
    overflow: hidden !important;
}

.medical-modal-header {
    padding: 20px 24px 0 24px !important;
    border-bottom: 1px solid #f3f4f6 !important;
    margin-bottom: 20px !important;
}

.medical-modal-header h3 {
    margin: 0 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #111827 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
}

.medical-modal-body {
    padding: 0 24px !important;
    margin-bottom: 24px !important;
}

.medical-modal-body p {
    margin: 0 0 12px 0 !important;
    font-size: 16px !important;
    color: #374151 !important;
    line-height: 1.5 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
}

.modal-warning {
    font-size: 14px !important;
    color: #7c2d12 !important;
    background: #fef3c7 !important;
    padding: 8px 12px !important;
    border-radius: 6px !important;
    border-left: 3px solid #f59e0b !important;
}

.medical-modal-actions {
    padding: 20px 24px !important;
    background: #f9fafb !important;
    display: flex !important;
    gap: 12px !important;
    justify-content: flex-end !important;
}

.medical-modal-cancel {
    min-height: 44px !important;
    padding: 10px 20px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    color: #374151 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.medical-modal-cancel:hover {
    background: #f9fafb !important;
    border-color: #9ca3af !important;
}

.medical-modal-confirm {
    min-height: 44px !important;
    padding: 10px 20px !important;
    border: none !important;
    border-radius: 8px !important;
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
    color: white !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 4px rgba(239, 68, 68, 0.2) !important;
}

.medical-modal-confirm:hover {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%) !important;
    box-shadow: 0 3px 6px rgba(239, 68, 68, 0.3) !important;
    transform: translateY(-1px) !important;
}

.medical-modal-confirm:active {
    transform: translateY(0) !important;
}

/* Responsive design for mobile */
@media (max-width: 768px) {
    .medical-controls-fixed-bar {
        bottom: 10px !important;
        left: 10px !important;
        right: 10px !important;
        transform: none !important;
        max-width: none !important;
        flex-direction: column !important;
    }
    
    .medical-primary-action-btn,
    .medical-end-visit-btn {
        min-width: 100% !important;
        justify-content: center !important;
    }
    
    .medical-modal-actions {
        flex-direction: column-reverse !important;
    }
    
    .medical-modal-cancel,
    .medical-modal-confirm {
        width: 100% !important;
    }
}