/* ===== SOLICITATION PAGE ===== */
.solic-page { padding: 100px 0 40px; min-height: 100vh; background: var(--blue-light); }
.solic-container { max-width: 780px; margin: 0 auto; padding: 0 24px; }

/* Progress bar */
.pbar { height: 4px; background: var(--gray-200); margin-bottom: 32px; border-radius: 2px; overflow: hidden; }
.pbar-fill { height: 100%; background: var(--blue-primary); transition: width 0.5s ease; border-radius: 2px; }

/* Stepper */
.stepper { display: flex; align-items: flex-start; justify-content: center; margin-bottom: 36px; }
.ss { display: flex; flex-direction: column; align-items: center; gap: 6px; flex: 1; position: relative; }
.ss:not(:last-child)::after { content: ''; position: absolute; top: 16px; left: calc(50% + 20px); width: calc(100% - 40px); height: 2px; background: var(--gray-300); }
.ss.done:not(:last-child)::after { background: var(--blue-primary); }
.sc { width: 34px; height: 34px; border-radius: 50%; background: var(--gray-200); color: var(--gray-400); display: flex; align-items: center; justify-content: center; font-size: 0.8rem; font-weight: 700; z-index: 2; border: 2px solid var(--gray-200); transition: all 0.3s; }
.ss.now .sc { background: white; color: var(--blue-primary); border-color: var(--blue-primary); box-shadow: 0 0 0 4px rgba(37,99,235,0.15); }
.ss.done .sc { background: var(--blue-primary); color: white; border-color: var(--blue-primary); }
.sl { font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; color: var(--gray-400); text-align: center; }
.ss.now .sl { color: var(--blue-primary); font-weight: 700; }
.ss.done .sl { color: var(--blue-primary); }

