/* ═══════════════════════════════════════════════════════════
   VERA ZAMBRANO & ASSOCIATES — Consultation Form
   High-end European editorial aesthetic · WCAG 2.2
═══════════════════════════════════════════════════════════ */


/* ─── CUSTOM PROPERTIES ──────────────────────────────────── */
.vzc-form-wrap {
  --color-form-primary:      #3A3F5C;
  --color-form-primary-dk:   #2a2e44;
  --color-form-secondary:    #B8A1B0;
  --color-form-accent:       #C8B27D;
  --color-form-accent-dk:    #a8945f;
  --color-form-bg:           #F8F6F4;
  --color-form-bg-warm:      #F2EDEA;
  --color-form-white:        #ffffff;
  --color-form-text:         #5F6472;
  --color-form-text-dk:      #2E3144;
  --color-form-text-lt:      #7a7f8e;
  --color-form-border:       #ddd8d4;
  --color-form-border-lt:    #ede9e6;
  --color-form-error:        #7d2a2a;
  --color-form-error-bg:     #fdf3f3;
  --color-form-success:      #2E6B4F;
  --color-form-vera:         #3A3F5C;
  --color-form-assoc:        #B8A1B0;
  --color-form-booked:       #d9cfc9;

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Inter', system-ui, sans-serif;

  --panel-w: 340px;
  --radius:   6px;
  --radius-md:10px;
  --radius-lg:14px;

  --shadow-sm: 0 1px 4px rgba(58,63,92,.07);
  --shadow-md: 0 4px 16px rgba(58,63,92,.11);
  --shadow-lg: 0 12px 36px rgba(58,63,92,.13);

  --ease: 250ms ease;
  --ease-slow: 380ms cubic-bezier(.4,0,.2,1);
}

/* ─── RESET ───────────────────────────────────────────────── */
.vzc-form-wrap,.vzc-form-wrap *,.vzc-form-wrap *::before,.vzc-form-wrap *::after{box-sizing:border-box;margin:0;padding:0}
.vzc-form-wrap{
  font-family:var(--font-body);
  font-size:.9375rem;
  line-height:1.65;
  color:var(--color-form-text);
  background:var(--color-form-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  min-height:100vh;
}
.vzc-form-wrap .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ─── FOCUS ───────────────────────────────────────────────── */
.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px;border-radius:3px}

/* ═══════════════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════════════ */
.page-wrapper{
  display:grid;
  grid-template-columns:var(--panel-w) 1fr;
  min-height:100vh;
}

/* ═══════════════════════════════════════════════════════════
   LEFT PANEL
═══════════════════════════════════════════════════════════ */
.panel-left{
  position:sticky;top:0;
  background:var(--color-form-primary);
  overflow:hidden;z-index:10;
}
.panel-left__bg{position:absolute;inset:0;pointer-events:none}
.bg-orb{position:absolute;border-radius:50%}
.bg-orb--1{width:420px;height:420px;background:radial-gradient(circle,rgba(200,178,125,.11) 0%,transparent 70%);top:-80px;right:-130px}
.bg-orb--2{width:260px;height:260px;background:radial-gradient(circle,rgba(184,161,176,.09) 0%,transparent 70%);bottom:80px;left:-50px}
.bg-circle{position:absolute;width:160px;height:160px;border:1px solid rgba(200,178,125,.13);border-radius:50%;bottom:130px;right:-44px}
.bg-line{position:absolute;width:1px;height:200px;background:linear-gradient(to bottom,transparent,rgba(200,178,125,.18),transparent);top:50%;left:50%;transform:translate(-50%,-50%)}

.panel-left__inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;
  height:100%;padding:2rem 1.75rem;
  gap:0;
}

/* Logo */
.firm-logo{
  width:100%;
  display:block;
  margin:0 0 2.25rem;
  padding:0 .15rem;
}
.firm-logo__img{
  width:100%;
  max-width:260px;
  height:auto;
  display:block;
  object-fit:contain;
  filter:brightness(1.1);
}

/* Step Nav */
.step-nav{margin-bottom:auto}
.step-nav__list{list-style:none;display:flex;flex-direction:column}
.step-nav__item{position:relative}
.step-nav__item:not(:last-child)::after{
  content:'';display:block;width:1px;height:22px;
  background:rgba(255,255,255,.14);margin-left:14px;
}
.step-nav__btn{
  display:flex;align-items:center;gap:12px;
  padding:7px 0;background:none;border:none;cursor:pointer;
  width:100%;text-align:left;color:rgba(255,255,255,.38);
  transition:color var(--ease);
}
.step-nav__btn:hover{color:rgba(255,255,255,.65)}
.step-nav__btn.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px;border-radius:4px}

.step-nav__indicator{
  flex-shrink:0;width:28px;height:28px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.18);
  display:grid;place-items:center;
  transition:all var(--ease);position:relative;
}
.step-nav__num{font-size:.7rem;font-weight:600;transition:opacity 150ms}
.step-nav__tick{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity 150ms}
.step-nav__label{font-size:.8rem;font-weight:400;letter-spacing:.01em;transition:font-weight 150ms}

/* ═══ BASE TICK RULE — replace the old one ═══ */
.step-nav__tick{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  opacity:0;
  transition:opacity 150ms;
}

/* ═══ ACTIVE — now uses the muted "complete" look ═══ */
.step-nav__item[data-state="active"] .step-nav__btn{
  color:rgba(255,255,255,.6);
}
.step-nav__item[data-state="active"] .step-nav__indicator{
  border-color:var(--color-form-accent);
  background:rgba(200,178,125,.16);
  color:var(--color-form-accent);
}
/* number stays visible (no opacity rule), label not bold */
.step-nav__item[data-state="active"] .step-nav__label{
  font-weight:400;
}

/* ═══ COMPLETE — now uses the bold "active" look ═══ */
.step-nav__item[data-state="complete"] .step-nav__btn{
  color:#fff;
}
.step-nav__item[data-state="complete"] .step-nav__indicator{
  border-color:var(--color-form-accent);
  background:var(--color-form-accent);
  color:var(--color-form-primary);   /* dark tick on gold bg */
}
.step-nav__item[data-state="complete"] .step-nav__label{
  font-weight:600;
}
/* content swap: hide number, show tick */
.step-nav__item[data-state="complete"] .step-nav__num{
  opacity:0;
}
.step-nav__item[data-state="complete"] .step-nav__tick{
  opacity:1;
}

