/* ===== Appointment Page ===== */

.form-progress-wrap{background:#fff;border-bottom:1px solid #eee;padding:20px 0}
.progress-bar-track{height:4px;background:#e2e8f0;border-radius:2px;margin-bottom:16px;overflow:hidden}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--blue));border-radius:2px;width:14.28%;transition:width .4s ease}
.progress-steps{display:flex;justify-content:space-between}
.progress-step{font-size:12px;font-weight:500;color:var(--text-light);display:flex;align-items:center;gap:6px}
.progress-step span{width:24px;height:24px;border-radius:50%;background:#e2e8f0;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:var(--text-light);transition:all .3s}
.progress-step.active span{background:var(--navy);color:#fff}
.progress-step.active{color:var(--navy);font-weight:600}
.progress-step.completed span{background:var(--blue);color:#fff}
.progress-step.completed{color:var(--blue)}

.intake-section{background:#f8fbff;padding:48px 0 80px;min-height:70vh}
.intake-form-wrap{max-width:680px;margin:0 auto;background:#fff;border-radius:24px;padding:48px;box-shadow:0 8px 32px rgba(11,31,59,.06)}

.form-step{display:none}
.form-step.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.step-header{margin-bottom:32px}
.step-header h2{font-size:26px;font-weight:700;margin-bottom:8px}
.step-header p{color:var(--text-muted);font-size:15px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-grid .full-width{grid-column:1/-1}
.form-stack{display:flex;flex-direction:column;gap:20px}

.form-group label{display:block;font-weight:600;font-size:14px;color:var(--navy);margin-bottom:6px}
.form-group input[type="text"],.form-group input[type="email"],.form-group input[type="tel"],.form-group input[type="date"],.form-group input[type="number"],.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;font-family:'Inter',sans-serif;color:var(--text-dark);transition:border-color .2s,box-shadow .2s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(77,181,212,.15)}
.form-group input.invalid,.form-group select.invalid{border-color:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.1)}
.height-inputs{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.checkbox-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.checkbox-label,.radio-label{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f8fbff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;font-size:14px;transition:all .2s}
.checkbox-label:hover,.radio-label:hover{border-color:var(--blue);background:#f0f7ff}
.radio-group{display:flex;gap:12px;flex-wrap:wrap}

.treatment-options{display:flex;flex-direction:column;gap:16px}
.treatment-card{display:block;position:relative;border:2px solid #e2e8f0;border-radius:20px;padding:28px;cursor:pointer;transition:all .3s}
.treatment-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(11,31,59,.08)}
.treatment-card input[type="radio"]{position:absolute;top:20px;right:20px;width:20px;height:20px;accent-color:var(--blue)}
.treatment-card:has(input:checked){border-color:var(--blue);background:#f0f9ff;box-shadow:0 4px 16px rgba(77,181,212,.15)}
.treatment-tag{display:inline-block;background:var(--gold);color:#fff;font-size:11px;font-weight:700;letter-spacing:1px;padding:4px 12px;border-radius:4px;margin-bottom:8px}
.treatment-content h3{font-size:20px;margin-bottom:4px}
.treatment-price{font-family:'Poppins',sans-serif;font-size:28px;font-weight:700;color:var(--navy);margin-bottom:8px}
.treatment-price span{font-size:14px;color:var(--text-muted);font-weight:500}
.treatment-content p{color:var(--text-muted);font-size:14px;margin-bottom:12px}
.treatment-content ul{list-style:none;padding:0;margin:0}
.treatment-content li{font-size:14px;color:var(--text-muted);padding:4px 0 4px 20px;position:relative}
.treatment-content li::before{content:'\2713';position:absolute;left:0;color:var(--blue);font-weight:700}

.upload-area{border:2px dashed #cbd5e0;border-radius:20px;padding:48px 28px;text-align:center;cursor:pointer;transition:all .3s;color:var(--text-muted)}
.upload-area:hover{border-color:var(--blue);background:#f0f7ff}
.upload-area.dragover{border-color:var(--cyan);background:rgba(59,255,243,.05)}
.upload-area svg{color:var(--blue);margin-bottom:12px}
.upload-area p{margin:0 0 6px;font-size:16px}
.upload-area span{font-size:13px;color:var(--text-light)}
.upload-preview{display:flex;align-items:center;justify-content:space-between;background:#f0f9ff;padding:12px 16px;border-radius:12px;border:1px solid var(--blue)}
.upload-filename{font-weight:500;font-size:14px;color:var(--navy)}
.upload-remove{background:none;border:none;color:#ef4444;cursor:pointer;font-weight:600;font-size:14px}

.trust-note{display:flex;align-items:flex-start;gap:12px;background:#f8fbff;padding:16px 20px;border-radius:12px;border:1px solid #e2e8f0}
.trust-note svg{flex-shrink:0;color:var(--blue);margin-top:2px}
.trust-note p{font-size:13px;color:var(--text-muted);margin:0;line-height:1.6}
.schedule-note{background:#fffbeb;padding:16px 20px;border-radius:12px;border:1px solid #fde68a}
.schedule-note p{font-size:14px;color:#92400e;margin:0}

.review-summary{background:#f8fbff;border-radius:16px;padding:24px;border:1px solid #e2e8f0}
.review-summary h4{font-size:16px;margin-bottom:12px}
.review-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #eee;font-size:14px}
.review-row:last-child{border-bottom:none}
.review-label{color:var(--text-muted)}
.review-value{font-weight:600;color:var(--navy)}

.consent-group{display:flex;flex-direction:column;gap:12px}
.consent-group .checkbox-label{background:#fff;font-size:13px;line-height:1.5;align-items:flex-start}
.consent-group .checkbox-label input{margin-top:3px;flex-shrink:0}
.consent-group a{color:var(--blue);text-decoration:underline}

.payment-note{display:flex;align-items:flex-start;gap:14px;background:#f0fdf4;padding:20px 24px;border-radius:12px;border:1px solid #bbf7d0}
.payment-note svg{flex-shrink:0;color:#22c55e;margin-top:2px}
.payment-note strong{color:#166534;font-size:15px;display:block;margin-bottom:4px}
.payment-note p{font-size:13px;color:#166534;margin:0}

.step-actions{display:flex;justify-content:space-between;margin-top:36px;gap:16px}
.btn-next,.btn-submit{background:var(--cyan);color:var(--navy);border:none;padding:14px 36px;border-radius:60px;font-weight:700;font-size:16px;cursor:pointer;transition:all .3s;margin-left:auto}
.btn-next:hover,.btn-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(59,255,243,.3)}
.btn-submit{background:var(--navy);color:#fff;padding:16px 40px;font-size:17px}
.btn-submit:hover{background:var(--navy-mid);box-shadow:0 8px 24px rgba(11,31,59,.3)}
.btn-back{background:transparent;color:var(--text-muted);border:2px solid #e2e8f0;padding:14px 28px;border-radius:60px;font-weight:600;font-size:15px;cursor:pointer;transition:all .2s}
.btn-back:hover{border-color:var(--navy);color:var(--navy)}

@media(max-width:768px){
  .intake-form-wrap{padding:28px 20px}
  .form-grid{grid-template-columns:1fr}
  .checkbox-grid{grid-template-columns:1fr}
  .progress-steps{gap:4px;font-size:10px}
  .progress-step span{width:20px;height:20px;font-size:10px}
}
@media(max-width:480px){
  .progress-step{font-size:0}
  .progress-step span{font-size:11px}
  .step-actions{flex-direction:column-reverse}
  .btn-next,.btn-submit{margin-left:0;width:100%}
  .btn-back{width:100%;text-align:center}
  .radio-group{flex-direction:column}
}
