/* v0.1.16 Production Optimized CSS - Complementary to TailwindCSS */
/* High-performance, minified CSS for production environment */

/* Reset and Base Styles */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:"Hiragino Kaku Gothic ProN","ヒラギノ角ゴ ProN W3","Meiryo","メイリオ",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Noto Sans",sans-serif}

/* Enhanced Loading Spinner */
.loading-spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* Medical Form Components */
.medical-input{width:100%;padding:0.75rem 1rem;border:2px solid #d1d5db;border-radius:0.5rem;font-size:1rem;line-height:1.6;transition:all 0.2s ease;background-color:#fff}
.medical-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,0.5)}
.medical-input:invalid{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,0.3)}

/* Enhanced Button System */
.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:500;padding:0.75rem 1.5rem;border-radius:0.5rem;text-decoration:none;transition:all 0.2s ease;cursor:pointer;border:none;font-size:0.875rem;line-height:1.25rem}
.btn:disabled{opacity:0.5;cursor:not-allowed}

.btn-primary{background-color:#2563eb;color:#fff;box-shadow:0 4px 6px -1px rgba(0,0,0,0.1)}
.btn-primary:hover:not(:disabled){background-color:#1d4ed8;box-shadow:0 10px 15px -3px rgba(0,0,0,0.1)}
.btn-primary:focus{box-shadow:0 0 0 3px rgba(59,130,246,0.5)}

.btn-secondary{background-color:#e5e7eb;color:#1f2937;box-shadow:0 1px 2px 0 rgba(0,0,0,0.05)}
.btn-secondary:hover:not(:disabled){background-color:#d1d5db}

.btn-success{background-color:#15803d;color:#fff;box-shadow:0 4px 6px -1px rgba(0,0,0,0.1)}
.btn-success:hover:not(:disabled){background-color:#166534}

.btn-warning{background-color:#c2410c;color:#fff;box-shadow:0 4px 6px -1px rgba(0,0,0,0.1)}
.btn-warning:hover:not(:disabled){background-color:#9a3412}

.btn-danger{background-color:#b91c1c;color:#fff;box-shadow:0 4px 6px -1px rgba(0,0,0,0.1)}
.btn-danger:hover:not(:disabled){background-color:#991b1b}

/* Medical Card System */
.medical-card{background-color:#fff;border-radius:0.75rem;box-shadow:0 10px 15px -3px rgba(0,0,0,0.1);border:1px solid #e5e7eb;padding:1.5rem;transition:all 0.3s ease}
.medical-card:hover{box-shadow:0 20px 25px -5px rgba(0,0,0,0.1);transform:translateY(-2px)}

/* Priority Indicators */
.priority-emergency{background-color:#fef2f2;border-left:4px solid #dc2626;color:#991b1b;padding:1rem}
.priority-urgent{background-color:#fff7ed;border-left:4px solid #ea580c;color:#c2410c;padding:1rem}
.priority-routine{background-color:#eff6ff;border-left:4px solid #3b82f6;color:#1d4ed8;padding:1rem}

/* Status Indicators */
.status-active{display:inline-flex;align-items:center;padding:0.25rem 0.75rem;border-radius:9999px;background-color:#dcfce7;color:#166534;font-size:0.75rem;font-weight:500}
.status-inactive{display:inline-flex;align-items:center;padding:0.25rem 0.75rem;border-radius:9999px;background-color:#fee2e2;color:#991b1b;font-size:0.75rem;font-weight:500}
.status-pending{display:inline-flex;align-items:center;padding:0.25rem 0.75rem;border-radius:9999px;background-color:#fef3c7;color:#92400e;font-size:0.75rem;font-weight:500}

/* Form Validation Feedback */
.validation-error{color:#dc2626;font-size:0.875rem;margin-top:0.25rem}
.validation-success{color:#166534;font-size:0.875rem;margin-top:0.25rem}

/* Enhanced Table Styles */
.medical-table{width:100%;border-collapse:collapse;background-color:#fff;border-radius:0.5rem;overflow:hidden;box-shadow:0 1px 3px 0 rgba(0,0,0,0.1)}
.medical-table th{background-color:#f8fafc;padding:0.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}
.medical-table td{padding:0.75rem 1rem;border-bottom:1px solid #f3f4f6}
.medical-table tr:hover{background-color:#f8fafc}

/* Responsive Utilities */
@media (max-width:640px){
  .btn{padding:0.5rem 1rem;font-size:0.75rem}
  .medical-card{padding:1rem}
  .medical-input{padding:0.5rem 0.75rem}
  .responsive-text-sm{font-size:0.75rem;line-height:1.4}
  .responsive-text-base{font-size:0.875rem;line-height:1.5}
  .responsive-text-lg{font-size:1rem;line-height:1.6}
}

/* Performance Optimizations */
.gpu-accelerated{transform:translateZ(0);will-change:transform}
.smooth-scroll{scroll-behavior:smooth}

/* Accessibility Enhancements */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.focus-visible:focus{outline:2px solid #3b82f6;outline-offset:2px}

/* Print Styles */
@media print{
  .no-print{display:none!important}
  .medical-card{box-shadow:none;border:1px solid #d1d5db}
  .btn{background-color:#f3f4f6!important;color:#374151!important}
}