/* BizInvest Calculator – Brand: #080924 + #C21017 */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --bic-dark:    #080924;
  --bic-red:     #C21017;
  --bic-red-dark:#9e0d13;
  --bic-red-light:#e8141c;
  --bic-gold:    #d4a843;
  --bic-white:   #ffffff;
  --bic-bg:      #f8f9ff;
  --bic-card:    #ffffff;
  --bic-border:  #e4e6f0;
  --bic-text:    #1a1d3a;
  --bic-muted:   #6b7280;
  --bic-success: #10b981;
  --bic-warning: #f59e0b;
  --bic-shadow:  0 4px 24px rgba(8,9,36,0.10);
  --bic-radius:  16px;
  --bic-radius-sm:10px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* === WRAPPER === */
.bic-calc-wrapper {
  font-family: 'Plus Jakarta Sans', sans-serif;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 16px 60px;
  color: var(--bic-text);
}

/* === PROGRESS === */
.bic-progress-wrap {
  padding: 30px 0 20px;
  position: relative;
}
.bic-steps-indicator {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  overflow-x: auto;
  gap: 0;
  scrollbar-width: none;
}
.bic-step-dot-outer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.bic-step-dot-inner {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--bic-border);
  color: var(--bic-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  transition: all 0.4s cubic-bezier(.175,.885,.32,1.275);
  position: relative;
  z-index: 2;
}
.bic-step-dot-outer.active .bic-step-dot-inner {
  background: var(--bic-red);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(194,16,23,0.20);
  transform: scale(1.15);
}
.bic-step-dot-outer.done .bic-step-dot-inner {
  background: var(--bic-success);
  color: #fff;
}
.bic-step-dot-outer span {
  font-size: 10px;
  font-weight: 600;
  color: var(--bic-muted);
  white-space: nowrap;
  text-align: center;
}
.bic-step-dot-outer.active span { color: var(--bic-red); }
.bic-step-dot-outer.done span  { color: var(--bic-success); }
.bic-step-line {
  flex: 1;
  height: 2px;
  background: var(--bic-border);
  margin-bottom: 22px;
  min-width: 10px;
  transition: background 0.4s;
}
.bic-step-line.done { background: var(--bic-success); }
.bic-progress-track {
  height: 4px;
  background: var(--bic-border);
  border-radius: 10px;
  overflow: hidden;
}
.bic-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--bic-red), var(--bic-gold));
  border-radius: 10px;
  transition: width 0.5s cubic-bezier(.4,0,.2,1);
  width: 0%;
}

