
/* Zeyna Bride Survey — Luxury UI */
.zbs-wrap{
  --zbs-accent: var(--zbs-accent, #b47a57);
  --zbs-radius: var(--zbs-radius, 24px);
  --zbs-bg1: var(--zbs-bg1, #fff7f2);
  --zbs-bg2: var(--zbs-bg2, #f4efe8);
  --zbs-ink: #1f1a16;
  --zbs-muted:#6b6157;
  --zbs-border: rgba(0,0,0,.10);
  --zbs-shadow: 0 18px 60px rgba(31,26,22,.10);
  --zbs-sum-bg: #ffffff;
  --zbs-sum-border: rgba(0,0,0,.10);
  --zbs-sum-text: var(--zbs-ink);
  --zbs-sum-label: var(--zbs-muted);
  font-family: inherit;
}

.zbs-shell{
  /* Wider shell so the shortcode can take advantage of full-width containers */
  max-width: 1280px;
  margin: 0 auto;
  padding: clamp(18px, 3vw, 28px);
  border-radius: calc(var(--zbs-radius) + 6px);
  background: radial-gradient(circle at top left, var(--zbs-bg1), var(--zbs-bg2) 45%, #ffffff 100%);
  border: 1px solid var(--zbs-border);
  box-shadow: var(--zbs-shadow);
  position: relative;
  overflow: hidden;
}

/* When the live summary is enabled we allow a wider card so the form stays roomy. */
.zbs-shell.zbs-has-summary{ max-width: 1600px; }

/* In the final Review screen we hide the summary and give the form full width */
.zbs-shell.zbs-in-review .zbs-summary{ display:none !important; }
.zbs-shell.zbs-in-review .zbs-layout{ grid-template-columns: 1fr !important; }

/* Layout: left (survey) + right (summary). Summary stays *inside* the survey card. */
.zbs-layout{ display:block; }
.zbs-shell.zbs-has-summary .zbs-layout{
  display:grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 24px;
  align-items: start;
}

.zbs-left{ min-width: 0; }
.zbs-shell:before{
  content:"";
  position:absolute;
  inset:-120px -120px auto auto;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, color-mix(in srgb, var(--zbs-accent) 22%, transparent) 0, transparent 70%);
  filter: blur(2px);
  opacity: .55;
  pointer-events:none;
}

.zbs-loading{ padding: 24px; color: var(--zbs-muted); }

.zbs-topbar{
  display:block;
  margin-bottom: 14px;
}
.zbs-head{ display:block; }
.zbs-head-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
}
@media (max-width: 520px){
  .zbs-head-top{ flex-direction: column; align-items:flex-start; }
}

/* Luxury pill button: "Send me my link" */
.zbs-resume-pill{
  appearance: none;
  border: 1px solid rgba(0,0,0,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.60));
  color: var(--zbs-ink);
  font-size: 14px;
  font-weight: 650;
  letter-spacing: .25px;
  cursor: pointer;
  padding: 12px 22px;
  border-radius: 999px;
  white-space: nowrap;
  box-shadow: 0 12px 30px rgba(0,0,0,.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, padding .18s ease;
}
.zbs-resume-pill__arrow{
  display:inline-block;
  margin-left: 10px;
  transform: translateX(0);
  transition: transform .22s ease;
  opacity: .9;
}
.zbs-resume-pill:hover{
  transform: translateY(-1px) scale(1.04);
  padding-left: 24px;
  padding-right: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.70));
  box-shadow: 0 16px 38px rgba(0,0,0,.14);
}
.zbs-resume-pill:hover .zbs-resume-pill__arrow{ transform: translateX(4px); }
.zbs-resume-pill:active{ transform: translateY(0) scale(1.01); }
.zbs-draftbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.62));
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 16px 40px rgba(0,0,0,.12);
  margin: 6px 0 12px;
  transition: opacity .22s ease, transform .22s ease;
}
.zbs-draftbar-left{
  display:flex;
  align-items:flex-start;
  gap: 10px;
  min-width: 0;
}
.zbs-draftbar-icon{
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size: 13px;
  font-weight: 800;
  background: rgba(180,122,87,.16);
  color: var(--zbs-accent);
  flex: 0 0 auto;
  margin-top: 1px;
}
.zbs-draftbar.is-hiding{ opacity:0; transform: translateY(-6px); pointer-events:none; }
.zbs-draftbar-text{ font-size: 12.5px; color: var(--zbs-muted); line-height: 1.35; }
.zbs-draftbar-actions{ display:flex; gap: 10px; align-items:center; flex: 0 0 auto; }
.zbs-iconbtn{
  appearance:none;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.65);
  width: 34px;
  height: 34px;
  border-radius: 999px;
  cursor:pointer;
  line-height: 1;
  font-size: 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.zbs-iconbtn:hover{
  transform: translateY(-1px) scale(1.04);
  background: rgba(255,255,255,.86);
  box-shadow: 0 14px 34px rgba(0,0,0,.12);
}
.zbs-iconbtn:active{ transform: translateY(0) scale(1.01); }

