/* SF Bay Area Moving Insurance Form - Processed CSS */
/* All selectors prefixed with .sfbay-insurance-wrapper for isolation */

.sfbay-insurance-wrapper {
  /* Root variables maintained */
  --primary: #e02020;
  --primary-dark: #b11111;
  --text-main: #151515;
  --text-muted: #6b7280;
  --bg-page: #ffffff;
  --bg-soft: #f7f7f7;
  --border-color: #e5e7eb;
  --radius-md: 12px;
  --radius-lg: 18px;
  --radius-xl: 24px;
  --max-width: 1120px;
  --btn-main: #e02020;
  --btn-main-hover: #3a3a3a;
  --cta-btn-gray: #181818;
  --cta-btn-gray-hover: #3a3a3a;
}

.sfbay-insurance-wrapper * {
  box-sizing: border-box !important;
}

.sfbay-insurance-wrapper body {
  margin: 0 !important;
  font-family: "Montserrat", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  background-color: var(--bg-page) !important;
  background-image: radial-gradient(circle at 0 0, rgba(224,32,32,0.06) 0, transparent 55%),
        radial-gradient(circle at 100% 100%, rgba(0,0,0,0.06) 0, transparent 55%),
        repeating-linear-gradient(
          135deg,
          rgba(0,0,0,0.015) 0,
          rgba(0,0,0,0.015) 1px,
          transparent 1px,
          transparent 7px
        ) !important;
  background-attachment: fixed !important;
  color: var(--text-main) !important;
  line-height: 1.6 !important;
}

.sfbay-insurance-wrapper a {
  color: var(--primary-dark) !important;
  text-decoration: none !important;
}

.sfbay-insurance-wrapper a:hover {
  text-decoration: underline !important;
}

.sfbay-insurance-wrapper .page-wrapper {
  min-height: 100vh !important;
  padding: 32px 16px 40px !important;
}

.sfbay-insurance-wrapper .container {
  max-width: var(--max-width) !important;
  margin: 0 auto !important;
}

/* HEADER / BANNER */
.sfbay-insurance-wrapper .header-card {
  border-radius: var(--radius-xl) !important;
  background: #ffffff !important;
  box-shadow: 0 20px 50px rgba(15,23,42,0.22) !important;
  border: 1px solid rgba(15,23,42,0.08) !important;
  overflow: hidden !important;
  margin-bottom: 24px !important;
}

/* BACKGROUND REMOVIDO AQUI - AGORA É CONTROLADO POR PHP */
.sfbay-insurance-wrapper .header-image {
  width: 100% !important;
  height: 330px !important;
  display: flex !important;
  align-items: flex-end !important;
  padding: 22px !important;
  color: #ffffff !important;
  position: relative !important;
}

.sfbay-insurance-wrapper .header-image::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    to top,
    rgba(0,0,0,0.42),
    rgba(0,0,0,0.02)
  ) !important;
  pointer-events: none !important;
}

.sfbay-insurance-wrapper .header-tag {
  position: relative !important;
  z-index: 2 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 7px 16px !important;
  border-radius: 999px !important;
  background: rgba(224,32,32,0.92) !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.16em !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.35) !important;
}

.sfbay-insurance-wrapper .header-tag span {
  width: 8px !important;
  height: 8px !important;
  border-radius: 999px !important;
  background: #22c55e !important;
}

.sfbay-insurance-wrapper .header-copy {
  padding: 18px 22px 16px !important;
  border-top: 1px solid rgba(229,231,235,0.9) !important;
}

.sfbay-insurance-wrapper .header-copy h1 {
  margin: 0 0 10px !important;
  font-size: 1.55rem !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--primary) !important;
}

.sfbay-insurance-wrapper .header-copy p {
  margin: 0 0 6px !important;
  font-size: 1rem !important;
}

.sfbay-insurance-wrapper .required-legend {
  margin-top: 8px !important;
  font-size: 0.9rem !important;
  color: var(--primary-dark) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
}

