/* Reescrevendo todo o CSS para ficar idêntico à versão React com !important */
.calculadora-horas-trabalhadas {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
  padding: 16px !important;
  background: #f9fafb !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1) !important;
}

.calculadora-container {
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.calculadora-header {
  text-align: center !important;
  margin-bottom: 24px !important;
}

.calculadora-header h1 {
  font-size: 24px !important;
  font-weight: 700 !important;
  margin-bottom: 8px !important;
  line-height: 1.2 !important;
}

.titulo-normal {
  color: #374151 !important;
}

.titulo-destaque {
  color: #fe3e6d !important;
}

.subtitulo {
  color: #6b7280 !important;
  font-size: 14px !important;
  margin: 0 !important;
}

.calculadora-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  gap: 24px !important;
  align-items: start !important;
}

.configuracoes-column,
.registro-column,
.registros-column {
  display: flex !important;
  flex-direction: column !important;
  gap: 24px !important;
}

.calculadora-card {
  background: white !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
  border: 0 !important;
  overflow: hidden !important;
}

.card-header {
  background: linear-gradient(to right, #f9fafb, #f3f4f6) !important;
  border-bottom: 1px solid #e5e7eb !important;
  padding: 12px 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.header-icon {
  color: #fe3e6d !important;
  font-size: 20px !important;
}

.card-header h2 {
  color: #fe3e6d !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  margin: 0 !important;
}

.card-content {
  padding: 16px !important;
}

.input-field {
  display: flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
  margin-bottom: 16px !important;
}

.field-icon {
  flex-shrink: 0 !important;
  width: 24px !important;
  color: #6b7280 !important;
  font-size: 16px !important;
  margin-top: 24px !important;
}

.field-content {
  flex-grow: 1 !important;
}

.field-content.full-width {
  width: 100% !important;
}

.field-content label {
  display: block !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: #374151 !important;
  margin-bottom: 4px !important;
}

.input-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}

.input-wrapper input,
.field-content input,
.field-content textarea {
  width: 100% !important;
  height: 36px !important;
  padding: 4px 12px !important;
  font-size: 14px !important;
  background: #f9fafb !important;
  border: 1px solid #d1d5db !important;
  border-radius: 6px !important;
  transition: all 0.2s !important;
}

.field-content textarea {
  height: auto !important;
  padding: 12px !important;
  resize: vertical !important;
}

.input-wrapper input:focus,
.field-content input:focus,
.field-content textarea:focus {
  outline: none !important;
  background: white !important;
  border-color: #fe3e6d !important;
}

.input-prefix,
.input-suffix {
  position: absolute !important;
  color: #6b7280 !important;
  font-size: 14px !important;
  pointer-events: none !important;
}

.input-prefix {
  left: 12px !important;
}

.input-suffix {
  right: 12px !important;
}

.input-wrapper input:has(+ .input-prefix) {
  padding-left: 40px !important;
}

.input-wrapper input:has(+ .input-suffix) {
  padding-right: 40px !important;
}

/* Resumo */
.resumo-item {
  padding: 12px !important;
  background: #f9fafb !important;
  border-radius: 8px !important;
  margin-bottom: 12px !important;
}

.resumo-item.destaque {
  background: #fe3e6d !important;
  color: white !important;
}

.resumo-label {
  font-size: 12px !important;
  color: #6b7280 !important;
  margin-bottom: 4px !important;
  margin: 0 0 4px 0 !important;
}

.resumo-item.destaque .resumo-label {
  color: white !important;
}

.resumo-valor {
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #1f2937 !important;
  margin: 0 !important;
}

.resumo-valor-total {
  font-size: 24px !important;
  font-weight: 700 !important;
  color: white !important;
  margin: 0 !important;
}

.card-actions {
  display: flex !important;
  gap: 8px !important;
  margin-top: 24px !important;
}

.btn-limpar,
.btn-imprimir {
  flex: 1 !important;
  padding: 8px 16px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 6px !important;
  background: transparent !important;
  color: #374151 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  transition: all 0.2s !important;
}

.btn-imprimir {
  background: #fe3e6d !important;
  color: white !important;
  border-color: #fe3e6d !important;
}

.btn-limpar:hover {
  background: #f3f4f6 !important;
}

.btn-imprimir:hover {
  background: #e5366a !important;
}

.btn-adicionar {
  width: 100% !important;
  padding: 8px 16px !important;
  background: #fe3e6d !important;
  color: white !important;
  border: none !important;
  border-radius: 6px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  transition: all 0.2s !important;
}

.btn-adicionar:hover {
  background: #e5366a !important;
}

/* Lista de Registros */
.registros-lista {
  max-height: 384px !important;
  overflow-y: auto !important;
}

.registros-vazio {
  text-align: center !important;
  padding: 32px 16px !important;
  color: #6b7280 !important;
}

.registros-vazio i {
  font-size: 48px !important;
  margin-bottom: 12px !important;
  opacity: 0.5 !important;
  display: block !important;
}

.registros-vazio p {
  margin: 0 0 4px 0 !important;
  font-size: 14px !important;
}

.texto-pequeno {
  font-size: 12px !important;
}

.registro-item {
  padding: 12px !important;
  background: #f9fafb !important;
  border-radius: 8px !important;
  border: 1px solid #e5e7eb !important;
  margin-bottom: 12px !important;
  position: relative !important;
}

.registro-data {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #1f2937 !important;
  margin-bottom: 8px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.btn-remover {
  background: none !important;
  border: none !important;
  color: #ef4444 !important;
  cursor: pointer !important;
  padding: 4px !important;
  border-radius: 4px !important;
  font-size: 16px !important;
  transition: all 0.2s !important;
}

.btn-remover:hover {
  background: #fef2f2 !important;
  color: #dc2626 !important;
}

.registro-detalhes {
  font-size: 12px !important;
  color: #6b7280 !important;
  line-height: 1.4 !important;
}

.registro-detalhes div {
  display: flex !important;
  justify-content: space-between !important;
  margin-bottom: 2px !important;
}

.registro-detalhes .horas-extras {
  color: #fe3e6d !important;
  font-weight: 500 !important;
}

.registro-observacoes {
  font-size: 12px !important;
  color: #6b7280 !important;
  font-style: italic !important;
  margin-top: 8px !important;
}

/* Informações */
.info-section {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
}

.info-icon {
  color: #3b82f6 !important;
  font-size: 20px !important;
  flex-shrink: 0 !important;
  margin-top: 2px !important;
}

.info-content {
  flex: 1 !important;
}

.info-title {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #1d4ed8 !important;
  margin: 0 0 4px 0 !important;
}

.info-list {
  margin: 0 !important;
  padding-left: 16px !important;
  font-size: 14px !important;
  color: #2563eb !important;
  line-height: 1.4 !important;
}

.info-list li {
  margin-bottom: 2px !important;
}

/* Responsivo */
@media (max-width: 1024px) {
  .calculadora-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .calculadora-header h1 {
    font-size: 20px !important;
  }
}

@media (max-width: 768px) {
  .calculadora-horas-trabalhadas {
    padding: 8px !important;
  }

  .card-content {
    padding: 12px !important;
  }

  .input-field {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .field-icon {
    margin-top: 0 !important;
    margin-bottom: 8px !important;
  }
}
