/* ============================================================
   RHINOPLASTY INTAKE FORM — editorial monograph rewrite
   Serene single-question-at-a-time concierge intake.
   Assumes :root tokens from styles.css:
     --bg #F4EFE6  --bg2 #EAE2D2  --paper #FBF7EF
     --ink #1A140D  --ink2 #3A3026  --muted #867A6A
     --line #D9CFBE  --accent #9C7A4F  --accent2 #C9A878
     --serif (Cormorant)  --sans (Hanken)  --mono (JetBrains)
     --ease cubic-bezier(.62,.05,.01,.99)
     --t-fast .4s  --t-base .7s  --t-slow 1.2s
   Defensive fallbacks are inlined wherever a token might be missing.
   ============================================================ */

/* ----- defensive fallbacks (only fire if styles.css didn't define) ----- */
:root{
  --form-bg: var(--paper, #FBF7EF);
  --form-page: var(--bg, #F4EFE6);
  --form-ink: var(--ink, #1A140D);
  --form-ink2: var(--ink2, #3A3026);
  --form-muted: var(--muted, #867A6A);
  --form-line: var(--line, #D9CFBE);
  --form-accent: var(--accent, #9C7A4F);
  --form-accent-2: var(--accent2, #C9A878);
  --form-serif: var(--serif, 'Cormorant Garamond','Cormorant',Georgia,serif);
  --form-sans:  var(--sans,  'Hanken Grotesk', system-ui, -apple-system, sans-serif);
  --form-mono:  var(--mono,  'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace);
  --form-ease:  var(--ease,  cubic-bezier(.62,.05,.01,.99));
  --form-t-fast: var(--t-fast, .4s);
  --form-t-base: var(--t-base, .7s);
  --form-t-slow: var(--t-slow, 1.2s);
  --form-rust: #B85838;
}

/* ============================================================
   PAGE FRAME — the form IS the page, no card chrome
   ============================================================ */
.form-section{
  background: var(--form-bg);
  min-height: 100vh;
  padding: 0;
  position: relative;
}

/* Slim sentinel-style header echo + 2px hairline progress (full bleed) */
.form-shell{
  max-width: 680px;
  margin: 0 auto;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
  padding: clamp(96px, 12vw, 160px) clamp(24px, 4vw, 48px) 160px;
  position: relative;
}

/* ============================================================
   PROGRESS HEADER
   ============================================================ */
.form-head{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 40;
  background: var(--form-bg);
  border: 0;
  border-bottom: 1px solid var(--form-line);
  padding: 22px clamp(24px, 4vw, 64px) 0;
}
.form-head-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin: 0 0 18px;
  max-width: 1320px;
  margin-left: auto;
  margin-right: auto;
}
.form-step-label{
  font-family: var(--form-serif);
  font-weight: 400;
  font-size: 18px;
  line-height: 1;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--form-ink);
}
.form-step-label::before{
  content: 'Kassis  ·  ';
  color: var(--form-ink);
  letter-spacing: .18em;
}
.form-step-count{
  font-family: var(--form-mono);
  font-size: 11.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--form-muted);
  font-weight: 400;
}
.form-step-count b{
  color: var(--form-ink);
  font-weight: 500;
}

/* 2px-tall hairline progress runs full viewport width */
.progress-rail{
  position: relative;
  height: 2px;
  background: var(--form-line);
  border-radius: 0;
  overflow: hidden;
  margin: 0 calc(-1 * clamp(24px, 4vw, 64px));
}
.progress-fill{
  height: 100%;
  background: var(--form-accent);
  border-radius: 0;
  transition: width var(--form-t-base) var(--form-ease);
}

/* step dots become a faint dot index — hidden on small viewports */
.step-dots{
  display: flex;
  gap: 0;
  padding: 12px 0 14px;
  flex-wrap: nowrap;
  max-width: 1320px;
  margin: 0 auto;
  justify-content: center;
  align-items: center;
}
.step-dot{
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 0;
  background: transparent;
  position: relative;
  display: flex; align-items: center; justify-content: center;
  font-size: 0;
  color: transparent;
  cursor: default;
  margin: 0 4px;
  transition: transform var(--form-t-fast) var(--form-ease);
}
.step-dot::before{
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--form-line);
  transition: background var(--form-t-fast) var(--form-ease), transform var(--form-t-fast) var(--form-ease);
}
.step-dot.done::before{ background: var(--form-accent); }
.step-dot.active::before{
  background: var(--form-ink);
  transform: scale(1.6);
}
.step-dot svg{ display: none; }

/* Push the actual form body below the fixed header. */
.form-shell{ margin-top: 0; }
.form-shell::before{
  content: '';
  display: block;
  height: 96px; /* matches fixed header */
}

/* ============================================================
   BODY — generous luxury padding
   ============================================================ */
.form-body{
  padding: 0;
  min-height: 320px;
  background: transparent;
}

/* ----- step header (number + question + sub) ----- */
.step-head{
  margin: 0 0 56px;
}
.step-head .si{
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 11.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--form-muted);
  margin: 0 0 28px;
  display: inline-block;
}
.step-head h3{
  font-family: var(--form-serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--form-ink);
  margin: 0;
}
.step-head p{
  color: var(--form-ink2);
  font-family: var(--form-sans);
  font-size: 16px;
  line-height: 1.65;
  margin: 24px 0 0;
  max-width: 54ch;
}

/* fade/translate between steps */
.step-anim{
  animation: stepIn .5s var(--form-ease);
}
@keyframes stepIn{
  from{ opacity: 0; transform: translateY(16px); }
  to  { opacity: 1; transform: translateY(0); }
}
@keyframes stepFadeOnly{
  from{ opacity: 0; }
  to  { opacity: 1; }
}

/* ============================================================
   FIELDS — bottom-rule only, no boxes
   ============================================================ */
.field-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px 40px;
}
.field{
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}
.field.full{ grid-column: 1 / -1; }

.field label{
  font-family: var(--form-sans);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--form-ink);
  transition: color var(--form-t-fast) var(--form-ease);
}
.field label .opt{
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--form-muted);
  margin-left: 6px;
}
.field .req{
  color: var(--form-accent);
  font-weight: 500;
  letter-spacing: 0;
}

/* inputs: bottom-rule only, no border-box */
.input,
.textarea,
select.input{
  font-family: var(--form-sans);
  font-size: 17px;
  line-height: 1.55;
  color: var(--form-ink);
  padding: 14px 0;
  border: 0;
  border-bottom: 1px solid var(--form-line);
  border-radius: 0;
  background: transparent;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  transition:
    border-color var(--form-t-fast) var(--form-ease),
    border-bottom-width var(--form-t-fast) var(--form-ease);
}

/* italic-serif placeholder — subtle editorial cue, darkened for AA-readable affordance */
.input::placeholder,
.textarea::placeholder{
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 15px;
  color: var(--form-ink2);
  opacity: 0.55;
}

.input:focus,
.textarea:focus,
select.input:focus{
  outline: none;
  border-bottom: 2px solid var(--form-accent);
  border-top: 1px solid var(--form-line);
  background: transparent;
  box-shadow: none;
  padding-top: 13px;            /* keep total height stable when top border appears */
}
/* accessible focus visibility — softer ring only for keyboard */
.input:focus-visible,
.textarea:focus-visible,
select.input:focus-visible{
  outline: 2px solid transparent;
  box-shadow: 0 2px 0 0 var(--form-accent);
}
.field:focus-within label{
  color: var(--form-accent);
}

.textarea{
  resize: vertical;
  min-height: 112px;
  line-height: 1.65;
}

/* date input — strip the native chrome a bit */
.input[type="date"]{
  font-family: var(--form-sans);
  color: var(--form-ink);
  letter-spacing: .01em;
}
.input[type="date"]::-webkit-calendar-picker-indicator{
  opacity: .55;
  cursor: pointer;
}

/* select arrow — small caret in accent */
select.input{
  background-image: linear-gradient(45deg, transparent 50%, var(--form-accent) 50%),
                    linear-gradient(135deg, var(--form-accent) 50%, transparent 50%);
  background-position: calc(100% - 14px) center, calc(100% - 9px) center;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 28px;
}

/* error state — warm rust, never red */
.field.error .input,
.field.error .textarea,
.field.error select.input{
  border-bottom-color: var(--form-rust);
}
.field.error label{
  color: var(--form-rust);
}
.err-msg{
  font-family: var(--form-serif);
  font-style: italic;
  font-size: 13px;
  line-height: 1.5;
  color: var(--form-rust);
  margin-top: 4px;
}
.err-msg::before{
  content: '— ';
  font-style: normal;
  color: var(--form-rust);
  margin-right: 2px;
}

/* ============================================================
   CHOICE CHECKLIST (multi-select concerns)
   Editorial typographic rows, not card grid.
   ============================================================ */
.choice-grid{
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--form-line);
}
.choice{
  display: grid;
  grid-template-columns: 32px 1fr;
  align-items: center;
  gap: 24px;
  padding: 22px 0;
  border: 0;
  border-bottom: 1px solid var(--form-line);
  border-radius: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
  width: 100%;
  font-family: inherit;
  color: var(--form-ink);
  transition: color var(--form-t-fast) var(--form-ease);
}
.choice:hover{
  background: transparent;
  transform: none;
  border-color: var(--form-line);
}
.choice:hover .ctxt{ color: var(--form-ink); }
.choice:hover::after{ color: var(--form-accent); }

