/* ==============================================
   CHECKFRONT BOOKING WIDGET
   Uses site CSS variables from style.css
   ============================================== */

.cf-widget {
  margin-top: 1rem;
}

/* --- Steps --- */
.cf-step {
  animation: cf-fade-in .25s ease;
}

.cf-hidden {
  display: none !important;
}

@keyframes cf-fade-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --- Step header label --- */
.cf-step-header {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--heading-font);
  font-size: .85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--primary-color);
  margin-bottom: .85rem;
}

/* --- Date row --- */
.cf-date-row {
  display: flex;
  gap: .75rem;
  align-items: flex-end;
  flex-wrap: wrap;
}

.cf-date-row .cta-button {
  flex-shrink: 0;
  white-space: nowrap;
}

/* --- Form fields --- */
.cf-field {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

.cf-field label {
  font-size: .8rem;
  font-weight: 600;
  color: var(--muted-text-color);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.cf-field input,
.cf-field textarea {
  width: 100%;
  padding: .65rem .85rem;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--card-bg-color);
  color: var(--text-color);
  font-family: var(--body-font);
  font-size: .95rem;
  transition: border-color .2s, box-shadow .2s;
}

.cf-field input:focus,
.cf-field textarea:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(243, 156, 18, .15);
}

.cf-field textarea {
  resize: vertical;
  min-height: 72px;
}

.cf-req {
  color: var(--dramatic-red);
}

/* --- Form grid --- */
.cf-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  margin: 1rem 0;
}

.cf-field-full {
  grid-column: 1 / -1;
}

@media (max-width: 520px) {
  .cf-form-grid {
    grid-template-columns: 1fr;
  }
  .cf-date-row {
    flex-direction: column;
    align-items: stretch;
  }
  .cf-date-row .cf-field {
    width: 100%;
  }
  .cf-date-row .cta-button {
    width: 100%;
    justify-content: center;
  }
}

/* --- Availability badge --- */
.cf-avail-badge {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
  padding: .6rem .85rem;
  background: rgba(46, 204, 113, .1);
  border: 1.5px solid rgba(46, 204, 113, .3);
  border-radius: var(--radius-sm);
  font-size: .9rem;
  font-weight: 600;
  color: var(--success-color);
  margin-bottom: .25rem;
}

.cf-avail-badge i {
  font-size: 1rem;
}

.cf-price-tag {
  margin-left: auto;
  background: var(--accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: var(--heading-font);
  font-size: 1.1rem;
  font-weight: 700;
}

/* --- Policy checkbox --- */
.cf-policy-label {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  font-size: .85rem;
  color: var(--muted-text-color);
  cursor: pointer;
  line-height: 1.4;
  margin-bottom: .75rem;
}

.cf-policy-label input[type="checkbox"] {
  margin-top: .15rem;
  flex-shrink: 0;
  accent-color: var(--primary-color);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.cf-policy-label a {
  color: var(--primary-color);
  text-decoration: underline;
}

/* --- Form actions row --- */
.cf-form-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: .6rem;
}

/* --- Back button --- */
.cf-back-btn {
  background: none;
  border: none;
  color: var(--muted-text-color);
  font-size: .85rem;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  gap: .35rem;
  transition: color .2s;
}

.cf-back-btn:hover {
  color: var(--primary-color);
}

/* --- Weekday discount note --- */
.cf-weekday-note {
  font-size: .85rem;
  font-weight: 600;
  color: #27ae60;
  display: flex;
  align-items: center;
  gap: .45rem;
  margin: .5rem 0 .25rem;
  padding: .5rem .75rem;
  background: rgba(39, 174, 96, .08);
  border: 1px solid rgba(39, 174, 96, .25);
  border-radius: var(--radius-sm);
}

.cf-weekday-note i {
  flex-shrink: 0;
}

.dark-mode .cf-weekday-note {
  color: #2ecc71;
  background: rgba(46, 204, 113, .1);
  border-color: rgba(46, 204, 113, .25);
}

/* --- Handoff note --- */
.cf-handoff-note {
  font-size: .88rem;
  color: var(--muted-text-color);
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  line-height: 1.5;
  margin: .75rem 0;
  padding: .65rem .85rem;
  background: rgba(243, 156, 18, .06);
  border: 1px solid rgba(243, 156, 18, .2);
  border-radius: var(--radius-sm);
}

.cf-handoff-note i {
  color: var(--primary-color);
  margin-top: .15rem;
  flex-shrink: 0;
}

/* --- Deposit note --- */
.cf-deposit-note {
  font-size: .78rem;
  color: var(--muted-text-color);
  display: flex;
  align-items: flex-start;
  gap: .4rem;
  line-height: 1.4;
}

.cf-deposit-note i {
  color: var(--primary-color);
  margin-top: .1rem;
  flex-shrink: 0;
}

/* --- Messages --- */
.cf-message {
  font-size: .85rem;
  margin-top: .5rem;
  padding: .5rem .75rem;
  border-radius: var(--radius-sm);
  display: none;
}

.cf-message:not(:empty) {
  display: block;
}

.cf-msg-error {
  background: rgba(231, 76, 60, .1);
  border: 1px solid rgba(231, 76, 60, .3);
  color: var(--dramatic-red);
}

.cf-msg-info {
  background: rgba(243, 156, 18, .1);
  border: 1px solid rgba(243, 156, 18, .3);
  color: var(--primary-color);
}

/* --- Success state --- */
.cf-success {
  text-align: center;
  padding: 2rem 1rem;
  background: var(--card-bg-color);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius);
}

.cf-success-icon {
  font-size: 2.5rem;
  background: var(--accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: .75rem;
}

.cf-success h3 {
  font-family: var(--heading-font);
  font-size: 1.3rem;
  margin-bottom: .5rem;
  color: var(--text-color);
}

.cf-success p {
  color: var(--muted-text-color);
  font-size: .9rem;
  margin-bottom: .25rem;
}

.cf-ref-line {
  margin-top: .5rem;
  font-size: .85rem;
  color: var(--muted-text-color);
}

/* --- Dark mode adjustments --- */
body.dark-mode .cf-field input,
body.dark-mode .cf-field textarea {
  background: #1e1e1e;
  border-color: var(--border-color);
  color: var(--text-color);
}

body.dark-mode .cf-success {
  background: var(--card-bg-color);
  border-color: var(--border-color);
}