/* Modal (Send resume link) */
.zbs-modal{
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.zbs-modal-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
}
.zbs-modal-card{
  position: relative;
  width: min(520px, 100%);
  background: #fff;
  border-radius: 22px;
  padding: 18px;
  border: 1px solid rgba(0,0,0,.12);
  box-shadow: 0 24px 70px rgba(0,0,0,.25);
}
.zbs-modal-card h3{ margin: 0 0 6px; font-size: 18px; }
.zbs-modal-actions{ display:flex; justify-content:flex-end; gap: 12px; margin-top: 12px; }
.zbs-modal-note{
  margin: 10px 0 0;
}

/* ------------------------------------------------------------------ */
/* Surveys listing (shortcode [zbs_surveys])                           */
/* Provides a clean grid of survey cards. Clicking a card shows the
   associated survey below without reloading the page.                 */
.zbs-surveys-list-wrapper{
  display:flex;
  flex-direction:column;
  gap:32px;
  margin: 0 auto;
  max-width: 1280px;
  padding: clamp(12px,3vw,32px);
}
.zbs-surveys-cards{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px,1fr));
  gap:24px;
}
.zbs-surveys-card{
  background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.65));
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 22px;
  box-shadow: 0 8px 26px rgba(0,0,0,.12);
  padding: 22px;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease;
  color: var(--zbs-ink);
  text-align:left;
}
.zbs-surveys-card:hover,
.zbs-surveys-card.is-active{
  transform: translateY(-3px);
  box-shadow: 0 14px 38px rgba(0,0,0,.16);
}
.zbs-surveys-card-title{
  margin: 0 0 8px;
  font-size: 19px;
  font-weight: 700;
  color: var(--zbs-ink);
}
.zbs-surveys-card-desc{
  margin: 0;
  font-size: 14px;
  color: var(--zbs-muted);
}
.zbs-surveys-forms{
  /* ensures forms stack nicely */
  display:block;
}
.zbs-surveys-form{
  margin-top: 18px;
}
.zbs-linkbox{
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.74));
}
.zbs-linkbox-row{
  display:flex;
  gap: 10px;
  align-items:center;
}
.zbs-linkbox-row .zbs-input{
  flex: 1 1 auto;
  min-width: 0;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12.5px;
}
[data-zbs-modal-msg].is-ok{ color: #1b6b3a; }
[data-zbs-modal-msg].is-error{ color: #a83232; }
.zbs-title{
  margin:0;
  font-size: clamp(20px, 2.2vw, 28px);
  font-weight: 600;
  letter-spacing: .2px;
}
.zbs-subtitle{ margin: 2px 0 0; color: var(--zbs-muted); }

.zbs-progress{
  /* The progress bar now lives between Back / Next, so it should expand */
  flex: 1 1 auto;
  min-width: 0;
}
.zbs-progress .bar{
  height: 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.06);
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
}
.zbs-progress .bar > i{
  display:block;
  height:100%;
  width:0%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--zbs-accent), color-mix(in srgb, var(--zbs-accent) 55%, #ffffff));
  transition: width .4s ease;
}
.zbs-progress .meta{
  margin-top: 6px;
  font-size: 12px;
  color: var(--zbs-muted);
  text-align:right;
}

.zbs-stepper{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  margin: 12px 0 18px;
}
.zbs-pill{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-size: 12px;
  color: var(--zbs-muted);
  cursor: pointer;
  user-select: none;
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.zbs-pill:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 32px rgba(31,26,22,.10);
  border-color: rgba(0,0,0,.14);
}
.zbs-pill.is-active{
  color: var(--zbs-ink);
  border-color: color-mix(in srgb, var(--zbs-accent) 35%, rgba(0,0,0,.10));
  box-shadow: 0 10px 30px rgba(31,26,22,.08);
}
.zbs-pill i{
  display:inline-flex;
  width: 18px; height: 18px;
  border-radius: 50%;
  align-items:center; justify-content:center;
  margin-right: 8px;
  background: rgba(0,0,0,.06);
  color: var(--zbs-ink);
  font-style: normal;
  font-weight: 700;
  font-size: 11px;
}
.zbs-pill.is-active i{
  background: color-mix(in srgb, var(--zbs-accent) 16%, rgba(0,0,0,.06));
}

.zbs-card{
  border-radius: var(--zbs-radius);
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: clamp(16px, 2.2vw, 22px);
}
.zbs-step-title{
  margin:0 0 6px;
  font-size: 18px;
  font-weight: 600;
}
.zbs-step-desc{
  margin:0 0 16px;
  color: var(--zbs-muted);
  line-height: 1.65;
}

.zbs-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 820px){
  .zbs-topbar{ flex-direction:column; align-items:flex-start; }
  .zbs-progress{ width:100%; min-width:0; }
  .zbs-grid{ grid-template-columns: 1fr; }
}