/* 24px square checkbox */
.choice .check{
  width: 22px; height: 22px;
  flex: none;
  border-radius: 0;
  border: 1px solid var(--form-line);
  background: var(--form-bg);
  display: flex; align-items: center; justify-content: center;
  color: var(--form-bg);
  transition:
    background var(--form-t-fast) var(--form-ease),
    border-color var(--form-t-fast) var(--form-ease),
    color var(--form-t-fast) var(--form-ease);
}
.choice.on .check{
  background: var(--form-accent);
  border-color: var(--form-accent);
  color: var(--form-bg);
}
.choice .check svg{
  width: 13px; height: 13px;
  opacity: 0;
  transition: opacity var(--form-t-fast) var(--form-ease);
}
.choice.on .check svg{ opacity: 1; }

/* hide concern icons in favor of typographic treatment */
.choice .ico{ display: none; }

/* label — serif name + em-dash + (description optional via data-desc) */
.choice .ctxt{
  font-family: var(--form-serif);
  font-weight: 500;
  font-size: 19px;
  line-height: 1.35;
  letter-spacing: -.01em;
  color: var(--form-ink);
  transition: color var(--form-t-fast) var(--form-ease);
}

.choice.on .ctxt{ color: var(--form-ink); }

/* selected state — subtle accent left edge accent */
.choice.on{
  background: transparent;
  box-shadow: none;
  border-bottom-color: var(--form-line);
}

