/* ==========================================================================
   🌟 ส่วนรวม CSS สไตล์เดิมคุณเล้ง + อัปเดตโครงสร้าง Safe-Zone
   ========================================================================== */

/* [กฎข้อ 19 & ข้อ 9] ล็อกพฤติกรรมหน้าจอมือถือไม่ให้ปัดนิ้วเพื่อรีเฟรช และเซ็ตพื้นฐาน */
body {
  overscroll-behavior-y: none !important;
  font-family: 'Sarabun', sans-serif;
  font-size: 16px !important;
  background-color: #f4f7f6 !important;
  color: #333 !important;
}

/* การจัดระดับขนาดกล่องกรอกข้อมูลและความสูงสัมผัสปุ่มกดเพื่อรองรับอุปกรณ์พกพา */
.form-control, .form-select, .btn {
  min-height: 48px !important;
  border-radius: 10px !important;
  font-size: 16px !important;
}

.form-control, .form-select {
  border: 1px solid #dce1e6 !important;
  padding: 10px 15px !important;
  transition: all 0.2s ease !important;
}

.form-control:focus, .form-select:focus {
  border-color: #0d6efd !important;
  box-shadow: 0 0 0 4px rgba(13, 110, 253, 0.15) !important;
}

/* สไตล์ระดับพรีเมียมของแผง Card */
.card-shadow {
  border-radius: 16px !important;
  border: none !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04) !important;
  background: #ffffff !important;
  transition: box-shadow 0.3s ease !important;
}

.card-shadow:hover {
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.07) !important;
}

/* ปุ่มกดสไตล์ไล่เฉดสีมิติดั้งเดิม */
.btn {
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

.btn-primary {
  background: linear-gradient(135deg, #0d6efd, #0b5ed7) !important;
  border: none !important;
  box-shadow: 0 4px 12px rgba(13, 110, 253, 0.2) !important;
}

.btn-primary:hover:not(:disabled) {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 16px rgba(13, 110, 253, 0.3) !important;
  background: linear-gradient(135deg, #0b5ed7, #0a53be) !important;
}

.btn:disabled {
  opacity: 0.7 !important;
  cursor: not-allowed !important;
  transform: none !important;
}

/* แท็บเปลี่ยนหน้าสไตล์ Minimal และโมเดิร์น */
.nav-pills {
  gap: 8px !important;
  padding: 6px !important;
  background: #e9ecef !important;
  border-radius: 14px !important;
  display: inline-flex !important;
}

.nav-pills .nav-link {
  min-height: 44px !important;
  border-radius: 10px !important;
  font-weight: 500 !important;
  color: #495057 !important;
  padding: 8px 20px !important;
  transition: all 0.3s ease !important;
}

.nav-pills .nav-link.active {
  background-color: #ffffff !important;
  color: #0d6efd !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important;
}

/* สไตล์รายละเอียดอื่นๆ คงเดิม */
.pre-wrap { 
  white-space: pre-wrap; 
  word-break: break-word; 
}

.img-preview { 
  max-height: 100px; 
  margin: 5px;
  border-radius: 8px; 
  border: 2px solid #dee2e6; 
}

.card-detail { 
  transition: transform 0.2s; 
  border-left: 5px solid #0d6efd;
}

.card-detail:hover { 
  transform: translateY(-3px); 
}

.alert {
  border-radius: 12px !important;
  border: none !important;
}

#inline-msg { 
  display: none; 
  margin-bottom: 20px;
}

/* 🚩 [กฎข้อ 18] ล็อกขีดจำกัดสูงสุดการแสดงผลช่อง Textarea ซ่อนแถบเลื่อนเมื่อไม่จำเป็น */
textarea { 
  max-height: 200px !important;
  overflow-y: auto !important;
  resize: none !important;
}

/* ✨ [กฎข้อ 26] Skeleton Loader Shimmer Box ระหว่างรอดึงข้อมูล */
.skeleton-card {
  height: 180px;
  background: linear-gradient(90deg, #f2f4f5 25%, #e1e4e6 50%, #f2f4f5 75%);
  background-size: 200% 100%;
  animation: shimmerEffect 1.5s infinite ease-in-out;
  border-radius: 14px;
  margin-bottom: 20px;
}

@keyframes shimmerEffect {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}