.zbs-field{ display:flex; flex-direction:column; gap: 7px; }
.zbs-field label{
  font-size: 13px;
  color: var(--zbs-muted);
  font-weight: 600;
}
.zbs-field .req{ color: var(--zbs-accent); margin-left: 4px; }
.zbs-input, .zbs-select, .zbs-textarea{
  width:100%;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.12);
  padding: 12px 14px;
  background: rgba(255,255,255,.92);
  outline:none;
  box-shadow: 0 10px 24px rgba(31,26,22,.06);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

/* Date: fake placeholder overlay (works on iOS where placeholders are ignored) */
.zbs-ios .zbs-date-wrap{
  position: relative;
}
.zbs-ios .zbs-date-ph{
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--zbs-muted);
  opacity: .75;
  font-size: 16px;
  line-height: 1;
  white-space: nowrap;
}
.zbs-ios .zbs-date-wrap.is-filled .zbs-date-ph,
.zbs-ios .zbs-date-wrap:focus-within .zbs-date-ph{
  display:none;
}

.zbs-textarea{ min-height: 110px; resize: vertical; }

/* iOS date input normalization: keeps the date placeholder/value aligned with other inputs */
.zbs-ios .zbs-input[type="date"]{
  -webkit-appearance: none;
  appearance: none;
  line-height: 1.2;
}

.zbs-ios .zbs-input[type="date"]{
  text-align: left;
}

/* iOS/WebKit sometimes centers the displayed date value; force it to align like other placeholders/values */
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-date-and-time-value{
  display: block;
  width: 100%;
  text-align: left;
  margin: 0;
}
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit{
  display: block;
  width: 100%;
}
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit,
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit-fields-wrapper,
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit-text,
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit-month-field,
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit-day-field,
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit-year-field{
  padding: 0;
  margin: 0;
  line-height: 1.2;
}
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-date-and-time-value{
  text-align: left;
}