/* keyboard focus */
.choice:focus-visible{
  outline: none;
  background: rgba(156,122,79,0.05);
  box-shadow: inset 3px 0 0 0 var(--form-accent);
}

/* ============================================================
   YES / NO INLINE — circle radios with italic-serif label
   ============================================================ */
.qa-list{
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--form-line);
}
.qa{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 32px 0;
  border: 0;
  border-bottom: 1px solid var(--form-line);
  flex-wrap: wrap;
}
.qa:last-child{ border-bottom: 1px solid var(--form-line); }
.qa .q{
  font-family: var(--form-serif);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.35;
  letter-spacing: -.01em;
  color: var(--form-ink);
  max-width: 62%;
  flex: 1 1 auto;
}

/* segmented becomes two underlined word buttons with accent rings */
.seg{
  display: inline-flex;
  background: transparent;
  border-radius: 0;
  padding: 0;
  gap: 28px;
  flex: none;
  align-items: center;
}
.seg button{
  position: relative;
  border: 0;
  background: transparent;
  padding: 8px 0 8px 32px;
  border-radius: 0;
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 19px;
  letter-spacing: 0;
  text-transform: lowercase;
  color: var(--form-muted);
  cursor: pointer;
  transition: color var(--form-t-fast) var(--form-ease);
}
.seg button::before{
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1px solid var(--form-line);
  background: transparent;
  transition:
    background var(--form-t-fast) var(--form-ease),
    border-color var(--form-t-fast) var(--form-ease);
}
.seg button:hover{ color: var(--form-ink); }
.seg button:hover::before{ border-color: var(--form-accent); }
.seg button.on{ color: var(--form-ink); }
.seg button.on::before{
  background: var(--form-accent);
  border-color: var(--form-accent);
  box-shadow: inset 0 0 0 3px var(--form-bg);
}
.seg button.on.yes{ color: var(--form-ink); }
.seg button:focus-visible{
  outline: 2px solid var(--form-accent);
  outline-offset: 4px;
  border-radius: 2px;
}