/* FORM MAIN WRAPPER */
.sfbay-insurance-wrapper .form-shell {
  margin: 0 auto 26px !important;
  max-width: 1000px !important;
  border-radius: var(--radius-lg) !important;
  background: #ffffff !important;
  box-shadow: 0 18px 40px rgba(15,23,42,0.18) !important;
  border: 1px solid rgba(15,23,42,0.06) !important;
  padding: 20px 22px 18px !important;
}

.sfbay-insurance-wrapper .form-title-bar {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  margin-bottom: 10px !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.sfbay-insurance-wrapper .form-title-main {
  font-size: 1rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.18em !important;
  color: var(--primary-dark) !important;
  font-weight: 700 !important;
}

.sfbay-insurance-wrapper .form-title-sub {
  font-size: 0.85rem !important;
  color: var(--text-muted) !important;
}

.sfbay-insurance-wrapper .form-section {
  border-radius: var(--radius-md) !important;
  border: 1px solid var(--border-color) !important;
  background: #ffffff !important;
  padding: 12px 12px 10px !important;
  margin-bottom: 14px !important;
}

.sfbay-insurance-wrapper .section-header {
  margin-bottom: 8px !important;
}

.sfbay-insurance-wrapper .step-label {
  font-size: 0.78rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.16em !important;
  color: var(--primary-dark) !important;
  font-weight: 700 !important;
  margin-bottom: 3px !important;
}

.sfbay-insurance-wrapper .section-header h3 {
  margin: 0 !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.10em !important;
  color: #111827 !important;
}

.sfbay-insurance-wrapper .section-header h3 span {
  color: var(--primary) !important;
}

.sfbay-insurance-wrapper label {
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  display: block !important;
  margin-bottom: 3px !important;
}

.sfbay-insurance-wrapper .required {
  color: #b91c1c !important;
  margin-left: 3px !important;
}

/* NEW FIELD ROWS (IMPROVED LAYOUT) */
.sfbay-insurance-wrapper .form-row {
  display: flex !important;
  gap: 16px !important;
  width: 100% !important;
}

.sfbay-insurance-wrapper .form-col {
  flex: 1 !important;
}

.sfbay-insurance-wrapper .form-col.full {
  flex: 100% !important;
}

.sfbay-insurance-wrapper input[type="text"],
.sfbay-insurance-wrapper input[type="email"],
.sfbay-insurance-wrapper input[type="tel"],
.sfbay-insurance-wrapper input[type="number"],
.sfbay-insurance-wrapper input[type="date"],
.sfbay-insurance-wrapper textarea,
.sfbay-insurance-wrapper select {
  width: 100% !important;
  border-radius: 8px !important;
  border: 1px solid var(--border-color) !important;
  padding: 10px 12px !important;
  font-family: inherit !important;
  font-size: 0.9rem !important;
  color: var(--text-main) !important;
  background-color: #ffffff !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
}

.sfbay-insurance-wrapper textarea {
  min-height: 110px !important;
  resize: vertical !important;
}

.sfbay-insurance-wrapper input:focus,
.sfbay-insurance-wrapper textarea:focus,
.sfbay-insurance-wrapper select:focus {
  outline: none !important;
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 1px rgba(224,32,32,0.3) !important;
}

.sfbay-insurance-wrapper .muted {
  font-size: 0.86rem !important;
  color: var(--text-muted) !important;
}

.sfbay-insurance-wrapper .option-line {
  display: flex !important;
  gap: 10px !important;
  margin-bottom: 6px !important;
  align-items: flex-start !important;
}

/* BUTTONS */
.sfbay-insurance-wrapper .btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 11px 20px !important;
  border-radius: 8px !important;
  border: none !important;
  cursor: pointer !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  white-space: nowrap !important;
  transition: 0.15s ease !important;
  font-family: inherit !important;
}

.sfbay-insurance-wrapper .btn-primary {
  background: var(--btn-main) !important;
  color: #ffffff !important;
  box-shadow: 0 6px 14px rgba(0,0,0,0.25) !important;
}