/* Force iOS Safari date control to match other inputs exactly */
.zbs-input, .zbs-select{
  min-height: 52px;
}
.zbs-ios .zbs-input[type="date"]{
  -webkit-appearance: none;
  appearance: none;
  height: 52px;
  min-height: 52px;
  padding: 0 14px;
  line-height: 52px;
  text-align: left;
}
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit,
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-datetime-edit-fields-wrapper,
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-date-and-time-value{
  height: 100%;
  display: flex;
  align-items: center;
  width: 100%;
  margin: 0;
  padding: 0;
  text-align: left;
}
.zbs-ios .zbs-ios .zbs-ios .zbs-input[type="date"]::-webkit-calendar-picker-indicator{
  margin: 0;
}

/* Prevent iOS Safari input zoom and odd baseline shifts (esp. date) */
@supports (-webkit-touch-callout: none){
  .zbs-input, .zbs-select, .zbs-textarea{
    font-size: 16px;
  }
}
.zbs-input:focus, .zbs-select:focus, .zbs-textarea:focus{
  border-color: color-mix(in srgb, var(--zbs-accent) 50%, rgba(0,0,0,.12));
  box-shadow: 0 14px 34px rgba(31,26,22,.10);
  transform: translateY(-1px);
}
.zbs-help{ font-size: 12px; color: var(--zbs-muted); margin-top: -2px; }

.zbs-choice{
  display:flex; gap:10px; flex-wrap:wrap;
}
.zbs-chip{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.82);
  cursor:pointer;
  user-select:none;
  transition: transform .15s ease, border-color .2s ease;
}
.zbs-chip:hover{ transform: translateY(-1px); }
.zbs-chip input{ margin:0; }
.zbs-chip.is-checked{
  border-color: color-mix(in srgb, var(--zbs-accent) 45%, rgba(0,0,0,.10));
  box-shadow: 0 14px 32px rgba(31,26,22,.10);
}

/* Chips: keep the default wrapping behavior (mobile included) */

.zbs-error{
  margin-top: 8px;
  color: #8b1e1e;
  background: rgba(139,30,30,.06);
  border: 1px solid rgba(139,30,30,.18);
  padding: 10px 12px;
  border-radius: 14px;
  font-size: 13px;
}

.zbs-actions{
  display:flex;
  gap: 16px;
  justify-content: flex-start;
  align-items:center;
  margin-top: 16px;
}