/* conditional inline reveal — fade + slide instead of jump */
.conditional{
  width: 100%;
  margin-top: 20px;
  animation: condIn .5s var(--form-ease) both;
}
@keyframes condIn{
  from{ opacity: 0; transform: translateY(8px); }
  to  { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   RADIO (single) — pill-free, hairline outline
   ============================================================ */
.radio-row{
  display: flex;
  gap: 0;
  flex-wrap: wrap;
  border-top: 1px solid var(--form-line);
}
.radio{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 18px 0;
  border: 0;
  border-bottom: 1px solid var(--form-line);
  border-radius: 0;
  background: transparent;
  cursor: pointer;
  font-family: var(--form-serif);
  font-weight: 400;
  font-size: 18px;
  color: var(--form-ink);
  transition: color var(--form-t-fast) var(--form-ease);
  flex: 1 1 100%;
}
.radio:hover{ color: var(--form-ink); border-color: var(--form-line); }
.radio.on{ color: var(--form-ink); background: transparent; box-shadow: none; }
.radio .ring{
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1px solid var(--form-line);
  flex: none;
  display: flex; align-items: center; justify-content: center;
  background: transparent;
  transition: border-color var(--form-t-fast) var(--form-ease);
}
.radio.on .ring{ border-color: var(--form-accent); background: transparent; }
.radio.on .ring::after{
  content: '';
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--form-accent);
}
.radio:focus-visible{
  outline: 2px solid var(--form-accent);
  outline-offset: 4px;
}

/* ============================================================
   PHOTO DROPZONES — 3:4 paper portrait frames
   ============================================================ */
.upload-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.dropzone{
  position: relative;
  border: 1px solid var(--form-line);
  border-radius: 0;
  background: var(--form-bg);
  aspect-ratio: 3/4;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  text-align: center;
  padding: 18px;
  cursor: pointer;
  overflow: hidden;
  transition:
    border-color var(--form-t-fast) var(--form-ease),
    background var(--form-t-fast) var(--form-ease);
}
.dropzone:hover,
.dropzone.drag{
  border-color: var(--form-accent);
  background: var(--form-bg);
}
.dropzone.filled{
  border-style: solid;
  border-color: var(--form-accent);
  background: transparent;
}

/* upload icon hidden — replaced with typographic UPLOAD label */
.dropzone .dz-ico{ display: none; }

/* italic-serif slot label, top-left */
.dropzone .dz-label{
  position: absolute;
  top: 18px; left: 18px; right: 18px;
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 15px;
  color: var(--form-ink);
  text-align: left;
  letter-spacing: 0;
}

/* small caps optional / UPLOAD hint at bottom */
.dropzone .dz-opt{
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--form-muted);
  align-self: center;
  margin-bottom: 4px;
  transition: color var(--form-t-fast) var(--form-ease);
}
.dropzone:hover .dz-opt{ color: var(--form-accent); }