/* Form card */
.fc { background: white; border-radius: var(--radius-lg); padding: 40px 36px; box-shadow: var(--shadow-md); border: 1px solid var(--gray-200); margin-bottom: 24px; }
.fc h2 { font-size: 1.5rem; font-weight: 800; margin-bottom: 6px; }
.fc .fd { color: var(--gray-500); font-size: 0.9rem; margin-bottom: 28px; }
.fc label.fl { display: block; font-weight: 700; font-size: 0.9rem; margin-bottom: 8px; margin-top: 20px; }
.fc label.fl .req { color: #e53e3e; }

/* Text inputs */
.ti { width: 100%; padding: 14px 16px; border: 2px solid var(--gray-200); border-radius: var(--radius); font-family: inherit; font-size: 0.9rem; outline: none; transition: border-color 0.2s; }
.ti:focus { border-color: var(--blue-primary); }
.ti::placeholder { color: var(--gray-400); }
textarea.ti { min-height: 80px; resize: vertical; }
select.ti { appearance: auto; cursor: pointer; }
.warn-box { background: #fef3cd; border: 1px solid #ffc107; border-radius: var(--radius); padding: 14px 18px; font-size: 0.85rem; color: #856404; margin-bottom: 20px; line-height: 1.6; }
.warn-box strong { color: #664d03; }

/* Checkbox */
.cb { width: 22px; height: 22px; border-radius: 5px; border: 2px solid var(--gray-300); display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: white; transition: all 0.2s; cursor: pointer; }
.cb.sel { background: var(--blue-primary); border-color: var(--blue-primary); }
.cb.sel::after { content: '✓'; color: white; font-size: 0.75rem; font-weight: 700; }

/* Step 1 - Symptom options */
.sym-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.sym-opt { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border: 2px solid var(--gray-200); border-radius: var(--radius); cursor: pointer; transition: all 0.25s; font-size: 0.95rem; font-weight: 600; }
.sym-opt:hover { border-color: var(--green-muted); background: var(--green-light); }
.sym-opt.sel { border-color: var(--green-primary); background: var(--green-light); }
.sym-icon { width: 36px; height: 36px; border-radius: 10px; background: var(--gray-100); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 1.1rem; }
.sym-opt.sel .sym-icon { background: var(--green-muted); }

/* Step 2 - Radio options */
.rad-list { display: flex; flex-direction: column; gap: 12px; }
.rad-opt { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border: 2px solid var(--gray-200); border-radius: var(--radius); cursor: pointer; transition: all 0.2s; font-weight: 600; font-size: 0.95rem; }
.rad-opt:hover { border-color: var(--blue-muted); background: var(--blue-light); }
.rad-opt.sel { border-color: var(--blue-primary); background: var(--blue-light); }
.rad-dot { width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--gray-300); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rad-opt.sel .rad-dot { border-color: var(--blue-primary); }
.rad-opt.sel .rad-dot::after { content: ''; width: 12px; height: 12px; border-radius: 50%; background: var(--blue-primary); }

/* Step 3 - Checkbox options */
.chk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.chk-opt { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 2px solid var(--gray-200); border-radius: var(--radius); cursor: pointer; transition: all 0.2s; font-size: 0.9rem; font-weight: 500; }
.chk-opt:hover { border-color: var(--blue-muted); }
.chk-opt.sel { border-color: var(--blue-primary); background: var(--blue-light); }
.chk-opt.sel .cb { background: var(--blue-primary); border-color: var(--blue-primary); }
.chk-opt.sel .cb::after { content: '✓'; color: white; font-size: 0.7rem; font-weight: 700; }

/* Step 4 - Date & Days */
.date-badge { display: inline-block; padding: 6px 16px; background: var(--blue-light); color: var(--blue-primary); border-radius: var(--radius-full); font-weight: 700; font-size: 0.85rem; margin-bottom: 12px; border: 1px solid var(--blue-muted); }
.d-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 8px; }
.d-opt { padding: 12px; text-align: center; border: 2px solid var(--gray-200); border-radius: var(--radius); cursor: pointer; font-weight: 600; font-size: 0.9rem; transition: all 0.2s; }
.d-opt:hover { border-color: var(--blue-muted); }
.d-opt.sel { border-color: var(--blue-primary); background: var(--blue-primary); color: white; }
.cal-input { width: 100%; padding: 12px 16px; border: 2px solid var(--blue-primary); border-radius: var(--radius); font-family: inherit; font-size: 0.95rem; color: var(--dark); outline: none; margin-top: 10px; margin-bottom: 8px; cursor: pointer; background: var(--blue-light); font-weight: 600; }
.cal-input::-webkit-calendar-picker-indicator { cursor: pointer; }
.day-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 8px; }
.day-opt { display: flex; justify-content: space-between; align-items: center; padding: 14px 16px; border: 2px solid var(--gray-200); border-radius: var(--radius); cursor: pointer; font-weight: 600; font-size: 0.9rem; transition: all 0.2s; }
.day-opt:hover { border-color: var(--blue-muted); }
.day-opt.sel { border-color: var(--blue-primary); background: var(--blue-light); }
.day-opt .pr { color: var(--blue-primary); font-weight: 700; font-size: 0.85rem; }
.note { font-size: 0.8rem; color: var(--gray-400); margin-bottom: 24px; }

/* Step 4 - Hospital */
.h-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.h-opt { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 20px 12px; border: 2px solid var(--gray-200); border-radius: var(--radius); cursor: pointer; transition: all 0.2s; min-height: 80px; background: white; }
.h-opt:hover { border-color: var(--blue-muted); }
.h-opt.sel { border-color: var(--blue-primary); background: var(--blue-light); }
.h-opt img { max-width: 100px; max-height: 45px; object-fit: contain; }
.h-opt .hn { font-size: 0.8rem; color: var(--gray-500); text-align: center; }

/* Step 6 - Addons */
.addon-list { display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.addon { display: flex; align-items: flex-start; gap: 14px; padding: 16px 18px; border: 2px solid var(--gray-200); border-radius: var(--radius); cursor: pointer; transition: all 0.2s; }
.addon:hover { border-color: var(--blue-muted); }
.addon.sel { border-color: var(--blue-primary); background: var(--blue-light); }
.addon-info { flex: 1; }
.addon-info h4 { font-size: 0.95rem; font-weight: 700; margin-bottom: 2px; display: flex; align-items: center; gap: 8px; }
.addon-info h4 .bg { background: var(--green-accent); color: white; font-size: 0.65rem; padding: 2px 8px; border-radius: var(--radius-full); font-weight: 700; }
.addon-info p { font-size: 0.8rem; color: var(--gray-500); }
.addon-pr { font-weight: 700; font-size: 0.9rem; color: var(--gray-600); white-space: nowrap; }

/* Step 6 - Preview */
.prev-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--gray-400); margin-bottom: 8px; }
.prev-card { border: 1px solid var(--gray-200); border-radius: var(--radius); overflow: hidden; margin-bottom: 20px; }
.prev-hd { background: var(--blue-primary); color: white; padding: 12px 20px; display: flex; justify-content: space-between; align-items: center; font-weight: 700; font-size: 0.85rem; }
.prev-hd .hb { background: rgba(255,255,255,0.2); padding: 4px 12px; border-radius: var(--radius-full); font-size: 0.75rem; }
.prev-body { padding: 24px 20px; font-size: 0.85rem; color: var(--gray-600); line-height: 1.8; font-family: 'Courier New', monospace; }
.prev-body strong { color: var(--dark); }
.prev-sig { text-align: center; color: var(--gray-400); font-size: 0.8rem; margin-top: 16px; padding-top: 16px; border-top: 2px dashed var(--gray-200); }
.prev-warn { display: flex; align-items: flex-start; gap: 8px; background: #fff3cd; border: 1px solid #ffc107; border-radius: 8px; padding: 12px 16px; font-size: 0.8rem; color: #856404; margin-bottom: 20px; }
.total-bar { background: var(--blue-primary); color: white; padding: 16px 24px; border-radius: var(--radius); display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; font-weight: 700; }
.total-bar .ta { font-size: 1.4rem; }
.info-box { display: flex; align-items: flex-start; gap: 10px; padding: 14px 18px; border: 1px solid var(--gray-200); border-radius: var(--radius); margin-bottom: 12px; font-size: 0.85rem; color: var(--gray-600); }
.info-box svg { width: 20px; height: 20px; color: var(--blue-primary); flex-shrink: 0; margin-top: 2px; }
.info-box strong { color: var(--dark); }
.pix-box { background: var(--blue-primary); color: white; padding: 14px 18px; border-radius: var(--radius); margin-bottom: 16px; }
.pix-box strong { display: block; font-size: 1rem; }
.pix-box span { font-size: 0.85rem; opacity: 0.85; }
.terms-chk { display: flex; align-items: flex-start; gap: 10px; margin: 16px 0; font-size: 0.85rem; color: var(--gray-600); cursor: pointer; }
.terms-chk a { color: var(--blue-primary); }
.terms-txt { font-size: 0.8rem; color: var(--gray-400); line-height: 1.7; margin-bottom: 20px; }

/* Step 7 - Payment */
.qr-wrap { text-align: center; padding: 20px; }
.qr-img { max-width: 220px; margin: 0 auto 12px; }
.qr-img img { width: 100%; height: auto; border-radius: 8px; }
.qr-ph { width: 200px; height: 200px; margin: 0 auto 12px; background: var(--gray-100); border: 2px dashed var(--gray-300); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; }
.qr-note { font-size: 0.8rem; color: var(--gray-400); }
.pix-code { padding: 12px 14px; background: var(--gray-100); border: 1px solid var(--gray-200); border-radius: 8px; font-size: 0.75rem; font-family: monospace; color: var(--gray-500); word-break: break-all; margin: 12px 0; }
.btn-copy { width: 100%; padding: 14px; background: var(--green-accent); color: white; border: none; border-radius: var(--radius); font-weight: 700; font-size: 1rem; cursor: pointer; font-family: inherit; display: flex; align-items: center; justify-content: center; gap: 8px; }
.btn-copy:hover { background: var(--green-primary); }
.upload-box { border: 1px solid var(--gray-200); border-radius: var(--radius); padding: 16px; margin-top: 16px; }
.upload-box h4 { font-size: 0.9rem; font-weight: 700; margin-bottom: 4px; }
.upload-box p { font-size: 0.8rem; color: var(--gray-500); margin-bottom: 12px; }
.upload-btn { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px; border: 2px dashed var(--gray-300); border-radius: 8px; color: var(--gray-400); font-size: 0.85rem; cursor: pointer; }
.btn-confirm { width: 100%; padding: 16px; background: var(--green-accent); color: white; border: none; border-radius: var(--radius); font-weight: 700; font-size: 1.05rem; cursor: pointer; font-family: inherit; display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 16px; }
.btn-confirm:hover { background: var(--green-primary); }
.paid-screen { text-align: center; padding: 40px 20px; }
.paid-screen .check-circle { width: 80px; height: 80px; border-radius: 50%; background: var(--green-accent); color: white; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; font-size: 2rem; }
.paid-screen h2 { color: var(--green-primary); margin-bottom: 8px; }

/* Form actions */
.fa { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; }
.fb { display: inline-flex; align-items: center; gap: 6px; color: var(--gray-400); font-size: 0.9rem; cursor: pointer; background: none; border: 1px solid var(--gray-200); font-family: inherit; padding: 10px 16px; border-radius: var(--radius); font-weight: 500; }
.fb:hover { color: var(--gray-600); }
.fb svg { width: 16px; height: 16px; }
.fn { display: inline-flex; align-items: center; gap: 8px; background: var(--gray-300); color: var(--gray-500); padding: 12px 32px; border-radius: var(--radius); font-weight: 700; font-size: 0.95rem; border: none; cursor: not-allowed; font-family: inherit; transition: all 0.3s; }
.fn.ok { background: var(--blue-primary); color: white; cursor: pointer; }
.fn.ok:hover { background: var(--blue-dark); }
.tr { display: flex; justify-content: center; gap: 28px; flex-wrap: wrap; }
.tri { display: flex; align-items: center; gap: 6px; color: var(--gray-400); font-size: 0.8rem; }
.tri svg { width: 16px; height: 16px; }

/* CPF status */
.cpf-loading { display: inline-block; width: 14px; height: 14px; border: 2px solid var(--gray-300); border-radius: 50%; border-top-color: var(--blue-primary); animation: spin 0.8s linear infinite; margin-left: 8px; vertical-align: middle; }
.cpf-ok { color: var(--green-accent); font-weight: 700; margin-left: 8px; font-size: 0.85rem; }

/* Responsive */
@media (max-width: 968px) {
  .sym-grid, .chk-grid, .d-grid, .day-grid, .h-grid { grid-template-columns: 1fr; }
  .sl { font-size: 0.55rem; }
}
@media (max-width: 640px) {
  .fc { padding: 28px 20px; }
  .stepper { overflow-x: auto; }
}