/* Make the progress bar feel "embedded" between the two buttons */
.zbs-actions .zbs-progress{
  max-width: 100%;
  /* Align the progress *bar* to the exact vertical center of Back/Next */
  display: flex;
  align-items: center;
  gap: 12px;
}
.zbs-actions .zbs-progress .bar{ flex: 1 1 auto; }
.zbs-actions .zbs-progress .meta{
  margin-top: 0;
  text-align:right;
  white-space: nowrap;
}
.zbs-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.76);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-weight: 700;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.zbs-btn:hover{ transform: translateY(-1px); box-shadow: 0 18px 40px rgba(31,26,22,.12); }
.zbs-btn.primary{
  background: linear-gradient(135deg, color-mix(in srgb, var(--zbs-accent) 70%, #ffffff), var(--zbs-accent));
  border-color: color-mix(in srgb, var(--zbs-accent) 55%, rgba(0,0,0,.12));
  color: #fff;
}
.zbs-btn[disabled]{ opacity:.5; cursor:not-allowed; transform:none; box-shadow:none; }

/*
 * Custom section title for grouping fields within a step.
 * These elements are rendered via heading fields in the survey schema. They
 * span the full width of the grid and provide visual separation between
 * groups of related inputs.
 */
.zbs-section-title{
  grid-column: 1 / -1;
  margin: 22px 0 8px;
  font-size: 18px;
  font-weight: 600;
  color: var(--zbs-ink);
  /* fallback accent colour for emphasis */
  border-bottom: 1px solid rgba(0,0,0,.07);
  padding-bottom: 4px;
}

/*
 * Improve the appearance of the Back button. By default the primary button has
 * a gradient accent background. The secondary (Back) button now gets a
 * subtle outline in the accent colour and coloured text to harmonise with the
 * design. It also has a slightly more opaque background to stand out from
 * the card.
 */
.zbs-actions .zbs-btn[data-zbs-back]{
  background: rgba(255, 255, 255, 0.85);
  border-color: color-mix(in srgb, var(--zbs-accent) 35%, rgba(0,0,0,.12));
  color: var(--zbs-accent);
  box-shadow: 0 8px 18px rgba(31,26,22,.05);
}
.zbs-actions .zbs-btn[data-zbs-back]:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 38px rgba(31,26,22,.08);
}

/*
 * Live Summary (Desktop)
 * - Lives INSIDE the survey card (not fixed in the page)
 * - Shows only required fields the visitor has already filled
 */
.zbs-summary{
  display:flex;
  flex-direction: column;
  border-radius: calc(var(--zbs-radius) - 2px);
  background: var(--zbs-sum-bg);
  border: 1px solid var(--zbs-sum-border);
  box-shadow: 0 18px 45px rgba(31,26,22,.10);
  padding: 16px 16px;
  color: var(--zbs-sum-text);
  overflow: hidden;
}
.zbs-summary-head{ margin-bottom: 12px; }

/* Two-column grid for summary items (desktop only). */
.zbs-summary-body{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
  overflow: auto;
  /* Make wheel scrolling feel natural inside the summary without
     propagating to the page when the summary is scrollable. */
  overscroll-behavior: contain;
  padding-right: 6px; /* room for scrollbar */
}

/* Admin option: switch the summary to one column. */
.zbs-shell.zbs-sum-cols-1 .zbs-summary-body{
  grid-template-columns: 1fr;
}

.zbs-summary-group-title{
  grid-column: 1 / -1;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--zbs-sum-border) 60%, transparent);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--zbs-sum-label);
  font-weight: 700;
}
.zbs-summary-group-title.is-first{
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.zbs-summary-title{
  margin: 0;
  font-size: 16px;
  font-weight: 650;
  letter-spacing: .2px;
}
.zbs-summary-desc{
  margin: 6px 0 0;
  font-size: 12px;
  line-height: 1.45;
  color: var(--zbs-sum-label);
}
.zbs-summary-item{
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--zbs-sum-border) 55%, transparent);
  background: color-mix(in srgb, var(--zbs-sum-bg) 70%, #ffffff);
}
.zbs-summary-label{
  font-size: 12px;
  color: var(--zbs-sum-label);
}
.zbs-summary-value{
  margin-top: 3px;
  font-size: 14px;
  color: var(--zbs-sum-text);
  font-weight: 600;
  word-break: break-word;
}
.zbs-summary-empty{
  grid-column: 1 / -1;
  padding: 10px 0;
  font-size: 13px;
  color: var(--zbs-sum-label);
}

/* Hide summary on smaller screens */
@media (max-width: 1000px){
  .zbs-shell.zbs-has-summary .zbs-layout{ display:block; }
  .zbs-summary{ display:none; }
}

.zbs-success{
  text-align:center;
  padding: 14px 6px 6px;
}
.zbs-success h3{ margin: 0 0 8px; font-size: 20px; }
.zbs-success p{ margin: 0 0 14px; color: var(--zbs-muted); line-height:1.7; }
.zbs-book{
  display:flex;
  justify-content:center;
  margin-top: 10px;
}
.zbs-book a{
  text-decoration:none;
}