/* the actual UPLOAD button-equivalent that reveals on hover */
.dropzone::after{
  content: 'Upload';
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--form-accent);
  opacity: 0;
  transition: opacity var(--form-t-fast) var(--form-ease);
  pointer-events: none;
}
.dropzone:hover::after{ opacity: 1; }
.dropzone.filled::after{ content: none; }
.dropzone.filled .dz-opt{ display: none; }

/* filled state — photo fills the frame */
.dropzone img{
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: contrast(1.02) saturate(0.98);
}
/* keep the slot label visible over photo as a small caption strip */
.dropzone.filled .dz-label{ display: none; }

/* the badge that JSX renders on filled state — restyled as small italic caption */
.dropzone .badge-view{
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 10px 14px;
  background: linear-gradient(to top, rgba(26,20,13,0.65), transparent);
  color: #FBF7EF;
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0;
  text-transform: lowercase;
  text-align: left;
  border-radius: 0;
  z-index: 2;
}

/* remove button — small square, top-right, paper bg */
.dropzone .remove{
  position: absolute;
  top: 10px; right: 10px;
  width: 28px; height: 28px;
  border-radius: 0;
  background: var(--form-bg);
  color: var(--form-ink);
  border: 1px solid var(--form-line);
  display: flex; align-items: center; justify-content: center;
  z-index: 3;
  cursor: pointer;
  transition:
    background var(--form-t-fast) var(--form-ease),
    color var(--form-t-fast) var(--form-ease),
    border-color var(--form-t-fast) var(--form-ease);
}
.dropzone .remove:hover{
  background: var(--form-ink);
  color: var(--form-bg);
  border-color: var(--form-ink);
}
.dropzone .remove svg{ width: 12px; height: 12px; }

/* upload hint line under the grid */
.upload-hint{
  margin-top: 28px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 14px;
  color: var(--form-muted);
}
.upload-hint svg{
  width: 14px; height: 14px;
  color: var(--form-accent);
  flex: none;
}

/* ============================================================
   REVIEW — printed contract / definition list
   ============================================================ */
.review-grid{
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--form-line);
}
.review-block{
  padding: 24px 0;
  border: 0;
  border-bottom: 1px solid var(--form-line);
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: 32px;
  align-items: start;
}
.review-block .rk{
  font-family: var(--form-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--form-muted);
  padding-top: 6px;
}
.review-block .rv{
  font-family: var(--form-serif);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.5;
  color: var(--form-ink);
}
.review-block .rv > div + div{
  margin-top: 6px;
  font-family: var(--form-sans);
  font-size: 14px;
  color: var(--form-ink2) !important;
}
.review-block .rv .muted{
  color: var(--form-muted);
  font-style: italic;
}

/* concern tags rendered as italic-serif list, not pills */
.review-block .rv ul{
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  margin: 0;
  padding: 0;
}
.review-block .rv li{
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 17px;
  color: var(--form-ink);
  background: transparent;
  padding: 0;
  border-radius: 0;
  position: relative;
}
.review-block .rv li:not(:last-child)::after{
  content: '  ·';
  color: var(--form-accent);
  margin-left: 8px;
}

.review-edit{
  font-family: var(--form-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--form-ink);
  background: none;
  border: 0;
  border-bottom: 1px solid transparent;
  padding: 6px 0;
  cursor: pointer;
  transition: border-color var(--form-t-fast) var(--form-ease), color var(--form-t-fast) var(--form-ease);
}
.review-edit:hover{
  color: var(--form-accent);
  border-bottom-color: var(--form-accent);
  text-decoration: none;
}

