/* ============================================
   LAYOUT - Bố cục chính của trang
   Chức năng: Định nghĩa container, grid, flexbox layout
   ============================================ */

/* Main Container - tràn chiều ngang màn hình lớn, chỉ giữ padding hai bên */
.main-container {
  max-width: none;
  width: 100%;
  margin: 0 auto;
  padding: var(--spacing-lg) clamp(12px, 2.5vw, 40px);
  display: grid;
  grid-template-columns: minmax(320px, 420px) 1fr;
  gap: var(--spacing-lg);
  box-sizing: border-box;
  overflow-x: hidden;
}

/* Màn hình rất rộng: cột trái không giãn quá để form vẫn gọn */
@media (min-width: 1600px) {
  .main-container {
    grid-template-columns: minmax(360px, 440px) 1fr;
    padding-left: clamp(20px, 3vw, 56px);
    padding-right: clamp(20px, 3vw, 56px);
  }
}

/* Responsive: Chuyển sang 1 cột trên tablet/mobile */
@media (max-width: 1024px) {
  .main-container {
    grid-template-columns: 1fr;
    padding: var(--spacing-md) clamp(10px, 3vw, 24px);
  }
}

/* Sidebar - Thanh bên trái */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

/* Preview Area - Khu vực xem trước bên phải */
.preview-area {
  position: sticky;
  top: 0; /* Dịch toàn bộ cột xem trước lên ngang với khối \"Cài đặt cơ bản\" */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  align-self: start;
}

/* Header nhỏ trong cột xem trước (QR-ME + 2 nút) */
.qr-page-header {
  width: 100%;
}

.qr-page-header-inner {
  max-width: none;
  width: 100%;
  margin: 0 auto 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-md);
  padding: 6px 10px;
  box-sizing: border-box;
}

.qr-page-header-title {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-weight: 700;
  color: #b91c1c;
}

.qr-page-header-actions {
  display: flex;
  gap: var(--spacing-sm);
}

.qr-page-header-actions .btn {
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 13px;
  background: #ffffff;
  border: 1px solid #dc2626;
  color: #0b6ed7;
  box-shadow: 0 4px 10px rgba(220, 38, 38, 0.18);
}

.qr-page-header-actions .btn i {
  color: #0b6ed7;
}

.qr-page-header-actions .btn:hover {
  background: #fff5f5;
  border-color: #b91c1c;
  box-shadow: 0 6px 14px rgba(185, 28, 28, 0.24);
  transform: translateY(-1px);
}

.qr-header-btn-text {
  margin-left: 6px;
}

/* Card - Component card chứa nội dung */
.card {
  background: #ffffff;
  border-radius: 16px;
  padding: 20px 20px 18px;
  box-shadow: var(--shadow-lg);
  border: 1px solid #dc2626;
}

.sidebar .card + .card {
  margin-top: 16px;
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-sm);
  border-bottom: 2px solid #f0f6ff;
}

.card-title {
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: #0b2540;
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .main-container {
    padding: var(--spacing-md);
  }
  
  .preview-area {
    position: static;
  }
}