/* =============================
   Review & Book (final screen)
   ============================= */
.zbs-review{
  width: 100%;
}

.zbs-review-card{
  border: 1px solid rgba(31,26,22,0.10);
  background: rgba(255,255,255,0.85);
  border-radius: 26px;
  padding: 22px 22px;
}

.zbs-review-head h3{
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: .2px;
}

.zbs-review-head p{
  margin: 8px 0 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--zbs-muted);
}

.zbs-review-cta{
  margin-top: 14px;
}

.zbs-review-section{
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(31,26,22,0.08);
}

.zbs-review-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.zbs-review-section-head h4{
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(31,26,22,0.65);
}

.zbs-link{
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: var(--zbs-accent);
  cursor: pointer;
  text-decoration: none;
  font-weight: 650;
}
.zbs-link:hover{
  text-decoration: underline;
}

.zbs-review-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
}

.zbs-review-item{
  border-radius: 14px;
  border: 1px solid rgba(31,26,22,0.08);
  background: rgba(255,255,255,0.70);
  padding: 12px 12px;
}

.zbs-review-label{
  font-size: 12px;
  color: rgba(31,26,22,0.65);
}

.zbs-review-value{
  margin-top: 3px;
  font-size: 14px;
  color: rgba(31,26,22,0.96);
  font-weight: 650;
  word-break: break-word;
  white-space: pre-wrap;
}

.zbs-review-empty{
  margin-top: 14px;
  font-size: 13px;
  color: rgba(31,26,22,0.65);
}

@media (max-width: 780px){
  .zbs-review-grid{
    grid-template-columns: 1fr;
  }
}


/* ---------------------------------------------
   Save & Resume link placement (Summary + Mobile)
---------------------------------------------- */

.zbs-summary-foot{
  margin-top: 14px;
}

.zbs-summary-helper{
  margin: 0 0 10px;
  font-size: 13px;
  line-height: 1.35;
  color: rgba(31,26,22,0.75);
}

.zbs-resume-link{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 0;
  background: transparent;
  padding: 6px 0;
  cursor: pointer;
  text-decoration: underline;
  font: inherit;
  color: var(--zbs-accent);
}

.zbs-resume-link__icon{
  font-size: 16px;
  line-height: 1;
}

.zbs-resume-link__text{
  font-size: 14px;
  line-height: 1.2;
  opacity: 1;
}

/* Mobile-only placement under step actions (Option A-style: end of flow) */
.zbs-resume-mobile{
  display: none;
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.70));
  box-shadow: 0 12px 34px rgba(31,26,22,.08);
}
.zbs-resume-mobile__helper{
  margin: 0 0 10px;
  font-size: 13px;
  line-height: 1.35;
  color: rgba(31,26,22,0.75);
}

/* Modal cancel should look like the Back button */
.zbs-modal-actions [data-zbs-modal-close]{
  background: rgba(255, 255, 255, 0.85);
  border-color: color-mix(in srgb, var(--zbs-accent) 35%, rgba(0,0,0,.12));
  color: var(--zbs-accent);
  box-shadow: 0 8px 18px rgba(31,26,22,.05);
}
.zbs-modal-actions [data-zbs-modal-close]:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 38px rgba(31,26,22,.08);
}

@media (max-width: 820px){
  /* hide the desktop summary link if the summary sidebar is hidden on mobile */
  .zbs-summary-foot{
    display: none;
  }

  .zbs-resume-mobile{
    display: block;
  }

  .zbs-resume-link--mobile{
    width: 100%;
    justify-content: center;
    padding: 12px 12px;
    border-radius: 14px;
    text-decoration: none;
    border: 1px solid color-mix(in srgb, var(--zbs-accent) 25%, rgba(0,0,0,.10));
    background: rgba(255,255,255,.65);
  }
  .zbs-resume-link--mobile .zbs-resume-link__text{
    font-size: 15px;
  }
}