/* Panel Copy */
.panel-copy{margin-top:2rem;margin-bottom:1.5rem}
.panel-copy__item{animation:fadeUp .38s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.panel-copy__eyebrow{font-size:.65rem;font-weight:600;color:var(--color-form-accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.panel-copy__heading{font-family:var(--font-display);font-size:1.35rem;font-weight:500;font-style:italic;color:#fff;line-height:1.35;margin-bottom:12px}
.panel-copy__body{font-size:.78rem;line-height:1.7;color:rgba(255,255,255,.5)}

/* Firm Contact */
.panel-contact{margin-top:auto;margin-bottom:1rem;display:flex;flex-direction:column;gap:6px}
.panel-contact__row{display:flex;align-items:center;gap:7px;font-size:.72rem;color:rgba(255,255,255,.42)}
.panel-contact__row svg{flex-shrink:0;opacity:.7}

/* Confidentiality Badge */
.confidentiality-badge{
  display:flex;align-items:center;gap:7px;
  padding:9px 12px;
  background:rgba(200,178,125,.08);
  border:1px solid rgba(200,178,125,.18);
  border-radius:var(--radius);
  font-size:.65rem;font-weight:500;
  color:rgba(255,255,255,.45);letter-spacing:.04em;
}

/* ═══════════════════════════════════════════════════════════
   RIGHT PANEL
═══════════════════════════════════════════════════════════ */
.panel-right{
  display:flex;flex-direction:column;
  background:var(--color-form-bg);min-height:100vh;
}

/* Progress Bar */
.progress-bar{
  display:flex;align-items:center;gap:1rem;
  padding:1.1rem 2rem;
  border-bottom:1px solid var(--color-form-border-lt);
  background:var(--color-form-white);
}
.progress-bar__track{flex:1;height:3px;background:var(--color-form-border);border-radius:99px;overflow:hidden}
.progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--color-form-accent-dk),var(--color-form-accent));border-radius:99px;width:20%;transition:width var(--ease-slow)}
.progress-bar__label{font-size:.73rem;font-weight:500;color:var(--color-form-text-lt);white-space:nowrap;letter-spacing:.02em}

/* Form Viewport */
.form-viewport{flex:1;padding:2rem 2.25rem 1.5rem;width:96%}

/* ─── FORM STEP ───────────────────────────────────────────── */
.form-step{border:none;padding:0;animation:stepIn .32s cubic-bezier(.4,0,.2,1) both}
@keyframes stepIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:translateX(0)}}

.form-step__legend{display:block;width:100%;margin-bottom:1.75rem}
.form-step__eyebrow{display:block;font-size:.65rem;font-weight:600;color:var(--color-form-accent-dk);letter-spacing:.12em;text-transform:uppercase;margin-bottom:7px}
.form-step__title{display:block;font-family:var(--font-display);font-size:1.8rem;font-weight:500;color:var(--color-form-text-dk);line-height:1.28}

/* ═══════════════════════════════════════════════════════════
   STEP 1 — PRACTICE CARDS
═══════════════════════════════════════════════════════════ */
.practice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:10px;margin-bottom:.75rem}

.pcard{position:relative;display:block;cursor:pointer}
.pcard__body{
  display:flex;flex-direction:column;gap:5px;
  padding:16px 14px;
  border:1.5px solid var(--color-form-border);
  border-radius:var(--radius-md);
  background:var(--color-form-white);
  transition:all var(--ease);height:100%;
}
.pcard:hover .pcard__body{border-color:var(--color-form-secondary);background:var(--color-form-bg);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.pcard__icon{color:var(--color-form-secondary);margin-bottom:3px;transition:color var(--ease)}
.pcard__title{font-size:.84rem;font-weight:600;color:var(--color-form-text-dk);line-height:1.3}
.pcard__desc{font-size:.72rem;color:var(--color-form-text-lt);line-height:1.45}
.pcard__check{
  position:absolute;top:9px;right:9px;
  width:21px;height:21px;border-radius:50%;
  background:var(--color-form-accent);color:#fff;
  display:grid;place-items:center;
  opacity:0;transform:scale(.6);
  transition:all var(--ease);
}
.pcard input:checked~.pcard__body{
  border-color:var(--color-form-accent);
  background:linear-gradient(135deg,rgba(200,178,125,.07),rgba(200,178,125,.02));
  box-shadow:0 0 0 3px rgba(200,178,125,.14);
}
.pcard input:checked~.pcard__body .pcard__icon{color:var(--color-form-accent-dk)}
.pcard input:checked~.pcard__check{opacity:1;transform:scale(1)}
.pcard input:focus-visible~.pcard__body{outline:2px solid var(--color-form-accent);outline-offset:2px}

/* ═══════════════════════════════════════════════════════════
   FORM FIELDS
═══════════════════════════════════════════════════════════ */
.field-group{margin-bottom:1.25rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}

.field-label{display:block;font-size:.8rem;font-weight:600;color:var(--color-form-text-dk);letter-spacing:.01em;margin-bottom:7px}
.req{color:var(--color-form-accent-dk);font-weight:400;margin-left:1px}

.field-wrap{position:relative}
.field-wrap--icon .field-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--color-form-secondary);pointer-events:none}