/* consent row — same 24px square checkbox + italic serif text */
.consent{
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 24px;
  align-items: start;
  margin-top: 48px;
  padding: 28px 0 0;
  background: transparent;
  border: 0;
  border-top: 1px solid var(--form-line);
  border-radius: 0;
}
.consent input{
  -webkit-appearance: none;
  appearance: none;
  width: 22px; height: 22px;
  margin: 0;
  border: 1px solid var(--form-line);
  background: var(--form-bg);
  border-radius: 0;
  cursor: pointer;
  position: relative;
  flex: none;
  transition:
    background var(--form-t-fast) var(--form-ease),
    border-color var(--form-t-fast) var(--form-ease);
}
.consent input:checked{
  background: var(--form-accent);
  border-color: var(--form-accent);
}
.consent input:checked::after{
  content: '';
  position: absolute;
  left: 6px; top: 2px;
  width: 6px; height: 12px;
  border: solid var(--form-bg);
  border-width: 0 1.5px 1.5px 0;
  transform: rotate(45deg);
}
.consent input:focus-visible{
  outline: 2px solid var(--form-accent);
  outline-offset: 3px;
}
.consent label{
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  color: var(--form-ink2);
  cursor: pointer;
}

/* ============================================================
   STICKY FOOTER NAV — slim paper bar, text-only links
   ============================================================ */