/* === STEPS === */
.bic-step {
  animation: bicFadeIn 0.45s cubic-bezier(.4,0,.2,1);
}
@keyframes bicFadeIn {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.bic-step-header-content {
  text-align: center;
  padding: 32px 0 28px;
}
.bic-step-icon {
  font-size: 52px;
  margin-bottom: 12px;
  display: block;
  animation: bicBounce 0.6s cubic-bezier(.175,.885,.32,1.275);
}
@keyframes bicBounce {
  0%   { transform: scale(0.5); opacity: 0; }
  60%  { transform: scale(1.15); opacity: 1; }
  100% { transform: scale(1); }
}
.bic-step-header-content h2 {
  font-size: clamp(20px, 4vw, 28px);
  font-weight: 800;
  color: var(--bic-dark);
  margin-bottom: 8px;
}
.bic-step-header-content p {
  color: var(--bic-muted);
  font-size: 14px;
}

/* === SEARCH === */
.bic-search-wrap { margin-bottom: 20px; }
.bic-input-search {
  width: 100%;
  padding: 14px 18px;
  border: 2px solid var(--bic-border);
  border-radius: var(--bic-radius-sm);
  font-family: inherit;
  font-size: 14px;
  outline: none;
  transition: border-color 0.3s;
  background: var(--bic-card);
}
.bic-input-search:focus { border-color: var(--bic-red); }

/* === OPTIONS GRID === */
.bic-options-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  max-height: 400px;
  overflow-y: auto;
  padding: 4px;
}
.bic-option-item {
  border: 2px solid var(--bic-border);
  border-radius: var(--bic-radius-sm);
  padding: 14px 16px;
  cursor: pointer;
  transition: all 0.25s;
  background: var(--bic-card);
  font-size: 13px;
  font-weight: 500;
}
.bic-option-item:hover {
  border-color: var(--bic-red);
  background: #fff5f5;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(194,16,23,0.12);
}
.bic-option-item.selected {
  border-color: var(--bic-red);
  background: linear-gradient(135deg, #fff0f0, #fff5f5);
  box-shadow: 0 4px 16px rgba(194,16,23,0.18);
}
.bic-option-item .bic-opt-name { font-weight: 600; color: var(--bic-dark); }
.bic-option-item .bic-opt-sub  { font-size: 11px; color: var(--bic-muted); margin-top: 4px; }
.bic-option-item .bic-opt-cost { font-size: 12px; color: var(--bic-red); font-weight: 700; margin-top: 4px; }
.bic-option-item .bic-opt-check { float: right; color: var(--bic-red); font-size: 16px; display: none; }
.bic-option-item.selected .bic-opt-check { display: inline; }

.bic-loading { place-items: center; min-height: 120px; display: grid; }
.bic-spinner {
  width: 36px; height: 36px;
  border: 3px solid var(--bic-border);
  border-top-color: var(--bic-red);
  border-radius: 50%;
  animation: bicSpin 0.8s linear infinite;
}
@keyframes bicSpin { to { transform: rotate(360deg); } }

/* === ZONE CARDS === */
.bic-zone-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin: 10px 0;
}
.bic-zone-card {
  border: 2px solid var(--bic-border);
  border-radius: var(--bic-radius);
  padding: 24px 20px;
  cursor: pointer;
  transition: all 0.3s;
  background: var(--bic-card);
  text-align: center;
}
.bic-zone-card:hover {
  border-color: var(--bic-red);
  transform: translateY(-4px);
  box-shadow: var(--bic-shadow);
}
.bic-zone-card.selected {
  border-color: var(--bic-red);
  background: linear-gradient(135deg, #fff0f0, #fdf4f4);
  box-shadow: 0 8px 32px rgba(194,16,23,0.15);
}
.bic-zone-card-icon { font-size: 40px; margin-bottom: 12px; display: block; }
.bic-zone-card h3 { font-size: 18px; font-weight: 700; color: var(--bic-dark); margin-bottom: 8px; }
.bic-zone-card p  { font-size: 12px; color: var(--bic-muted); margin-bottom: 12px; }
.bic-zone-card ul { list-style: none; text-align: left; }
.bic-zone-card ul li { font-size: 11px; color: var(--bic-text); padding: 3px 0; }

/* === VISA SELECTOR === */
.bic-visa-selector { text-align: center; padding: 20px 0; }
.bic-visa-display {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-bottom: 24px;
}
.bic-visa-btn {
  width: 54px; height: 54px;
  border-radius: 50%;
  border: 2px solid var(--bic-red);
  background: var(--bic-card);
  color: var(--bic-red);
  font-size: 24px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  display: flex; align-items: center; justify-content: center;
}
.bic-visa-btn:hover { background: var(--bic-red); color: #fff; }
.bic-visa-number span { font-size: 64px; font-weight: 800; color: var(--bic-dark); line-height: 1; }
.bic-visa-number small { display: block; font-size: 14px; color: var(--bic-muted); margin-top: 4px; }
.bic-visa-grid {
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 16px;
}
.bic-visa-quick {
  padding: 8px 16px; border-radius: 8px;
  border: 2px solid var(--bic-border);
  background: var(--bic-card); cursor: pointer;
  font-weight: 600; font-size: 14px; transition: all 0.2s;
  font-family: inherit;
}
.bic-visa-quick:hover, .bic-visa-quick.active {
  border-color: var(--bic-red); background: var(--bic-red); color: #fff;
}
.bic-visa-cost-note { color: var(--bic-muted); font-size: 13px; }

/* === FORM FIELDS === */
.bic-form-fields { max-width: 480px; margin: 0 auto; }
.bic-form-group { margin-bottom: 20px; }
.bic-form-group label { display: block; font-weight: 600; font-size: 13px; color: var(--bic-dark); margin-bottom: 8px; }
.bic-req { color: var(--bic-red); }
.bic-form-input {
  width: 100%;
  padding: 14px 16px;
  border: 2px solid var(--bic-border);
  border-radius: var(--bic-radius-sm);
  font-family: inherit;
  font-size: 14px;
  outline: none;
  transition: all 0.3s;
  background: var(--bic-card);
}
.bic-form-input:focus { border-color: var(--bic-red); box-shadow: 0 0 0 3px rgba(194,16,23,0.1); }
.bic-form-input.error { border-color: var(--bic-red); }

/* === SUMMARY === */
.bic-summary-card {
  background: var(--bic-card);
  border: 1px solid var(--bic-border);
  border-radius: var(--bic-radius);
  overflow: hidden;
  box-shadow: var(--bic-shadow);
  margin-bottom: 24px;
}
.bic-summary-header {
  background: var(--bic-dark);
  padding: 20px 24px;
  display: flex; align-items: center; justify-content: space-between;
}
.bic-summary-logo { font-size: 18px; font-weight: 800; color: #fff; letter-spacing: 1px; }
.bic-summary-date  { font-size: 12px; color: rgba(255,255,255,0.6); }
.bic-summary-rows  { padding: 20px 24px; }
.bic-summary-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0; border-bottom: 1px solid var(--bic-border);
  font-size: 14px;
}
.bic-summary-row span { color: var(--bic-muted); }
.bic-summary-row strong { color: var(--bic-dark); font-weight: 600; text-align: right; max-width: 60%; }
.bic-summary-total {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 16px; padding: 16px 20px;
  background: linear-gradient(135deg, var(--bic-dark), #1a1d3a);
  border-radius: var(--bic-radius-sm);
  font-size: 16px;
}
.bic-summary-total span  { color: rgba(255,255,255,0.8); font-weight: 500; }
.bic-summary-total strong { color: var(--bic-gold); font-size: 24px; font-weight: 800; }
.bic-disclaimer { font-size: 11px; color: var(--bic-muted); margin-top: 12px; font-style: italic; }
.bic-summary-client {
  padding: 16px 24px;
  background: var(--bic-bg);
  border-top: 1px solid var(--bic-border);
  font-size: 13px;
  color: var(--bic-muted);
  display: flex; gap: 16px; flex-wrap: wrap;
}
.bic-summary-client strong { color: var(--bic-dark); }

/* === ACTION BUTTONS === */
.bic-submit-actions {
  display: flex; gap: 12px; flex-wrap: wrap; justify-content: center;
  margin-bottom: 20px;
}
.bic-action-btn {
  padding: 14px 22px; border-radius: var(--bic-radius-sm);
  font-family: inherit; font-weight: 700; font-size: 14px;
  cursor: pointer; border: none; text-decoration: none;
  display: inline-flex; align-items: center; gap: 8px;
  transition: all 0.3s; white-space: nowrap;
}
.bic-btn-pdf     { background: var(--bic-dark); color: #fff; }
.bic-btn-pdf:hover { background: #1a1d3a; transform: translateY(-2px); }
.bic-btn-submit  { background: var(--bic-red); color: #fff; box-shadow: 0 4px 16px rgba(194,16,23,0.35); }
.bic-btn-submit:hover { background: var(--bic-red-light); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(194,16,23,0.45); }
.bic-btn-whatsapp{ background: #25D366; color: #fff; }
.bic-btn-whatsapp:hover { background: #20ba57; transform: translateY(-2px); }

/* === NAV BUTTONS === */
.bic-nav-btns {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 24px; gap: 12px;
}
.bic-btn-nav {
  padding: 14px 28px; border-radius: var(--bic-radius-sm);
  font-family: inherit; font-weight: 700; font-size: 14px;
  cursor: pointer; border: none; transition: all 0.3s;
}
.bic-btn-prev { background: var(--bic-border); color: var(--bic-dark); }
.bic-btn-prev:hover { background: #d0d3e8; }
.bic-btn-next { background: var(--bic-red); color: #fff; box-shadow: 0 4px 14px rgba(194,16,23,0.3); }
.bic-btn-next:hover { background: var(--bic-red-light); transform: translateY(-2px); }

/* === SUCCESS SCREEN === */
#bic-success-screen {
  text-align: center;
  padding: 60px 20px;
  animation: bicFadeIn 0.5s ease;
}
.bic-success-icon { font-size: 80px; margin-bottom: 20px; animation: bicBounce 0.8s ease; }
#bic-success-screen h2 { font-size: 28px; font-weight: 800; color: var(--bic-dark); margin-bottom: 12px; }
#bic-success-screen > p { color: var(--bic-muted); margin-bottom: 30px; }
.bic-serial-display {
  background: var(--bic-dark);
  color: #fff;
  border-radius: var(--bic-radius);
  padding: 28px;
  margin: 0 auto 28px;
  max-width: 380px;
}
.bic-serial-display span { display: block; font-size: 12px; color: rgba(255,255,255,0.6); margin-bottom: 8px; }
.bic-serial-display strong { display: block; font-size: 32px; font-weight: 800; letter-spacing: 3px; color: var(--bic-gold); margin-bottom: 8px; }
.bic-serial-display small { font-size: 11px; color: rgba(255,255,255,0.5); }
.bic-success-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 20px; }
.bic-track-hint { font-size: 13px; color: var(--bic-muted); }
.bic-track-hint a { color: var(--bic-red); font-weight: 600; }

/* === TRACKER === */
.bic-tracker-wrapper {
  font-family: 'Plus Jakarta Sans', sans-serif;
  max-width: 600px;
  margin: 0 auto;
  padding: 0 16px 60px;
  color: var(--bic-text);
}
.bic-tracker-header { text-align: center; padding: 32px 0 24px; }
.bic-tracker-icon { font-size: 48px; display: block; margin-bottom: 12px; }
.bic-tracker-header h2 { font-size: 26px; font-weight: 800; color: var(--bic-dark); margin-bottom: 8px; }
.bic-tracker-header p  { color: var(--bic-muted); font-size: 14px; }
.bic-tracker-form { background: var(--bic-card); border-radius: var(--bic-radius); padding: 28px; box-shadow: var(--bic-shadow); margin-bottom: 24px; }
.bic-tracker-or   { text-align: center; color: var(--bic-muted); font-size: 12px; font-weight: 600; margin: 12px 0; }
.bic-lead-info-card { background: var(--bic-bg); border-radius: var(--bic-radius-sm); padding: 20px; margin-bottom: 20px; }
.bic-lead-info-row { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--bic-border); font-size: 14px; }
.bic-lead-info-row:last-child { border: none; }
.bic-lead-info-row span { color: var(--bic-muted); }
.bic-lead-info-row strong { color: var(--bic-dark); font-weight: 600; }
.bic-tracker-steps { display: flex; flex-direction: column; gap: 12px; margin: 16px 0; }
.bic-tracker-step {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 14px 16px; background: var(--bic-card); border-radius: var(--bic-radius-sm);
  border-left: 3px solid var(--bic-border);
}
.bic-tracker-step.completed { border-left-color: var(--bic-success); }
.bic-tracker-step.in_progress { border-left-color: var(--bic-warning); }
.bic-tracker-step-dot {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700;
  background: var(--bic-border); color: var(--bic-muted);
}
.bic-tracker-step.completed .bic-tracker-step-dot { background: var(--bic-success); color: #fff; }
.bic-tracker-step.in_progress .bic-tracker-step-dot { background: var(--bic-warning); color: #fff; }
.bic-tracker-step-info strong { font-size: 14px; color: var(--bic-dark); font-weight: 600; }
.bic-tracker-step-info small { font-size: 11px; color: var(--bic-muted); display: block; margin-top: 3px; }
.bic-tracker-support { text-align: center; margin-top: 24px; }
.bic-tracker-support p { color: var(--bic-muted); font-size: 13px; margin-bottom: 12px; }
.bic-tracker-error { background: #fff0f0; border: 1px solid #ffc5c7; border-radius: var(--bic-radius-sm); padding: 16px; color: var(--bic-red); text-align: center; font-size: 14px; }

/* === BADGES === */
.bic-badge { padding: 4px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; text-transform: uppercase; }
.bic-badge-new        { background: #dbeafe; color: #1d4ed8; }
.bic-badge-in_progress{ background: #fef3c7; color: #92400e; }
.bic-badge-completed  { background: #d1fae5; color: #065f46; }
.bic-badge-on_hold    { background: #f3f4f6; color: #374151; }
.bic-badge-cancelled  { background: #fee2e2; color: #991b1b; }

/* Progress bar */
.bic-progress-bar-wrap { height: 8px; background: var(--bic-border); border-radius: 10px; overflow: hidden; margin-bottom: 8px; }
.bic-progress-bar { height: 100%; background: linear-gradient(90deg, var(--bic-red), var(--bic-gold)); transition: width 0.5s ease; }
.bic-progress-text { font-size: 12px; color: var(--bic-muted); }

/* === RESPONSIVE === */
@media (max-width: 600px) {
  .bic-zone-cards { grid-template-columns: 1fr; }
  .bic-options-grid { grid-template-columns: 1fr 1fr; }
  .bic-steps-indicator { gap: 2px; }
  .bic-step-dot-inner { width: 28px; height: 28px; font-size: 11px; }
  .bic-step-dot-outer span { font-size: 9px; }
  .bic-submit-actions { flex-direction: column; }
  .bic-action-btn { width: 100%; justify-content: center; }
}