.sfbay-insurance-wrapper .btn-primary:hover {
  background: var(--btn-main-hover) !important;
  color: #ffffff !important;
  transform: translateY(-1px) !important;
  text-decoration: none !important;
}

.sfbay-insurance-wrapper .btn-secondary {
  background: #ffffff !important;
  color: var(--text-main) !important;
  border: 1px solid var(--border-color) !important;
}

.sfbay-insurance-wrapper .btn-secondary:hover {
  background: #f3f3f3 !important;
  border-color: #d1d5db !important;
  text-decoration: none !important;
}

.sfbay-insurance-wrapper .btn-sm {
  padding: 7px 12px !important;
  font-size: 0.75rem !important;
}

.sfbay-insurance-wrapper .form-footer {
  margin-top: 10px !important;
  padding-top: 10px !important;
  border-top: 1px solid var(--border-color) !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

/* SEÇÕES 3 E 4 - TABELA DINÂMICA DE ITENS */
.sfbay-insurance-wrapper .items-grid {
  border-radius: 10px !important;
  border: 1px solid var(--border-color) !important;
  padding: 10px !important;
  background: #fafafa !important;
  margin-top: 8px !important;
}

.sfbay-insurance-wrapper .items-grid-header,
.sfbay-insurance-wrapper .items-grid-row {
  display: grid !important;
  grid-template-columns: 2fr 2fr 1.3fr auto !important;
  gap: 8px !important;
  align-items: center !important;
}

.sfbay-insurance-wrapper .items-grid-header {
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: #4b5563 !important;
  margin-bottom: 6px !important;
}

.sfbay-insurance-wrapper .items-grid-header div {
  padding: 2px 0 !important;
}

.sfbay-insurance-wrapper .items-grid-row + .items-grid-row {
  margin-top: 6px !important;
}

.sfbay-insurance-wrapper .items-grid-row .item-remove {
  background: transparent !important;
  border: none !important;
  color: #9ca3af !important;
  font-size: 1.1rem !important;
  padding: 4px 6px !important;
  cursor: pointer !important;
  border-radius: 999px !important;
  line-height: 1 !important;
  align-self: flex-start !important;
}

.sfbay-insurance-wrapper .items-grid-row .item-remove:hover {
  background: rgba(0,0,0,0.04) !important;
  color: #ef4444 !important;
}

.sfbay-insurance-wrapper .items-actions {
  margin-top: 8px !important;
  display: flex !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.sfbay-insurance-wrapper .items-total {
  margin-top: 10px !important;
  font-size: 0.9rem !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 6px !important;
  align-items: baseline !important;
}

.sfbay-insurance-wrapper .items-total strong {
  font-weight: 800 !important;
  font-size: 1rem !important;
  color: #111827 !important;
}

.sfbay-insurance-wrapper .items-total-consolidated {
  border-top: 1px dashed var(--border-color) !important;
  padding-top: 6px !important;
  margin-top: 10px !important;
}

.sfbay-insurance-wrapper .hidden {
  display: none !important;
}

/* ESTIMADOR TOTALMENTE BRANCO */
.sfbay-insurance-wrapper .estimator-section {
  margin: 0 auto !important;
  max-width: 1000px !important;
}

.sfbay-insurance-wrapper .estimator-shell {
  background: #ffffff !important;
  color: #111 !important;
  border-radius: var(--radius-lg) !important;
  padding: 24px 22px !important;
  box-shadow: 0 14px 40px rgba(0,0,0,0.08) !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
}

.sfbay-insurance-wrapper .estimator-shell h2 {
  margin: 0 0 10px !important;
  font-size: 1.25rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.16em !important;
  font-weight: 800 !important;
  color: var(--primary) !important;
}

.sfbay-insurance-wrapper .estimator-shell p {
  font-size: 0.95rem !important;
  color: #333 !important;
  margin-bottom: 18px !important;
}

.sfbay-insurance-wrapper .estimator-shell label {
  font-weight: 600 !important;
  color: #111 !important;
  margin-bottom: 4px !important;
  display: block !important;
}

.sfbay-insurance-wrapper .estimator-shell select,
.sfbay-insurance-wrapper .estimator-shell input {
  width: 100% !important;
  padding: 12px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(0,0,0,0.2) !important;
  background: #fff !important;
  font-size: 0.95rem !important;
  color: #111 !important;
}

.sfbay-insurance-wrapper .estimator-shell select:focus,
.sfbay-insurance-wrapper .estimator-shell input:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 1px rgba(224,32,32,0.25) !important;
  outline: none !important;
}

.sfbay-insurance-wrapper .est-result {
  margin-top: 18px !important;
  padding: 16px !important;
  border-radius: 10px !important;
  background: #fafafa !important;
  border: 1px solid #e5e5e5 !important;
}

.sfbay-insurance-wrapper .est-amount {
  font-size: 1.6rem !important;
  font-weight: 800 !important;
  color: #000 !important;
}

.sfbay-insurance-wrapper .est-caption {
  font-size: 0.9rem !important;
  color: #444 !important;
}

.sfbay-insurance-wrapper .est-helper {
  margin-top: 12px !important;
  font-size: 0.85rem !important;
  color: #555 !important;
}

/* RESPONSIVO */
@media (max-width: 720px) {
  .sfbay-insurance-wrapper .form-shell {
    padding: 18px 14px !important;
  }
  .sfbay-insurance-wrapper .form-row {
    flex-direction: column !important;
  }
  .sfbay-insurance-wrapper .btn,
  .sfbay-insurance-wrapper .btn-primary,
  .sfbay-insurance-wrapper .btn-secondary {
    width: 100% !important;
  }
  .sfbay-insurance-wrapper .items-grid-header,
  .sfbay-insurance-wrapper .items-grid-row {
    grid-template-columns: 1.8fr 1.8fr 1.4fr auto !important;
  }

  /* ===== RESPONSIVE UPDATES ===== */
@media (max-width: 720px) {
  .sfbay-insurance-wrapper .header-image {
    height: 200px !important;
    padding: 15px !important;
  }
  
  .sfbay-insurance-wrapper .header-tag {
    font-size: 0.7rem !important;
    padding: 5px 12px !important;
  }
  
  .sfbay-insurance-wrapper .form-shell {
    padding: 15px 12px !important;
    margin-bottom: 20px !important;
  }
  
  .sfbay-insurance-wrapper .form-section {
    padding: 10px !important;
  }
  
  .sfbay-insurance-wrapper .items-grid-header,
  .sfbay-insurance-wrapper .items-grid-row {
    grid-template-columns: 1.5fr 1.5fr 1.2fr auto !important;
    gap: 6px !important;
    font-size: 11px !important;
  }
  
  .sfbay-insurance-wrapper .items-grid-row input {
    font-size: 11px !important;
    padding: 6px 8px !important;
  }
  
  .sfbay-insurance-wrapper .btn {
    padding: 10px 16px !important;
    font-size: 0.8rem !important;
  }
  
  .sfbay-insurance-wrapper .estimator-shell {
    padding: 18px 15px !important;
  }
  
  .sfbay-insurance-wrapper .est-amount {
    font-size: 1.4rem !important;
  }
}

/* Mobile muito pequeno */
@media (max-width: 480px) {
  .sfbay-insurance-wrapper .items-grid-header,
  .sfbay-insurance-wrapper .items-grid-row {
    grid-template-columns: 1.8fr 1fr auto !important;
  }
  
  .sfbay-insurance-wrapper .items-grid-header div:nth-child(2),
  .sfbay-insurance-wrapper .items-grid-row div:nth-child(2) {
    display: none !important;
  }
  
  .sfbay-insurance-wrapper .header-copy h1 {
    font-size: 1.2rem !important;
  }
  
  .sfbay-insurance-wrapper .section-header h3 {
    font-size: 0.9rem !important;
  }
}
}