.form-foot{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px clamp(24px, 4vw, 64px) calc(18px + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid var(--form-line);
  background: var(--form-bg);
  height: 64px;
  box-sizing: content-box;
}
.form-foot .save-note{
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 13px;
  color: var(--form-muted);
  display: flex;
  align-items: center;
  gap: 8px;
}
.form-foot .save-note svg{
  width: 13px; height: 13px;
  color: var(--form-accent);
}
.form-foot .nav-btns{
  display: flex;
  gap: 32px;
  align-items: center;
}

/* BACK — text-only, muted */
.btn-back{
  background: transparent;
  border: 0;
  border-bottom: 1px solid transparent;
  color: var(--form-muted);
  padding: 8px 0;
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  border-radius: 0;
  cursor: pointer;
  transition: color var(--form-t-fast) var(--form-ease), border-color var(--form-t-fast) var(--form-ease);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn-back:hover{
  color: var(--form-ink);
  border-bottom-color: var(--form-ink);
}
.btn-back svg{ width: 14px; height: 14px; }

/* CONTINUE — text-only Hanken caps, ink default, accent hover */
.btn-next{
  background: transparent;
  color: var(--form-ink);
  border: 0;
  border-bottom: 1px solid transparent;
  padding: 8px 0;
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  border-radius: 0;
  cursor: pointer;
  transition: color var(--form-t-fast) var(--form-ease), border-color var(--form-t-fast) var(--form-ease);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.btn-next:hover{
  color: var(--form-accent);
  border-bottom-color: var(--form-accent);
}
.btn-next .arrow{
  display: inline-flex;
  align-items: center;
}
.btn-next .arrow svg{
  width: 14px; height: 14px;
  transition: transform var(--form-t-fast) var(--form-ease);
}
.btn-next:hover .arrow svg{ transform: translateX(4px); }

/* Final-step SUBMIT — promoted to the wide accent pill */
.btn-next.btn-gold,
.btn.btn-gold.btn-next{
  background: var(--form-accent);
  color: var(--form-bg);
  border: 0;
  border-radius: 999px;
  padding: 16px 44px;
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  transition:
    background var(--form-t-base) var(--form-ease),
    color var(--form-t-base) var(--form-ease);
}
.btn-next.btn-gold:hover,
.btn.btn-gold.btn-next:hover{
  background: var(--form-ink);
  color: var(--form-bg);
  border-bottom-color: transparent;
}

/* generic .btn / .btn-primary fallback if jsx uses them */
.btn{
  font-family: var(--form-sans);
  border-radius: 999px;
  cursor: pointer;
}
.btn-primary{
  background: var(--form-accent);
  color: var(--form-bg);
  padding: 14px 40px;
  border: 0;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  transition: background var(--form-t-base) var(--form-ease);
}
.btn-primary:hover{ background: var(--form-ink); }
.btn-light{
  background: transparent;
  color: var(--form-ink);
  border: 1px solid var(--form-line);
  padding: 14px 40px;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  transition: border-color var(--form-t-fast) var(--form-ease), color var(--form-t-fast) var(--form-ease);
}
.btn-light:hover{ border-color: var(--form-ink); color: var(--form-ink); }
.btn-gold{
  background: var(--form-accent);
  color: var(--form-bg);
  border: 0;
}

/* keyboard focus on nav */
.btn-back:focus-visible,
.btn-next:focus-visible,
.btn:focus-visible{
  outline: 2px solid var(--form-accent);
  outline-offset: 4px;
  border-radius: 2px;
}

/* leave room for sticky footer at bottom of shell */
.form-shell{
  padding-bottom: clamp(140px, 18vw, 200px);
}

/* ============================================================
   META PILL ROW (above the shell, when used)
   In the brief this becomes a single small-caps line.
   ============================================================ */
.form-meta-row{
  display: block;
  text-align: center;
  margin: 32px 0 0;
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 11px;
  line-height: 1.6;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--form-muted);
}
.meta-pill{
  display: inline;
  background: none;
  border: 0;
  padding: 0;
  border-radius: 0;
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
}
.meta-pill svg,
.meta-pill .ic{ display: none; }
.meta-pill::after{
  content: '  ·  ';
  color: var(--form-accent);
}
.meta-pill:last-child::after{ content: none; }

/* ============================================================
   THANK-YOU OVERLAY — full ivory, oversized italic serif
   ============================================================ */
.thanks-overlay{
  position: fixed;
  inset: 0;
  z-index: 120;
  background: var(--form-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  animation: thanksFade var(--form-t-slow) var(--form-ease) both;
}
@keyframes thanksFade{
  from{ opacity: 0; }
  to  { opacity: 1; }
}
.thanks-card{
  max-width: 720px;
  text-align: center;
  color: var(--form-ink);
  animation: thanksRise var(--form-t-slow) calc(.1s) var(--form-ease) both;
}
@keyframes thanksRise{
  from{ opacity: 0; transform: translateY(16px); }
  to  { opacity: 1; transform: translateY(0); }
}

/* hide the seal — pure typography */
.thanks-seal{ display: none; }

.thanks-card .eyebrow{
  display: inline-block;
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 11.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--form-muted);
  margin: 0 0 32px;
  justify-content: center;
}
.thanks-card .eyebrow.center{ text-align: center; }

.thanks-card h2{
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(72px, 10vw, 144px);
  line-height: .98;
  letter-spacing: -.03em;
  color: var(--form-ink);
  margin: 0 0 40px;
}
.thanks-card h2 em{
  font-style: italic;
  color: var(--form-accent);
  display: block;
}

.thanks-card p{
  font-family: var(--form-sans);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.65;
  color: var(--form-ink2);
  max-width: 56ch;
  margin: 0 auto 16px;
}

.thanks-actions{
  display: flex;
  gap: 24px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 48px;
}

.thanks-actions .btn{
  background: transparent;
  color: var(--form-ink);
  border: 0;
  border-bottom: 1px solid var(--form-ink);
  border-radius: 0;
  padding: 10px 0;
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  transition: color var(--form-t-fast) var(--form-ease), border-color var(--form-t-fast) var(--form-ease);
}
.thanks-actions .btn:hover{
  color: var(--form-accent);
  border-bottom-color: var(--form-accent);
}
.thanks-actions .btn.btn-gold{
  background: var(--form-accent);
  color: var(--form-bg);
  padding: 16px 44px;
  border-radius: 999px;
  border: 0;
}
.thanks-actions .btn.btn-gold:hover{
  background: var(--form-ink);
  color: var(--form-bg);
  border: 0;
}

.thanks-detail{
  margin-top: 64px;
  padding-top: 40px;
  border-top: 1px solid var(--form-line);
  display: flex;
  gap: 48px;
  justify-content: center;
  flex-wrap: wrap;
}
.thanks-detail .td{ text-align: center; }
.thanks-detail .td .l{
  font-family: var(--form-sans);
  font-weight: 500;
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--form-muted);
  margin-bottom: 10px;
}
.thanks-detail .td .v{
  font-family: var(--form-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 17px;
  color: var(--form-ink);
}

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 880px){
  .form-shell{
    max-width: 100%;
    padding: clamp(72px, 14vw, 120px) 24px clamp(140px, 18vw, 200px);
  }
  .form-shell::before{ height: 80px; }
  .form-head{ padding: 16px 24px 0; }
  .form-step-label{ font-size: 15px; }
  .form-step-count{ font-size: 10.5px; }
}

@media (max-width: 680px){
  .step-head h3{
    font-size: clamp(32px, 7vw, 40px);
    line-height: 1.08;
  }
  .step-head p{ font-size: 15px; }

  .field-grid{
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .field label{ font-size: 11px; }
  .input, .textarea, select.input{ font-size: 16px; }

  /* choice rows — single column, tall tap targets */
  .choice-grid{ gap: 0; }
  .choice{
    grid-template-columns: 24px 1fr;
    gap: 18px;
    padding: 22px 0;
    min-height: 56px;
  }
  .choice .ctxt{ font-size: 17px; }

  /* yes/no stacks below the question on mobile */
  .qa{
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
    padding: 28px 0;
  }
  .qa .q{ max-width: 100%; font-size: 19px; }
  .seg{ width: 100%; gap: 32px; }
  .seg button{ font-size: 18px; min-height: 44px; }

  /* photos — 2x3 */
  .upload-grid{
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .dropzone .dz-label{ font-size: 14px; }

  /* review goes single-column */
  .review-block{
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 24px 0;
  }
  .review-edit{ justify-self: start; }
  .review-block .rv{ font-size: 17px; }

  /* sticky footer — full-width with 56px tap targets */
  .form-foot{
    padding: 12px 20px calc(12px + env(safe-area-inset-bottom, 0px));
    height: 56px;
  }
  .form-foot .save-note{ display: none; }
  .form-foot .nav-btns{
    width: 100%;
    justify-content: space-between;
    gap: 12px;
  }
  .btn-back, .btn-next{
    min-height: 44px;
    padding: 10px 0;
    display: inline-flex;
    align-items: center;
  }
  .btn-next.btn-gold,
  .btn.btn-gold.btn-next{
    padding: 14px 28px;
    font-size: 12px;
  }

  /* thanks scales down nicely */
  .thanks-card h2{ font-size: clamp(56px, 14vw, 88px); }
  .thanks-detail{ gap: 28px; }
}

/* ============================================================
   REDUCED MOTION — strip transforms and curtains
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  .step-anim,
  .conditional,
  .thanks-overlay,
  .thanks-card{
    animation: stepFadeOnly .2s ease-out both;
    transform: none !important;
  }
  .progress-fill,
  .input, .textarea, select.input,
  .choice, .choice .check,
  .seg button, .seg button::before,
  .radio, .radio .ring,
  .dropzone, .dropzone::after,
  .btn, .btn-back, .btn-next,
  .review-edit, .thanks-actions .btn{
    transition-duration: .2s !important;
  }
  .btn-next:hover .arrow svg{ transform: none; }
}

/* ============================================================
   PRINT — clean intake printout
   ============================================================ */
@media print{
  .form-head, .form-foot, .progress-rail, .step-dots{ display: none; }
  .form-shell{ padding: 0; max-width: 100%; }
  .form-shell::before{ display: none; }
  .step-anim{ animation: none; }
}