.field-input{
  width:100%;height:46px;padding:0 13px;
  font-family:var(--font-body);font-size:.9rem;
  color:var(--color-form-text-dk);background:var(--color-form-white);
  border:1.5px solid var(--color-form-border);border-radius:var(--radius);
  transition:border-color 150ms,box-shadow 150ms;
  appearance:none;-webkit-appearance:none;
}
.field-input--icon{padding-left:40px}
.field-input::placeholder{color:var(--color-form-text-lt);font-weight:300}
.field-input:hover{border-color:var(--color-form-secondary)}
.field-input:focus{outline:none;border-color:var(--color-form-accent);box-shadow:0 0 0 3px rgba(200,178,125,.17)}
.field-input[aria-invalid="true"]{border-color:var(--color-form-error);box-shadow:0 0 0 3px rgba(125,42,42,.09)}
.field-input.is-valid{border-color:#4a9e74}

/* Select */
.field-select-wrap{position:relative}
.field-select{
  width:100%;height:46px;padding:0 36px 0 13px;
  font-family:var(--font-body);font-size:.9rem;
  color:var(--color-form-text-dk);background:var(--color-form-white);
  border:1.5px solid var(--color-form-border);border-radius:var(--radius);
  appearance:none;-webkit-appearance:none;cursor:pointer;
  transition:border-color 150ms,box-shadow 150ms;
}
.field-select:hover{border-color:var(--color-form-secondary)}
.field-select:focus{outline:none;border-color:var(--color-form-accent);box-shadow:0 0 0 3px rgba(200,178,125,.17)}
.field-select[aria-invalid="true"]{border-color:var(--color-form-error)}
.field-select.is-valid{border-color:#4a9e74}
.select-caret{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--color-form-secondary);pointer-events:none}

/* Textarea */
.field-textarea-wrap{position:relative}
.field-textarea{
  width:100%;padding:11px 13px;
  font-family:var(--font-body);font-size:.9rem;
  color:var(--color-form-text-dk);background:var(--color-form-white);
  border:1.5px solid var(--color-form-border);border-radius:var(--radius);
  resize:vertical;min-height:124px;line-height:1.6;
  transition:border-color 150ms,box-shadow 150ms;
}
.field-textarea--sm{min-height:76px}
.field-textarea::placeholder{color:var(--color-form-text-lt);font-weight:300}
.field-textarea:hover{border-color:var(--color-form-secondary)}
.field-textarea:focus{outline:none;border-color:var(--color-form-accent);box-shadow:0 0 0 3px rgba(200,178,125,.17)}
.field-textarea[aria-invalid="true"]{border-color:var(--color-form-error)}
.field-textarea.is-valid{border-color:#4a9e74}
.char-counter{position:absolute;bottom:9px;right:11px;font-size:.68rem;color:var(--color-form-text-lt);pointer-events:none}

.field-hint{margin-top:5px;font-size:.73rem;color:var(--color-form-text-lt);line-height:1.5}

/* FIX #4: Errors hidden when field is valid */
.field-error{
  display:flex;align-items:center;gap:6px;
  margin-top:5px;font-size:.73rem;font-weight:500;
  color:var(--color-form-error);line-height:1.4;
}
.field-error[hidden]{display:none}

/* ─── PILLS ───────────────────────────────────────────────── */
.inline-fieldset{border:none;padding:0}
.pill-row{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}
.pill{cursor:pointer}
.pill__label{
  display:inline-flex;align-items:center;gap:7px;padding:5px 13px;
  font-size:.78rem;font-weight:500;
  color:var(--color-form-text);background:var(--color-form-white);
  border:1.5px solid var(--color-form-border);border-radius:99px;
  transition:all 150ms;user-select:none;
}
.flag-icon{
  width:18px;height:12px;display:inline-block;
  flex-shrink:0;border-radius:2px;box-shadow:0 0 0 1px rgba(58,63,92,.13);
}
.pill:hover .pill__label{border-color:var(--color-form-secondary);color:var(--color-form-text-dk)}
.pill input:checked~.pill__label{background:var(--color-form-primary);border-color:var(--color-form-primary);color:#fff}
.pill input:focus-visible~.pill__label{outline:2px solid var(--color-form-accent);outline-offset:2px}

/* ─── URGENCY CARDS ───────────────────────────────────────── */
.urgency-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}
.urgency-card{
  display:flex;flex-direction:column;gap:4px;
  padding:13px 14px;
  border:1.5px solid var(--color-form-border);border-radius:var(--radius-md);
  background:var(--color-form-white);cursor:pointer;
  transition:all var(--ease);
}
.urgency-card:hover{border-color:var(--color-form-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.urgency-card.is-selected{border-color:var(--color-form-accent);background:rgba(200,178,125,.06);box-shadow:0 0 0 3px rgba(200,178,125,.13)}
.urgency-card__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-bottom:4px}
.urgency--low .urgency-card__dot{background:#5fa878}
.urgency--medium .urgency-card__dot{background:#cfa040}
.urgency--high .urgency-card__dot{background:#b84a42}
.urgency-card__label{font-size:.82rem;font-weight:600;color:var(--color-form-text-dk)}
.urgency-card__sub{font-size:.7rem;color:var(--color-form-text-lt)}
.urgency-card input:focus-visible~.urgency-card__dot{outline:2px solid var(--color-form-accent);outline-offset:2px;border-radius:50%}

/* ─── PRIOR COUNSEL CARDS (FIX #7) ───────────────────────── */
.prior-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}
.prior-card{display:block;cursor:pointer}
.prior-card__inner{
  display:flex;align-items:center;gap:10px;
  padding:13px 16px;
  border:1.5px solid var(--color-form-border);border-radius:var(--radius-md);
  background:var(--color-form-white);
  transition:all var(--ease);
}
.prior-card:hover .prior-card__inner{border-color:var(--color-form-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.prior-card input:checked~.prior-card__inner{border-color:var(--color-form-accent);background:rgba(200,178,125,.06);box-shadow:0 0 0 3px rgba(200,178,125,.13)}
.prior-card input:focus-visible~.prior-card__inner{outline:2px solid var(--color-form-accent);outline-offset:2px}
.prior-card__inner svg{color:var(--color-form-secondary);flex-shrink:0}
.prior-card input:checked~.prior-card__inner svg{color:var(--color-form-accent-dk)}
.prior-card__label{font-size:.84rem;font-weight:600;color:var(--color-form-text-dk)}
.prior-card__sub{font-size:.7rem;color:var(--color-form-text-lt)}
.prior-followup{margin-top:.75rem;padding:1rem;background:var(--color-form-bg-warm);border-radius:var(--radius-md);border:1px solid var(--color-form-border)}
.prior-followup[hidden]{display:none}

/* ═══════════════════════════════════════════════════════════
   STEP 4 — CUSTOM AVAILABILITY CALENDAR (FIX #8)
═══════════════════════════════════════════════════════════ */
.cal-wrapper{
  background:var(--color-form-white);
  border:1.5px solid var(--color-form-border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  margin-bottom:1.5rem;
  max-width:620px;
}
.cal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 15px;
  background:var(--color-form-primary);
}
.cal-month-label{
  font-family:var(--font-display);
  font-size:.95rem;font-weight:500;font-style:italic;
  color:#fff;letter-spacing:.01em;
}
.cal-nav{
  width:28px;height:28px;border:none;border-radius:50%;
  background:rgba(255,255,255,.1);color:#fff;
  cursor:pointer;display:grid;place-items:center;
  transition:background var(--ease);
}
.cal-nav:hover{background:rgba(200,178,125,.3)}
.cal-nav.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px}

/* Legend */
.cal-legend{
  display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;
  padding:7px 15px;
  border-bottom:1px solid var(--color-form-border-lt);
  background:var(--color-form-bg-warm);
}
.cal-legend__item{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--color-form-text-lt)}
.cal-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}
.cal-dot--vera{background:var(--color-form-vera)}
.cal-dot--assoc{background:var(--color-form-assoc)}
.cal-dot--full{background:var(--color-form-booked)}

/* Weekday Headers */
.cal-weekdays{
  display:grid;grid-template-columns:repeat(7,1fr);
  padding:7px 12px 2px;
  gap:2px;
}
.cal-weekdays span{
  text-align:center;font-size:.67rem;font-weight:600;
  color:var(--color-form-text-lt);letter-spacing:.08em;text-transform:uppercase;
}

/* Calendar Grid */
.cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);
  padding:2px 12px 12px;gap:2px;
}
.cal-day{
  aspect-ratio:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:1px;
  border-radius:var(--radius);font-size:.73rem;font-weight:500;
  cursor:default;transition:all var(--ease);
  border:1.5px solid transparent;
  position:relative;
  color:var(--color-form-text-lt);
}
.cal-day--empty{background:transparent;cursor:default}
.cal-day--past{color:var(--color-form-border);cursor:not-allowed}
.cal-day--today{
  border-color:var(--color-form-border);
  color:var(--color-form-text-dk);font-weight:600;
}
.cal-day--vera{
  background:rgba(58,63,92,.07);
  color:var(--color-form-primary);cursor:pointer;
}
.cal-day--vera:hover{background:rgba(58,63,92,.14);border-color:var(--color-form-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.cal-day--assoc{
  background:rgba(184,161,176,.12);
  color:var(--color-form-primary);cursor:pointer;
}
.cal-day--assoc:hover{background:rgba(184,161,176,.22);border-color:var(--color-form-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.cal-day--full{
  background:var(--color-form-bg-warm);
  color:var(--color-form-text-lt);cursor:not-allowed;
  text-decoration:line-through;opacity:.7;
}
.cal-day--selected{
  background:var(--color-form-primary) !important;
  color:#fff !important;
  border-color:var(--color-form-primary) !important;
  box-shadow:var(--shadow-md) !important;
  transform:translateY(-1px) !important;
}
.cal-day--selected::after{
  content:'✓';position:absolute;top:2px;right:4px;
  font-size:.55rem;color:var(--color-form-accent);
}
.cal-day.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px}

/* Availability indicator dots */
.cal-day__dots{display:flex;gap:2px;justify-content:center}
.cal-day__dot{width:4px;height:4px;border-radius:50%}
.cal-day--vera .cal-day__dot{background:var(--color-form-vera)}
.cal-day--assoc .cal-day__dot{background:var(--color-form-assoc)}
.cal-day--selected .cal-day__dot{background:var(--color-form-accent)}

/* Selected display */
.cal-selected{
  display:flex;align-items:center;gap:8px;
  margin:0 15px 13px;padding:8px 12px;
  background:rgba(200,178,125,.1);
  border:1px solid rgba(200,178,125,.3);
  border-radius:var(--radius);
  font-size:.82rem;font-weight:500;color:var(--color-form-text-dk);
}
.cal-selected svg{color:var(--color-form-accent-dk);flex-shrink:0}
.cal-selected[hidden]{display:none}

/* ─── TIME SLOTS ──────────────────────────────────────────── */
.timeslot-group{
  background:var(--color-form-white);
  border:1.5px solid var(--color-form-border);
  border-radius:var(--radius-md);
  padding:16px 18px;
  margin-bottom:1.5rem;
  animation:fadeUp .3s ease both;
}
.timeslot-group[hidden]{display:none}
.timeslot-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.timeslot{cursor:pointer}
.timeslot__label{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 16px;
  font-size:.8rem;font-weight:500;
  border:1.5px solid var(--color-form-border);border-radius:var(--radius);
  background:var(--color-form-white);color:var(--color-form-text);
  transition:all var(--ease);user-select:none;
}
.timeslot:hover .timeslot__label{border-color:var(--color-form-secondary);color:var(--color-form-text-dk)}
.timeslot input:checked~.timeslot__label{background:var(--color-form-primary);border-color:var(--color-form-primary);color:#fff}
.timeslot input:focus-visible~.timeslot__label{outline:2px solid var(--color-form-accent);outline-offset:2px}
.timeslot__dot{width:7px;height:7px;border-radius:50%}
.timeslot__dot--vera{background:var(--color-form-accent)}
.timeslot__dot--assoc{background:var(--color-form-secondary)}
.timeslot input:checked~.timeslot__label .timeslot__dot{background:rgba(255,255,255,.7)}

/* ─── FORMAT CARDS ────────────────────────────────────────── */
.format-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}
.format-card{display:block;cursor:pointer}
.format-card__inner{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:7px;
  padding:18px 12px 14px;
  border:1.5px solid var(--color-form-border);border-radius:var(--radius-md);
  background:var(--color-form-white);color:var(--color-form-secondary);
  transition:all var(--ease);
}
.format-card:hover .format-card__inner{border-color:var(--color-form-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.format-card input:checked~.format-card__inner{border-color:var(--color-form-accent);background:rgba(200,178,125,.06);color:var(--color-form-accent-dk);box-shadow:0 0 0 3px rgba(200,178,125,.13)}
.format-card input:focus-visible~.format-card__inner{outline:2px solid var(--color-form-accent);outline-offset:2px}
.format-card__label{font-size:.82rem;font-weight:600;color:var(--color-form-text-dk)}
.format-card__sub{font-size:.7rem;color:var(--color-form-text-lt)}

/* ═══════════════════════════════════════════════════════════
   STEP 5 — REVIEW
═══════════════════════════════════════════════════════════ */
.review-card{
  background:var(--color-form-white);
  border:1px solid var(--color-form-border);
  border-radius:var(--radius-lg);
  overflow:hidden;margin-bottom:1.5rem;
}
.review-section{padding:16px 20px;border-bottom:1px solid var(--color-form-border-lt)}
.review-section:last-child{border-bottom:none}
.review-section__label{font-size:.63rem;font-weight:700;color:var(--color-form-accent-dk);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.review-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px}
.review-item__key{font-size:.72rem;font-weight:500;color:var(--color-form-text-lt);margin-bottom:2px}
.review-item__val{font-size:.85rem;font-weight:500;color:var(--color-form-text-dk)}
.language-val{display:inline-flex;align-items:center;gap:7px}
.review-item--full{grid-column:1/-1}
.review-summary{
  font-size:.84rem;color:var(--color-form-text);line-height:1.65;font-style:italic;
  border-left:2px solid var(--color-form-accent);padding-left:12px;margin-top:4px;
}

/* ─── CHECKBOXES ──────────────────────────────────────────── */
.consent-block{padding-top:.25rem}
.checkbox-wrap{display:flex;align-items:flex-start;gap:11px;cursor:pointer;margin-bottom:1rem}
.checkbox-box{
  flex-shrink:0;width:20px;height:20px;border-radius:4px;
  border:1.5px solid var(--color-form-border);background:var(--color-form-white);
  display:grid;place-items:center;color:transparent;
  transition:all 150ms;margin-top:1px;
}
.checkbox-wrap:hover .checkbox-box{border-color:var(--color-form-accent)}
.checkbox-wrap input:checked~.checkbox-box{background:var(--color-form-accent);border-color:var(--color-form-accent);color:#fff}
.checkbox-wrap input:focus-visible~.checkbox-box{outline:2px solid var(--color-form-accent);outline-offset:2px}
.checkbox-text{font-size:.8rem;color:var(--color-form-text);line-height:1.55}
.link{color:var(--color-form-accent-dk);text-decoration:underline;text-underline-offset:2px}
.link:hover{color:var(--color-form-primary)}

/* ─── FORM CONTROLS ───────────────────────────────────────── */
.form-controls{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:1rem;
  padding-top:1.5rem;
  border-top:1px solid var(--color-form-border-lt);
  margin-top:1rem;
}

.form-controls__spacer{display:none}

#btnBack{
  grid-column:1;
  justify-self:start;
}

#btnNext,
#btnSubmit{
  grid-column:3;
  justify-self:end;
  margin-left:0 !important;
}

#btnBack[hidden],
#btnNext[hidden],
#btnSubmit[hidden]{display:none !important}

/* ─── BUTTONS ─────────────────────────────────────────────── */
.btn-consult {
  display:inline-flex;align-items:center;gap:8px;
  padding:0 20px;height:46px;
  font-family:var(--font-body);font-size:.86rem;font-weight:600;
  letter-spacing:.02em;border-radius:var(--radius);
  border:none;cursor:pointer;
  transition:all var(--ease);text-decoration:none;white-space:nowrap;
}
.btn--primary{background:var(--color-form-primary);color:#fff}
.btn--primary:hover{background:var(--color-form-primary-dk);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--primary.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px}
.btn--submit{
  background:linear-gradient(135deg,var(--color-form-accent-dk),var(--color-form-accent));
  color:var(--color-form-primary-dk);font-weight:700;
}
.btn--submit:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);filter:brightness(1.04)}
.btn--submit.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-primary);outline-offset:2px}
.btn--ghost{background:transparent;color:var(--color-form-text);border:1.5px solid var(--color-form-border)}
.btn--ghost:hover{border-color:var(--color-form-secondary);color:var(--color-form-text-dk);background:var(--color-form-white)}
.btn--ghost.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px}
.btn--pdf{
  background:rgba(58,63,92,.08);color:var(--color-form-primary);
  border:1.5px solid rgba(58,63,92,.18);
  font-weight:600;margin-top:1rem;
  transition:all var(--ease);
}
.btn--pdf:hover{background:var(--color-form-primary);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--pdf.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px}

/* ═══════════════════════════════════════════════════════════
   SUCCESS STATE (FIX #5)
═══════════════════════════════════════════════════════════ */
.success-state{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:3rem 2rem;
}
.success-state[hidden]{display:none}
.success-state__inner{max-width:460px;width:100%;text-align:center;animation:successIn .55s cubic-bezier(.34,1.56,.64,1) both}
@keyframes successIn{from{opacity:0;transform:scale(.9) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}
.success-icon{display:inline-block;margin-bottom:1.5rem}
.sc{stroke-dasharray:195;stroke-dashoffset:195;animation:drawC .65s .15s ease forwards}
.st{stroke-dasharray:40;stroke-dashoffset:40;animation:drawT .4s .75s ease forwards}
@keyframes drawC{to{stroke-dashoffset:0}}
@keyframes drawT{to{stroke-dashoffset:0}}
.success-eyebrow{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-form-accent-dk);margin-bottom:8px}
.success-heading{font-family:var(--font-display);font-size:2.8rem;font-weight:400;font-style:italic;color:var(--color-form-text-dk);margin-bottom:1rem}
.success-body{font-size:.92rem;color:var(--color-form-text);line-height:1.7;margin-bottom:1.25rem}
.success-ref{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 12px 8px 16px;background:var(--color-form-bg-warm);
  border-radius:var(--radius);font-size:.8rem;color:var(--color-form-text-lt);
  margin-bottom:.5rem;
}
.success-ref strong{color:var(--color-form-text-dk);font-weight:600;letter-spacing:.04em;font-family:var(--font-body)}
.success-ref > svg{color:var(--color-form-accent-dk);flex-shrink:0}
.copy-ref-btn{
  display:inline-grid;place-items:center;
  width:26px;height:26px;margin-left:2px;
  border:1px solid rgba(58,63,92,.12);border-radius:50%;
  background:rgba(255,255,255,.55);color:var(--color-form-accent-dk);
  cursor:pointer;transition:all var(--ease);
}
.copy-ref-btn:hover{background:var(--color-form-white);color:var(--color-form-primary);transform:translateY(-1px)}
.copy-ref-btn.vzc-form-wrap :focus-visible{outline:2px solid var(--color-form-accent);outline-offset:2px}
.copy-ref-btn.is-copied{background:rgba(200,178,125,.2);color:var(--color-form-primary)}
.copy-ref-btn svg{display:block}

/* ═══════════════════════════════════════════════════════════
   PDF TEMPLATE (FIX #9)
═══════════════════════════════════════════════════════════ */
.pdf-tpl{
  display:none;
  position:fixed;top:-9999px;left:-9999px;
  width:794px;
}
@media print{
  @page{size:A4;margin:0}
  html,body{margin:0 !important;background:#fff !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .page-wrapper,.skip-link{display:none !important}
  .pdf-tpl{
    display:block !important;
    position:static;top:auto;left:auto;
    width:210mm;
    margin:0 auto;
  }
  .pdf-page{
    width:210mm !important;
    min-height:297mm !important;
    max-height:297mm !important;
    padding:10mm 11mm 22mm !important;
    overflow:hidden;
    page-break-after:avoid;
    break-after:avoid;
  }
  .pdf-foot{bottom:10mm !important;left:11mm !important;right:11mm !important}
}
.pdf-page{
  width:794px;min-height:1123px;
  padding:44px 46px 42px;
  background:#fff;
  font-family:var(--font-body);
  color:#2E3144;
  box-sizing:border-box;
}
.pdf-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}
.pdf-logo{
  height:50px;
  width:auto;
  max-width:210px;
  object-fit:contain;
  display:block;
  flex-shrink:0;
}
.pdf-head__firm{flex:1;padding-left:0;text-align:left}
.pdf-firm-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:#2E3144;letter-spacing:.02em}
.pdf-firm-sub{font-size:10px;font-weight:500;color:#5F6472;letter-spacing:.06em;text-transform:uppercase;margin-top:3px}
.pdf-firm-addr{font-size:9.5px;color:#7a7f8e;margin-top:6px;line-height:1.55}
.pdf-divider{height:2px;background:linear-gradient(90deg,#3A3F5C,#C8B27D,#3A3F5C);margin-bottom:16px;border-radius:2px}
.pdf-doc-title{margin-bottom:16px}
.pdf-doc-title__main{font-family:var(--font-display);font-size:19px;font-weight:500;color:#2E3144;font-style:italic;letter-spacing:.01em;margin-bottom:10px}
.pdf-doc-title__meta{display:flex;flex-wrap:wrap;gap:16px}
.pdf-doc-title__meta span{font-size:10px;color:#7a7f8e}
.pdf-doc-title__meta strong{color:#2E3144;font-weight:600}
.pdf-body{display:flex;flex-direction:column;gap:0}
.pdf-section{border:1px solid #ddd8d4;border-radius:6px;overflow:hidden;margin-bottom:9px;break-inside:avoid;page-break-inside:avoid}
.pdf-section-head{
  background:#3A3F5C;color:#fff;
  font-size:9px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:6px 14px;
}
.pdf-section-body{padding:9px 14px}
.pdf-row{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px}
.pdf-item__key{font-size:9px;font-weight:600;color:#7a7f8e;letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}
.pdf-item__val{font-size:11px;font-weight:500;color:#2E3144}
.pdf-item--full{grid-column:1/-1}
.pdf-summary{font-size:10px;color:#5F6472;line-height:1.45;font-style:italic;border-left:2.5px solid #C8B27D;padding-left:10px;margin-top:4px}
.pdf-foot{
  margin-top:auto;padding-top:14px;
  border-top:1px solid #ddd8d4;
  display:flex;align-items:flex-start;gap:20px;
  position:absolute;bottom:42px;left:46px;right:46px;
}
.pdf-page{position:relative;padding-bottom:90px}
.pdf-foot__left{flex:1}
.pdf-foot__badge{font-size:9px;font-weight:700;color:#3A3F5C;letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}
.pdf-foot__note{font-size:8.5px;color:#8a8f9e;line-height:1.55}
.pdf-foot__right{text-align:right;flex-shrink:0}
.pdf-foot__langs{display:flex;justify-content:flex-end;gap:8px;font-size:9px;font-weight:600;color:#B8A1B0;letter-spacing:.08em;margin-bottom:4px}
.pdf-foot__langs span{display:inline-flex;align-items:center;gap:3px}
.pdf-flag-icon{width:13px;height:8.6px;display:inline-block;border-radius:1.5px;box-shadow:0 0 0 .4px rgba(58,63,92,.14)}
.pdf-lang-val{display:inline-flex;align-items:center;gap:5px}
.pdf-lang-val .pdf-flag-icon{width:16px;height:10.6px}
.pdf-foot__est{font-size:8.5px;color:#7a7f8e}


/* ═══════════════════════════════════════════════════════════
   DARK MODE — matched to Home Page palette, WCAG 2.2 AA
═══════════════════════════════════════════════════════════ */
.vzc-form-wrap{color-scheme:light}

html[data-theme="dark"] .vzc-form-wrap,
[data-theme="dark"] .vzc-form-wrap,
.vzc-form-wrap[data-theme="dark"]{
  color-scheme:dark;

  /* Home page dark palette mapped to consultation variables */
  --color-form-primary:      #3A3F5C;
  --color-form-primary-dk:   #4A5170;
  --color-form-secondary:    #C7B6C2;
  --color-form-accent:       #D9C47F;
  --color-form-accent-dk:    #EAD99A;
  --color-form-bg:           #101319;
  --color-form-bg-warm:      #171B24;
  --color-form-white:        #171B24;
  --color-form-text:         #D4DBEA;
  --color-form-text-dk:      #F4F1EA;
  --color-form-text-lt:      #BBC6D8;
  --color-form-border:       #3B4254;
  --color-form-border-lt:    #2A3040;
  --color-form-error:        #FFB4A8;
  --color-form-error-bg:     #2B1819;
  --color-form-success:      #7DD7A7;
  --color-form-vera:         #EAD99A;
  --color-form-assoc:        #C7B6C2;
  --color-form-booked:       #434A5C;

  --color-primary-consultation-:      var(--color-form-primary);
  --color-primary-dark-consultation-: var(--color-form-primary-dk);
  --color-secondary-consultation-:    var(--color-form-secondary);
  --color-accent-consultation-:       var(--color-form-accent);
  --color-bg-consultation-:           var(--color-form-bg);
  --color-bg-warm-consultation-:      var(--color-form-bg-warm);
  --color-text-consultation-:         var(--color-form-text);
  --color-text-dark-consultation-:    var(--color-form-text-dk);
  --color-text-light-consultation-:   var(--color-form-text-lt);
  --color-border-consultation-:       var(--color-form-border);

  --shadow-sm: 0 1px 4px rgba(0,0,0,.32);
  --shadow-md: 0 4px 16px rgba(0,0,0,.38);
  --shadow-lg: 0 12px 36px rgba(0,0,0,.46);
}

html[data-theme="dark"] .vzc-form-wrap .panel-left{
  background:#0B0E14;
}
html[data-theme="dark"] .vzc-form-wrap .bg-orb--1{background:radial-gradient(circle,rgba(217,196,127,.13) 0%,transparent 70%)}
html[data-theme="dark"] .vzc-form-wrap .bg-orb--2{background:radial-gradient(circle,rgba(199,182,194,.10) 0%,transparent 70%)}
html[data-theme="dark"] .vzc-form-wrap .bg-circle{border-color:rgba(217,196,127,.18)}
html[data-theme="dark"] .vzc-form-wrap .bg-line{background:linear-gradient(to bottom,transparent,rgba(217,196,127,.22),transparent)}
html[data-theme="dark"] .vzc-form-wrap .firm-logo__img{filter:brightness(1.12) contrast(1.04)}
html[data-theme="dark"] .vzc-form-wrap .panel-copy__heading,
html[data-theme="dark"] .vzc-form-wrap .step-nav__item[data-state="active"] .step-nav__indicator,
html[data-theme="dark"] .vzc-form-wrap .step-nav__item[data-state="complete"] .step-nav__indicator,
html[data-theme="dark"] .vzc-form-wrap .confidentiality-badge{
  color:#ffffff;
}
html[data-theme="dark"] .vzc-form-wrap .panel-copy__body,
html[data-theme="dark"] .vzc-form-wrap .panel-contact__row,
html[data-theme="dark"] .vzc-form-wrap .confidentiality-badge{
  color:rgba(255,255,255,.72);
}
html[data-theme="dark"] .vzc-form-wrap .step-nav__btn{color:rgba(255,255,255,.55)}
html[data-theme="dark"] .vzc-form-wrap .step-nav__btn:hover,
html[data-theme="dark"] .vzc-form-wrap .step-nav__item[data-state="active"] .step-nav__btn,
html[data-theme="dark"] .vzc-form-wrap .step-nav__item[data-state="complete"] .step-nav__btn{color:rgba(255,255,255,.86)}
html[data-theme="dark"] .vzc-form-wrap .step-nav__indicator{border-color:rgba(255,255,255,.32)}
html[data-theme="dark"] .vzc-form-wrap .step-nav__item:not(:last-child)::after{background:rgba(255,255,255,.20)}

html[data-theme="dark"] .vzc-form-wrap .progress-bar,
html[data-theme="dark"] .vzc-form-wrap .pcard__body,
html[data-theme="dark"] .vzc-form-wrap .field-input,
html[data-theme="dark"] .vzc-form-wrap .field-select,
html[data-theme="dark"] .vzc-form-wrap .field-textarea,
html[data-theme="dark"] .vzc-form-wrap .urgency-card,
html[data-theme="dark"] .vzc-form-wrap .prior-card__inner,
html[data-theme="dark"] .vzc-form-wrap .cal-wrapper,
html[data-theme="dark"] .vzc-form-wrap .cal-day,
html[data-theme="dark"] .vzc-form-wrap .timeslot-group,
html[data-theme="dark"] .vzc-form-wrap .format-card__inner,
html[data-theme="dark"] .vzc-form-wrap .review-card {
  background:var(--color-form-white);
}

html[data-theme="dark"] .vzc-form-wrap .pcard:hover .pcard__body,
html[data-theme="dark"] .vzc-form-wrap .pill:hover .pill__label,
html[data-theme="dark"] .vzc-form-wrap .urgency-card:hover,
html[data-theme="dark"] .vzc-form-wrap .prior-card:hover .prior-card__inner,
html[data-theme="dark"] .vzc-form-wrap .timeslot:hover .timeslot__label,
html[data-theme="dark"] .vzc-form-wrap .format-card:hover .format-card__inner,
html[data-theme="dark"] .vzc-form-wrap .btn--ghost:hover,
html[data-theme="dark"] .vzc-form-wrap .copy-ref-btn:hover{
  background:#202637;
}

html[data-theme="dark"] .vzc-form-wrap .pcard input:checked~.pcard__body,
html[data-theme="dark"] .vzc-form-wrap .urgency-card.is-selected,
html[data-theme="dark"] .vzc-form-wrap .prior-card input:checked~.prior-card__inner,
html[data-theme="dark"] .vzc-form-wrap .format-card input:checked~.format-card__inner,
html[data-theme="dark"] .vzc-form-wrap .cal-selected,
html[data-theme="dark"] .vzc-form-wrap .success-ref,
html[data-theme="dark"] .vzc-form-wrap .copy-ref-btn.is-copied{
  background:rgba(217,196,127,.12);
  box-shadow:0 0 0 3px rgba(217,196,127,.18);
}

html[data-theme="dark"] .vzc-form-wrap .field-input:focus,
html[data-theme="dark"] .vzc-form-wrap .field-select:focus,
html[data-theme="dark"] .vzc-form-wrap .field-textarea:focus{
  border-color:var(--color-form-accent-dk);
  box-shadow:0 0 0 3px rgba(234,217,154,.18);
}
html[data-theme="dark"] .vzc-form-wrap .field-input::placeholder,
html[data-theme="dark"] .vzc-form-wrap .field-textarea::placeholder{
  color:#94A0B8;
}
html[data-theme="dark"] .vzc-form-wrap .field-input[aria-invalid="true"],
html[data-theme="dark"] .vzc-form-wrap .field-select[aria-invalid="true"],
html[data-theme="dark"] .vzc-form-wrap .field-textarea[aria-invalid="true"]{
  border-color:var(--color-form-error);
  box-shadow:0 0 0 3px rgba(255,180,168,.16);
}
html[data-theme="dark"] .vzc-form-wrap .field-input.is-valid,
html[data-theme="dark"] .vzc-form-wrap .field-select.is-valid,
html[data-theme="dark"] .vzc-form-wrap .field-textarea.is-valid{
  border-color:var(--color-form-success);
}

html[data-theme="dark"] .vzc-form-wrap .field-error,
html[data-theme="dark"] .vzc-form-wrap .req{color:var(--color-form-error)}
html[data-theme="dark"] .vzc-form-wrap .field-icon,
html[data-theme="dark"] .vzc-form-wrap .select-caret,
html[data-theme="dark"] .vzc-form-wrap .pcard__icon,
html[data-theme="dark"] .vzc-form-wrap .prior-card__inner svg,
html[data-theme="dark"] .vzc-form-wrap .format-card__inner{color:var(--color-form-secondary)}
html[data-theme="dark"] .vzc-form-wrap .form-step__eyebrow,
html[data-theme="dark"] .vzc-form-wrap .panel-copy__eyebrow,
html[data-theme="dark"] .vzc-form-wrap .review-section__label,
html[data-theme="dark"] .vzc-form-wrap .success-eyebrow,
html[data-theme="dark"] .vzc-form-wrap .link,
html[data-theme="dark"] .vzc-form-wrap .cal-selected svg,
html[data-theme="dark"] .vzc-form-wrap .success-ref > svg,
html[data-theme="dark"] .vzc-form-wrap .copy-ref-btn,
html[data-theme="dark"] .vzc-form-wrap .pcard input:checked~.pcard__body .pcard__icon,
html[data-theme="dark"] .vzc-form-wrap .prior-card input:checked~.prior-card__inner svg{
  color:var(--color-form-accent-dk);
}
html[data-theme="dark"] .vzc-form-wrap .pcard__check,
html[data-theme="dark"] .vzc-form-wrap .checkbox-wrap input:checked~.checkbox-box{
  color:#101319;
}
html[data-theme="dark"] .vzc-form-wrap .btn--submit{
  color:#101319;
}
html[data-theme="dark"] .vzc-form-wrap .btn--primary,
html[data-theme="dark"] .vzc-form-wrap .btn--pdf:hover,
html[data-theme="dark"] .vzc-form-wrap .pill input:checked~.pill__label,
html[data-theme="dark"] .vzc-form-wrap .cal-day--selected{
  color:#ffffff !important;
}
html[data-theme="dark"] .vzc-form-wrap .btn--ghost{
  color:var(--color-form-text);
  border-color:var(--color-form-border);
}
html[data-theme="dark"] .vzc-form-wrap .btn--pdf{
  background:rgba(217,196,127,.10);
  color:var(--color-form-accent-dk);
  border-color:rgba(234,217,154,.32);
}
html[data-theme="dark"] .vzc-form-wrap .copy-ref-btn{
  background:#202637;
  border-color:var(--color-form-border);
}

html[data-theme="dark"] .vzc-form-wrap .cal-day--past{
  color:#808BA3;
}
html[data-theme="dark"] .vzc-form-wrap .cal-day--full{
  background:#202637;
  color:#AEB8CC;
}
html[data-theme="dark"] .vzc-form-wrap .cal-day--vera{
  background:rgba(234,217,154,.10);
  border-color:rgba(234,217,154,.34);
  color:var(--color-form-text-dk);
}
html[data-theme="dark"] .vzc-form-wrap .cal-day--assoc{
  background:rgba(199,182,194,.12);
  border-color:rgba(199,182,194,.34);
  color:var(--color-form-text-dk);
}
html[data-theme="dark"] .vzc-form-wrap .cal-nav:hover{background:rgba(234,217,154,.16)}
html[data-theme="dark"] .vzc-form-wrap .review-summary{border-left-color:var(--color-form-accent)}

html[data-theme="dark"] .vzc-form-wrap .success-icon circle{stroke:rgba(125,215,167,.24)}
html[data-theme="dark"] .vzc-form-wrap .success-icon path{stroke:var(--color-form-success)}

html[data-theme="dark"] .vzc-form-wrap .pdf-page,
html[data-theme="dark"] .vzc-form-wrap .pdf-section-body{
  background:#ffffff;
  color:#2E3144;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  :root{--panel-w:280px}
  .panel-copy__heading{font-size:1.15rem}
  .form-viewport{padding:1.75rem 1.75rem 1.25rem}
}
@media(max-width:768px){
  .page-wrapper{grid-template-columns:1fr}
  .panel-left{display:none}
  .progress-bar{padding:.9rem 1.25rem}
  .form-viewport{padding:1.25rem 1.25rem 1rem}
  .practice-grid{grid-template-columns:repeat(2,1fr)}
  .urgency-row,.format-grid{grid-template-columns:1fr}
  .prior-row{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .review-grid{grid-template-columns:1fr}
  .form-step__title{font-size:1.45rem}
}
@media(max-width:480px){
  .practice-grid{grid-template-columns:1fr 1fr}
  .cal-day{font-size:.75rem}
}

/* ─── REDUCED MOTION ──────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
}
/* ─── FORCED COLORS ───────────────────────────────────────── */
@media(forced-colors:active){
  .pcard input:checked~.pcard__body,
  .urgency-card.is-selected,
  .format-card input:checked~.format-card__inner{outline:2px solid ButtonText}
  .btn--primary,.btn--submit{border:2px solid ButtonText}
}

/* ─── ATTORNEY PICKER MODAL ─────────────────────────────────── */
.vzc-form-wrap .attorney-modal[hidden]{display:none !important;}
.vzc-form-wrap .attorney-modal{
  position:fixed;
  inset:0;
  z-index:999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1.25rem;
  background:rgba(20,24,38,.54);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.vzc-form-wrap .attorney-modal__panel{
  width:min(100%,480px);
  border:1px solid var(--color-form-border);
  border-radius:var(--radius-xl);
  background:var(--color-form-bg-card);
  box-shadow:var(--shadow-xl);
  padding:1.35rem;
  position:relative;
  animation:modalIn .18s var(--ease-out);
}
.vzc-form-wrap .attorney-modal__panel::before{
  content:'';
  position:absolute;
  inset:0 0 auto 0;
  height:3px;
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  background:linear-gradient(90deg,var(--color-form-secondary),var(--color-form-accent));
}
.vzc-form-wrap .attorney-modal__title{
  margin:0 2.2rem .45rem 0;
  color:var(--color-form-text);
  font-size:1.15rem;
  line-height:1.25;
  font-family:inherit;
  font-weight:700;
}
.vzc-form-wrap .attorney-modal__body{
  margin:0 0 1rem;
  color:var(--color-form-text-muted);
  font-size:.9rem;
  line-height:1.55;
}
.vzc-form-wrap .attorney-modal__list{
  display:grid;
  gap:.7rem;
}
.vzc-form-wrap .attorney-choice{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  width:100%;
  padding:.9rem 1rem;
  border:1px solid var(--color-form-border);
  border-radius:var(--radius-md);
  background:var(--color-form-bg-soft);
  color:var(--color-form-text);
  cursor:pointer;
  text-align:left;
  font-family:inherit;
  transition:background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);
}
.vzc-form-wrap .attorney-choice:hover,
.vzc-form-wrap .attorney-choice:focus-visible{
  background:var(--color-form-bg-card);
  border-color:var(--color-form-accent);
  box-shadow:var(--shadow-md);
  transform:translateY(-1px);
  outline:none;
}
.vzc-form-wrap .attorney-choice strong{
  font-size:.95rem;
  font-weight:700;
}
.vzc-form-wrap .attorney-choice__meta{
  display:inline-block;
  margin-top:.2rem;
  color:var(--color-form-text-muted);
  font-size:.78rem;
}
.vzc-form-wrap .attorney-modal__close{
  position:absolute;
  top:.85rem;
  right:.85rem;
  width:2rem;
  height:2rem;
  border:1px solid var(--color-form-border);
  border-radius:999px;
  background:var(--color-form-bg-soft);
  color:var(--color-form-text);
  cursor:pointer;
  font-size:0;
}
.vzc-form-wrap .attorney-modal__close::before,
.vzc-form-wrap .attorney-modal__close::after{
  content:'';
  position:absolute;
  top:50%;
  left:50%;
  width:12px;
  height:1.5px;
  border-radius:2px;
  background:currentColor;
}
.vzc-form-wrap .attorney-modal__close::before{transform:translate(-50%,-50%) rotate(45deg);}
.vzc-form-wrap .attorney-modal__close::after{transform:translate(-50%,-50%) rotate(-45deg);}
.vzc-form-wrap .attorney-modal__close:hover,
.vzc-form-wrap .attorney-modal__close:focus-visible{
  border-color:var(--color-form-accent);
  box-shadow:var(--focus-ring);
  outline:none;
}
@keyframes modalIn{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
html[data-theme="dark"] .vzc-form-wrap .attorney-modal{background:rgba(7,10,18,.70)}
html[data-theme="dark"] .vzc-form-wrap .attorney-modal__panel{background:var(--color-form-bg-card);border-color:var(--color-form-border)}
html[data-theme="dark"] .vzc-form-wrap .attorney-choice{background:#202637;border-color:var(--color-form-border);color:var(--color-form-text-dk)}
html[data-theme="dark"] .vzc-form-wrap .attorney-choice:hover,
html[data-theme="dark"] .vzc-form-wrap .attorney-choice:focus-visible{background:#272E42;border-color:rgba(234,217,154,.45)}
html[data-theme="dark"] .vzc-form-wrap .attorney-modal__close{background:#202637;border-color:var(--color-form-border);color:var(--color-form-text-dk)}


/* VZC v5.1 attorney modal accessibility polish */
.vzc-form-wrap .attorney-modal{background:rgba(23,28,44,.72)!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.vzc-form-wrap .attorney-modal__panel{width:min(100%,520px)!important;border:1px solid rgba(58,63,92,.22)!important;border-radius:1.25rem!important;background:#fff!important;box-shadow:0 24px 70px rgba(26,31,49,.28)!important;padding:1.5rem!important;color:#2B2F47!important}
.vzc-form-wrap .attorney-modal__title{color:#2B2F47!important;font-size:1.25rem!important;letter-spacing:-.01em!important}.vzc-form-wrap .attorney-modal__body{color:#4D5268!important;font-size:.95rem!important}.vzc-form-wrap .attorney-choice{border:1.5px solid #DDD9D5!important;background:#F8F6F4!important;color:#2B2F47!important;border-radius:1rem!important;padding:1rem!important}.vzc-form-wrap .attorney-choice:hover,.vzc-form-wrap .attorney-choice:focus-visible{background:#fff!important;border-color:#3A3F5C!important;box-shadow:0 0 0 3px rgba(58,63,92,.18),0 10px 24px rgba(58,63,92,.12)!important;transform:translateY(-1px);outline:none!important}.vzc-form-wrap .attorney-choice__content{display:grid;gap:.18rem}.vzc-form-wrap .attorney-choice__meta{color:#535875!important;font-weight:600}.vzc-form-wrap .attorney-choice__arrow{width:1.8rem;height:1.8rem;border-radius:999px;background:#3A3F5C;color:#fff;display:grid;place-items:center;font-size:1.4rem;line-height:1}.vzc-form-wrap .attorney-modal__close{background:#F8F6F4!important;border:1.5px solid #DDD9D5!important;color:#2B2F47!important}.vzc-form-wrap .attorney-modal__close:hover,.vzc-form-wrap .attorney-modal__close:focus-visible{border-color:#3A3F5C!important;box-shadow:0 0 0 3px rgba(58,63,92,.18)!important;outline:none!important}
html[data-theme="dark"] .vzc-form-wrap .attorney-modal__panel{background:#171C2B!important;border-color:rgba(234,217,154,.32)!important;color:#F8F6F4!important}html[data-theme="dark"] .vzc-form-wrap .attorney-modal__title{color:#fff!important}html[data-theme="dark"] .vzc-form-wrap .attorney-modal__body{color:#D9DCE8!important}html[data-theme="dark"] .vzc-form-wrap .attorney-choice{background:#202637!important;color:#fff!important;border-color:rgba(234,217,154,.22)!important}html[data-theme="dark"] .vzc-form-wrap .attorney-choice__meta{color:#D9DCE8!important}html[data-theme="dark"] .vzc-form-wrap .attorney-choice__arrow{background:#C8B27D;color:#1D2233}html[data-theme="dark"] .vzc-form-wrap .attorney-modal__close{background:#202637!important;color:#fff!important;border-color:rgba(234,217,154,.22)!important}

/* Time period filter for appointment slots */
.timeslot-grid.has-periods{display:block}
.timeslot-periods{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 8px}
.timeslot-period{border:1px solid var(--color-form-border);background:#fff;border-radius:999px;padding:8px 12px;font-weight:700;color:var(--color-form-muted);cursor:pointer}
.timeslot-period.is-active{background:var(--color-form-primary);border-color:var(--color-form-primary);color:#fff}
.timeslot-grid__slots{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
html[data-theme="dark"] .vzc-form-wrap .timeslot-period{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#d6d6df}
html[data-theme="dark"] .vzc-form-wrap .timeslot-period.is-active{background:var(--color-form-primary);border-color:var(--color-form-primary);color:#fff}

/* v5.4.7 attorney image and description in availability popup */
.vzc-form-wrap .attorney-choice__photo{flex:0 0 54px;width:54px;height:54px;border-radius:999px;overflow:hidden;background:var(--color-form-bg-card);border:1px solid var(--color-form-border);display:block}
.vzc-form-wrap .attorney-choice__photo img{width:100%;height:100%;object-fit:cover;display:block}
.vzc-form-wrap .attorney-choice__description{display:block;margin-top:.25rem;color:var(--color-form-text-muted);font-size:.82rem;line-height:1.35;font-weight:500}
html[data-theme="dark"] .vzc-form-wrap .attorney-choice__description{color:#D9DCE8!important}
@media(max-width:520px){.vzc-form-wrap .attorney-choice__photo{flex-basis:46px;width:46px;height:46px}.vzc-form-wrap .attorney-choice{gap:.75rem}}
