/* Estilos específicos para componentes do tema */

/* === HOME === */
.home-container {
  padding: var(--spacing-xl, 32px) var(--spacing-lg, 24px);
}

/* === DESTAQUES === */
.destaques-section {
  margin-bottom: var(--spacing-2xl, 48px);
}

.destaques-swiper {
  padding-bottom: var(--spacing-xl, 32px);
}

.destaque-card {
  transition: all var(--transition-base, 0.3s ease);
}

.destaque-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl, 0 16px 48px rgba(0, 0, 0, 0.15)) !important;
}

.card-image-wrapper {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.card-image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-base, 0.3s ease);
}

.destaque-card:hover .card-image-wrapper img {
  transform: scale(1.1);
}

.badge-destaque {
  position: absolute;
  top: var(--spacing-sm, 8px);
  right: var(--spacing-sm, 8px);
  background: linear-gradient(135deg, var(--danger, #dc3545), #c82333);
  color: var(--white, #ffffff);
  padding: var(--spacing-xs, 4px) var(--spacing-sm, 8px);
  border-radius: var(--radius-full, 9999px);
  font-size: var(--font-size-xs, 0.75rem);
  font-weight: 700;
  box-shadow: var(--shadow-md, 0 4px 12px rgba(0, 0, 0, 0.15));
  z-index: 10;
}

.preco-destaque {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs, 4px);
  align-items: center;
}

.preco-original-small {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--text-secondary, #6c757d);
}

.preco-original-small strike {
  color: var(--gray-500, #adb5bd);
}

.preco-desconto-small {
  font-size: var(--font-size-xl, 1.25rem);
  font-weight: 700;
  color: var(--success, #198754);
}

.preco-normal-small {
  font-size: var(--font-size-xl, 1.25rem);
  font-weight: 700;
  color: var(--primary, #0d6efd);
}

@media (max-width: 768px) {
  .destaques-section {
    margin-bottom: var(--spacing-xl, 32px);
  }
  
  .card-image-wrapper {
    aspect-ratio: 4 / 3;
  }
  
  .preco-desconto-small,
  .preco-normal-small {
    font-size: var(--font-size-lg, 1.125rem);
  }
}

.section-title-wrapper {
  text-align: center;
  margin-bottom: var(--spacing-xl, 32px);
}

.section-title {
  font-size: var(--font-size-3xl, 1.875rem);
  font-weight: 700;
  color: var(--text-primary, #212529);
  margin-bottom: var(--spacing-sm, 8px);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm, 8px);
}

.section-title i {
  color: var(--primary, #0d6efd);
}

.section-subtitle {
  font-size: var(--font-size-lg, 1.125rem);
  color: var(--text-secondary, #6c757d);
  margin-bottom: 0;
}

.banner-link {
  display: block;
  transition: transform var(--transition-base, 0.3s ease);
}

.banner-link:hover {
  transform: scale(1.01);
}

/* === GRID DE PRODUTOS === */
.produtos-grid {
  padding: var(--spacing-xl, 32px) 0;
}

.produto-card {
  transition: all var(--transition-base, 0.3s ease);
  border: 1px solid var(--gray-200, #e9ecef);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.produto-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, 0.12));
}

.produto-link {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  height: 100%;
  flex: 1;
}

.produto-link:hover {
  text-decoration: none;
  color: inherit;
}

.produto-image-wrapper {
  position: relative;
  overflow: hidden;
  background: var(--gray-100, #f1f3f5);
  aspect-ratio: 4 / 3;
  flex-shrink: 0;
}

.produto-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-base, 0.3s ease);
}

.produto-card:hover .produto-image {
  transform: scale(1.1);
}

.badge-desconto {
  position: absolute;
  top: var(--spacing-sm, 8px);
  right: var(--spacing-sm, 8px);
  background: linear-gradient(135deg, var(--danger, #dc3545), #c82333);
  color: var(--white, #ffffff);
  padding: var(--spacing-xs, 4px) var(--spacing-sm, 8px);
  border-radius: var(--radius-full, 9999px);
  font-size: var(--font-size-xs, 0.75rem);
  font-weight: 700;
  box-shadow: var(--shadow-md, 0 4px 12px rgba(0, 0, 0, 0.15));
  z-index: 10;
}

.produto-card .card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: var(--spacing-md, 16px);
  justify-content: space-between;
}

.produto-title {
  font-size: var(--font-size-base, 1rem);
  font-weight: 600;
  margin-bottom: var(--spacing-sm, 8px);
  color: var(--text-primary, #212529);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
  max-height: 2.6em;
}

.produto-preco {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs, 4px);
  margin-top: auto;
}

.preco-original {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--text-secondary, #6c757d);
}

.preco-original strike {
  color: var(--gray-500, #adb5bd);
}

.preco-desconto {
  font-size: var(--font-size-xl, 1.25rem);
  font-weight: 700;
  color: var(--success, #198754);
}

.preco-normal {
  font-size: var(--font-size-xl, 1.25rem);
  font-weight: 700;
  color: var(--primary, #0d6efd);
}

/* === MODAL CUSTOMIZADO === */
.modal-custom {
  z-index: 2000 !important;
}

.modal-custom.show {
  display: block !important;
}

.modal-custom .modal-dialog {
  pointer-events: none;
}

.modal-custom .modal-content {
  border-radius: var(--radius-lg, 16px);
  overflow: hidden;
  border: none;
  box-shadow: var(--shadow-xl, 0 16px 48px rgba(0, 0, 0, 0.15));
  pointer-events: auto !important;
  position: relative;
  z-index: 1;
}

.modal-custom .modal-header {
  background: linear-gradient(135deg, rgba(13, 110, 253, 0.05) 0%, rgba(102, 16, 242, 0.05) 100%);
  border-bottom: 1px solid var(--gray-200, #e9ecef);
  padding: var(--spacing-lg, 20px);
  pointer-events: auto;
  position: relative;
  z-index: 2;
}

.modal-custom .modal-title {
  font-weight: 700;
  color: var(--text-primary, #212529);
  font-size: var(--font-size-xl, 1.25rem);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm, 8px);
}

.modal-custom .modal-title i {
  color: var(--primary, #0d6efd);
}

.modal-custom .modal-header .btn-close {
  pointer-events: auto !important;
  z-index: 10;
  position: relative;
}

.modal-custom .modal-body {
  padding: var(--spacing-lg, 20px);
  background: var(--bg-card, #ffffff);
  pointer-events: auto;
  position: relative;
  z-index: 1;
}

.modal-custom .modal-produto {
  display: flex;
  gap: var(--spacing-md, 16px);
  align-items: flex-start;
  margin-bottom: var(--spacing-lg, 24px);
  padding: var(--spacing-md, 16px);
  background: var(--gray-50, #f8f9fa);
  border-radius: var(--radius-md, 12px);
  border: 1px solid var(--gray-200, #e9ecef);
}

.modal-custom .modal-produto img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: var(--radius-md, 12px);
  box-shadow: var(--shadow-sm, 0 2px 4px rgba(0, 0, 0, 0.05));
  flex-shrink: 0;
}

.modal-custom .modal-produto .info {
  flex: 1;
}

.modal-custom .modal-produto .info h6 {
  font-size: var(--font-size-lg, 1.125rem);
  font-weight: 600;
  color: var(--text-primary, #212529);
  margin-bottom: var(--spacing-sm, 8px);
}

.produto-preco-modal {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs, 4px);
  margin-top: var(--spacing-sm, 8px);
}

.preco-original-modal {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--text-secondary, #6c757d);
}

.preco-desconto-modal {
  font-size: var(--font-size-2xl, 1.5rem);
  font-weight: 700;
  color: var(--success, #198754);
}

/* Seleção de Veículos */
.veiculos-selecao {
  border-top: 1px solid var(--gray-200, #e9ecef);
  padding-top: var(--spacing-lg, 24px);
}

.veiculos-selecao .form-label {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm, 8px);
  margin-bottom: var(--spacing-md, 16px);
  color: var(--text-primary, #212529);
}

.veiculos-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm, 8px);
}

.veiculo-item {
  display: flex;
  align-items: center;
  padding: var(--spacing-sm, 8px) var(--spacing-md, 12px);
  background: var(--bg-card, #ffffff);
  border: 2px solid var(--gray-200, #e9ecef);
  border-radius: var(--radius-sm, 8px);
  transition: all var(--transition-fast, 0.15s ease);
  cursor: pointer;
  position: relative;
  z-index: 1;
}

.veiculo-item input[type="radio"] {
  position: relative;
  z-index: 2;
  pointer-events: auto;
}

.veiculo-item label {
  position: relative;
  z-index: 2;
  pointer-events: auto;
}

.veiculo-item:hover {
  border-color: var(--primary, #0d6efd);
  background: var(--gray-50, #f8f9fa);
}

.veiculo-item input[type="radio"] {
  margin-right: var(--spacing-sm, 8px);
  cursor: pointer;
}

.veiculo-item input[type="radio"]:checked + label {
  color: var(--primary, #0d6efd);
  font-weight: 600;
}

.veiculo-item label {
  flex: 1;
  cursor: pointer;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.veiculo-item label.disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.modal-custom .modal-footer {
  border-top: 1px solid var(--gray-200, #e9ecef);
  padding: var(--spacing-lg, 20px);
  background: linear-gradient(180deg, #fff, var(--gray-50, #f8f9fa));
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-sm, 8px);
  pointer-events: auto;
  position: relative;
  z-index: 2;
}

.modal-custom .modal-footer .btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs, 4px);
  pointer-events: auto !important;
  cursor: pointer;
  z-index: 10;
  position: relative;
}

/* Garantir que elementos interativos do modal sejam clicáveis */
.modal-custom .modal-body input[type="radio"],
.modal-custom .modal-body input[type="hidden"],
.modal-custom .modal-body button,
.modal-custom .modal-body label,
.modal-custom .modal-body .veiculo-item,
.modal-custom .modal-body .veiculo-item * {
  pointer-events: auto !important;
  cursor: pointer;
  position: relative;
  z-index: 2;
}

.modal-custom .modal-body form {
  pointer-events: auto;
  position: relative;
  z-index: 1;
}

@media (max-width: 768px) {
  .produto-image-wrapper {
    aspect-ratio: 3 / 2;
  }
  
  .produto-title {
    font-size: var(--font-size-sm, 0.875rem);
    min-height: 2.4em;
    max-height: 2.4em;
  }
}

@media (max-width: 576px) {
  .modal-custom .modal-produto {
    flex-direction: column;
    text-align: center;
  }
  
  .modal-custom .modal-produto img {
    width: 100%;
    max-width: 200px;
    height: auto;
    margin: 0 auto;
  }
  
  .veiculo-item {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .veiculo-item label {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-xs, 4px);
  }
  
  .produto-card .card-body {
    padding: var(--spacing-sm, 12px);
  }
}

/* === RESPONSIVIDADE PARA PRODUTOS === */
@media (max-width: 1200px) {
  .produtos-grid .col-lg-3 {
    flex: 0 0 auto;
    width: 25%;
  }
}

@media (max-width: 992px) {
  .produtos-grid .col-lg-3,
  .produtos-grid .col-md-4 {
    flex: 0 0 auto;
    width: 33.333333%;
  }
}

@media (max-width: 768px) {
  .produtos-grid {
    padding: var(--spacing-lg, 24px) 0;
  }
  
  .produtos-grid .col-md-4 {
    flex: 0 0 auto;
    width: 50%;
  }
  
  .produto-image-wrapper {
    aspect-ratio: 4 / 3;
  }
  
  .produto-title {
    font-size: var(--font-size-sm, 0.875rem);
    min-height: 2.4em;
  }
  
  .preco-desconto,
  .preco-normal {
    font-size: var(--font-size-lg, 1.125rem);
  }
}

@media (max-width: 576px) {
  .produtos-grid {
    padding: var(--spacing-md, 16px) 0;
  }
  
  .produtos-grid .col-sm-6 {
    flex: 0 0 auto;
    width: 100%;
  }
  
  .produto-card {
    margin-bottom: var(--spacing-md, 16px);
  }
  
  .modal-custom .modal-produto {
    flex-direction: column;
    text-align: center;
  }
  
  .modal-custom .modal-produto img {
    width: 100px;
    height: 100px;
  }
}

/* === PÁGINA DE LOGIN === */
.login-container {
  min-height: calc(100vh - 200px);
  /*display: flex;*/
  /*align-items: center;*/
  padding: var(--spacing-xl, 32px) var(--spacing-md, 16px);
}

.login-wrapper {
  max-width: 900px;
  margin: 0 auto;
}

.login-header {
  margin-bottom: var(--spacing-xl, 32px);
}

.login-title {
  font-size: var(--font-size-3xl, 1.875rem);
  font-weight: 700;
  color: var(--text-primary, #212529);
  margin-bottom: var(--spacing-sm, 8px);
}

.login-subtitle {
  font-size: var(--font-size-lg, 1.125rem);
  color: var(--text-secondary, #6c757d);
  margin-bottom: 0;
}

.login-card {
  background: var(--bg-card, #ffffff);
  border-radius: var(--radius-lg, 16px);
  padding: var(--spacing-xl, 32px);
  box-shadow: var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, 0.12));
  border: 1px solid var(--gray-200, #e9ecef);
  height: 100%;
  transition: transform var(--transition-base, 0.3s ease), box-shadow var(--transition-base, 0.3s ease);
}

.login-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl, 0 16px 48px rgba(0, 0, 0, 0.15));
}

.login-card-header {
  text-align: center;
  margin-bottom: var(--spacing-lg, 24px);
}

.login-card-header i {
  font-size: var(--font-size-4xl, 2.25rem);
  color: var(--primary, #0d6efd);
  margin-bottom: var(--spacing-sm, 8px);
  display: block;
}

.login-card-header h3 {
  font-size: var(--font-size-xl, 1.25rem);
  font-weight: 600;
  color: var(--text-primary, #212529);
  margin-bottom: 0;
}

.login-form {
  margin-top: var(--spacing-lg, 24px);
}

#resultado {
  padding: var(--spacing-md, 16px);
  border-radius: var(--radius-sm, 8px);
  font-size: var(--font-size-sm, 0.875rem);
}

#resultado.success {
  background-color: var(--success-light, #d1e7dd);
  color: var(--success, #198754);
  border: 1px solid rgba(25, 135, 84, 0.2);
}

#resultado.error {
  background-color: var(--danger-light, #f8d7da);
  color: var(--danger, #dc3545);
  border: 1px solid rgba(220, 53, 69, 0.2);
}

@media (max-width: 768px) {
  .login-container {
    min-height: auto;
    padding: var(--spacing-lg, 24px) var(--spacing-md, 16px);
  }
  
  .login-title {
    font-size: var(--font-size-2xl, 1.5rem);
  }
  
  .login-card {
    padding: var(--spacing-lg, 24px);
    margin-bottom: var(--spacing-lg, 24px);
  }
  
  .login-card-header i {
    font-size: var(--font-size-3xl, 1.875rem);
  }
}

/* === ANIMAÇÕES === */
@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.produto-card {
  animation: slideInUp var(--transition-base, 0.3s ease) backwards;
}

.produto-card:nth-child(1) { animation-delay: 0.05s; }
.produto-card:nth-child(2) { animation-delay: 0.1s; }
.produto-card:nth-child(3) { animation-delay: 0.15s; }
.produto-card:nth-child(4) { animation-delay: 0.2s; }
.produto-card:nth-child(5) { animation-delay: 0.25s; }
.produto-card:nth-child(6) { animation-delay: 0.3s; }
.produto-card:nth-child(7) { animation-delay: 0.35s; }
.produto-card:nth-child(8) { animation-delay: 0.4s; }

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.login-card {
  animation: fadeIn var(--transition-base, 0.3s ease) backwards;
}

.login-card:nth-child(1) { animation-delay: 0.1s; }
.login-card:nth-child(2) { animation-delay: 0.2s; }
