
    /* =========================================================
       BRAND COLOUR SYSTEM
    ========================================================= */
    :root {
      --dark:       #13544E;
      --heading:    #095D40;
      --accent:     #6C9A40;
      --cta:        #008060;
      --lime:       #D3E162;
      --lime-light: #E4F577;
      --bg:         #FBF7ED;
      --alt:        #E0EDD4;
      --text:       #212B36;
      --muted:      #5a6a75;
      --white:      #ffffff;
      --error:      #ef4444;
      --success:    #22c55e;
      --radius:     12px;
      --radius-lg:  20px;
      --shadow:     0 4px 24px rgba(9,93,64,0.09);
      --shadow-lg:  0 8px 40px rgba(9,93,64,0.14);
      --shadow-xl:  0 16px 64px rgba(9,93,64,0.18);
      --transition: all 0.25s ease;
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'Inter', sans-serif;
      background: var(--bg);
      color: var(--text);
      font-size: 16px;
      line-height: 1.65;
      -webkit-font-smoothing: antialiased;
    }
    a { text-decoration: none; color: inherit; }
    .container    { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
    .container-sm { max-width: 760px;  margin: 0 auto; padding: 0 24px; }

    /* =========================================================
       SECTION 1 — MINIMAL NAV
    ========================================================= */
    .form-nav {
      background: var(--white);
      border-bottom: 1px solid rgba(9,93,64,0.10);
      box-shadow: 0 2px 10px rgba(9,93,64,0.07);
      padding: 14px 0;
    }
    .form-nav-inner {
      display: flex; align-items: center; justify-content: space-between; gap: 16px;
    }
    .nav-logo { font-size: 1.12rem; font-weight: 900; color: var(--heading); }
    .nav-logo .acc { color: var(--accent); }
    .nav-badge {
      display: inline-flex; align-items: center; gap: 5px;
      background: var(--lime); color: var(--heading);
      font-size: 0.68rem; font-weight: 900;
      padding: 3px 10px; border-radius: 100px; margin-left: 10px;
      text-transform: uppercase; letter-spacing: 0.04em;
    }
    .nav-save-note {
      display: flex; align-items: center; gap: 7px;
      font-size: 0.80rem; color: var(--muted); font-weight: 600;
    }
    .nav-save-note i { color: var(--cta); font-size: 0.72rem; }
    .nav-help {
      display: inline-flex; align-items: center; gap: 6px;
      font-size: 0.82rem; font-weight: 700; color: var(--muted);
      padding: 7px 14px; border-radius: 8px;
      border: 1.5px solid rgba(9,93,64,0.14); transition: var(--transition);
    }
    .nav-help:hover { border-color: var(--cta); color: var(--cta); background: rgba(0,128,96,0.04); }

    /* =========================================================
       SECTION 2 — PROGRESS BAR
    ========================================================= */
    .progress-section {
      background: var(--white);
      border-bottom: 1px solid rgba(9,93,64,0.08);
      padding: 18px 0 14px;
      position: sticky; top: 0; z-index: 900;
      box-shadow: 0 4px 16px rgba(9,93,64,0.08);
    }
    .progress-top {
      display: flex; align-items: center; justify-content: space-between;
      margin-bottom: 10px; flex-wrap: wrap; gap: 8px;
    }
    .progress-step-label { font-size: 0.84rem; font-weight: 800; color: var(--heading); }
    .progress-step-label span { color: var(--cta); }
    .progress-pct-label { font-size: 0.80rem; font-weight: 900; color: var(--cta); }
    .progress-bar-track {
      width: 100%; height: 8px; background: var(--alt);
      border-radius: 100px; overflow: hidden; margin-bottom: 14px;
    }
    .progress-bar-fill {
      height: 100%;
      background: linear-gradient(90deg, var(--cta), var(--lime));
      border-radius: 100px; width: 16.66%;
      transition: width 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
    }
    /* Step dots */
    .step-dots { display: flex; align-items: center; gap: 0; }
    .step-dot-wrap {
      display: flex; align-items: center; flex: 1;
    }
    .step-dot-wrap:last-child { flex: none; }
    .step-dot {
      width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
      display: flex; align-items: center; justify-content: center;
      font-size: 0.72rem; font-weight: 900; cursor: pointer;
      border: 2px solid rgba(9,93,64,0.18); background: var(--white);
      color: var(--muted); transition: var(--transition); position: relative;
    }
    .step-dot.done    { background: var(--cta); color: var(--white); border-color: var(--cta); }
    .step-dot.active  { background: var(--lime); color: var(--heading); border-color: var(--heading); box-shadow: 0 0 0 4px rgba(211,225,98,0.30); }
    .step-dot.pending { background: var(--alt); color: var(--muted); border-color: transparent; }
    .step-connector { flex: 1; height: 2px; background: var(--alt); margin: 0 4px; }
    .step-connector.done { background: var(--cta); }
    .step-label {
      position: absolute; top: 36px; left: 50%; transform: translateX(-50%);
      font-size: 0.64rem; font-weight: 800; white-space: nowrap; color: var(--muted);
    }
    .step-dot.active .step-label,
    .step-dot.done  .step-label { color: var(--heading); }
    .step-dots-container { position: relative; padding-bottom: 20px; }

    /* =========================================================
       FORM WRAPPER
    ========================================================= */
    .form-wrapper { padding: 44px 0 72px; }
    .form-card {
      background: var(--white);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-lg);
      border: 1.5px solid rgba(9,93,64,0.09);
      overflow: hidden;
    }
    .form-card-header {
      background: var(--heading);
      padding: 24px 32px;
      display: flex; align-items: center; gap: 16px;
    }
    .fch-icon {
      width: 48px; height: 48px; border-radius: 13px;
      background: rgba(211,225,98,0.18);
      display: flex; align-items: center; justify-content: center;
      font-size: 1.2rem; color: var(--lime); flex-shrink: 0;
    }
    .fch-text h2 { font-size: 1.05rem; font-weight: 900; color: var(--white); margin-bottom: 3px; }
    .fch-text p  { font-size: 0.82rem; color: rgba(255,255,255,0.68); }
    .fch-step-badge {
      margin-left: auto; flex-shrink: 0;
      background: rgba(211,225,98,0.18); border: 1px solid rgba(211,225,98,0.30);
      color: var(--lime); font-size: 0.74rem; font-weight: 900;
      padding: 4px 14px; border-radius: 100px;
    }
    .form-card-body { padding: 36px 32px; }

    /* =========================================================
       FORM ELEMENTS
    ========================================================= */
    .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
    .form-grid.three { grid-template-columns: 1fr 1fr 1fr; }
    .form-grid.full  { grid-template-columns: 1fr; }

    .form-group { display: flex; flex-direction: column; gap: 6px; }
    .form-group.full-width { grid-column: 1 / -1; }

    .form-group label {
      font-size: 0.84rem; font-weight: 800; color: var(--heading);
      display: flex; align-items: center; gap: 6px;
    }
    .form-group label .req {
      color: var(--error); font-size: 0.70rem;
    }
    .form-group label .opt {
      color: var(--muted); font-size: 0.68rem; font-weight: 600;
      background: var(--alt); padding: 1px 7px; border-radius: 100px;
    }
    .field-hint { font-size: 0.76rem; color: var(--muted); }

    /* Input / Select / Textarea */
    .form-group input,
    .form-group select,
    .form-group textarea {
      width: 100%; padding: 11px 14px;
      border: 1.5px solid rgba(9,93,64,0.15);
      border-radius: var(--radius); background: var(--bg);
      color: var(--text); font-family: inherit;
      font-size: 0.93rem; outline: none;
      transition: var(--transition);
    }
    .form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus {
      border-color: var(--cta); background: var(--white);
      box-shadow: 0 0 0 3px rgba(0,128,96,0.10);
    }
    .form-group input::placeholder,
    .form-group textarea::placeholder { color: #aab3bb; }
    .form-group textarea { resize: vertical; min-height: 96px; }
    .form-group select { cursor: pointer; appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a6a75' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
      background-repeat: no-repeat; background-position: right 14px center;
      padding-right: 36px;
    }
    .form-group input.error,
    .form-group select.error,
    .form-group textarea.error {
      border-color: var(--error); background: #fef2f2;
    }
    .field-error {
      display: none; font-size: 0.76rem; color: var(--error);
      font-weight: 700; align-items: center; gap: 5px;
    }
    .field-error.show { display: flex; }
    .field-error i { font-size: 0.68rem; }

    /* Input with icon */
    .input-icon-wrap { position: relative; }
    .input-icon-wrap i {
      position: absolute; left: 13px; top: 50%; transform: translateY(-50%);
      color: var(--muted); font-size: 0.80rem; pointer-events: none;
    }
    .input-icon-wrap input { padding-left: 36px; }
    .input-icon-wrap.right-icon i.right {
      left: auto; right: 13px;
    }

    /* Radio groups */
    .radio-group { display: flex; flex-direction: column; gap: 8px; }
    .radio-group.inline { flex-direction: row; flex-wrap: wrap; gap: 8px; }
    .radio-opt {
      display: flex; align-items: center; gap: 10px;
      background: var(--bg); border: 1.5px solid rgba(9,93,64,0.13);
      border-radius: var(--radius); padding: 10px 14px;
      cursor: pointer; transition: var(--transition); user-select: none;
    }
    .radio-opt:hover { border-color: var(--cta); background: rgba(0,128,96,0.04); }
    .radio-opt.selected { border-color: var(--cta); background: rgba(0,128,96,0.07); }
    .radio-opt.selected .ro-dot { background: var(--cta); border-color: var(--cta); }
    .radio-opt.selected .ro-dot::after { opacity: 1; }
    .ro-dot {
      width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
      border: 2px solid rgba(9,93,64,0.25); background: var(--white);
      position: relative; transition: var(--transition);
    }
    .ro-dot::after {
      content: ''; position: absolute; top: 50%; left: 50%;
      transform: translate(-50%, -50%);
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--white); opacity: 0; transition: var(--transition);
    }
    .ro-label { font-size: 0.88rem; font-weight: 600; color: var(--text); flex: 1; }
    .ro-label em { font-size: 0.76rem; font-style: normal; color: var(--muted); margin-left: 4px; }
    .ro-check {
      width: 20px; height: 20px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 0.62rem; color: var(--white); flex-shrink: 0;
      opacity: 0; transition: var(--transition);
    }
    .radio-opt.selected .ro-check { opacity: 1; background: var(--cta); }

    /* Checkbox */
    .checkbox-opt {
      display: flex; align-items: flex-start; gap: 10px;
      background: var(--bg); border: 1.5px solid rgba(9,93,64,0.13);
      border-radius: var(--radius); padding: 12px 14px;
      cursor: pointer; transition: var(--transition);
    }
    .checkbox-opt:hover { border-color: var(--cta); }
    .checkbox-opt.checked { border-color: var(--cta); background: rgba(0,128,96,0.06); }
    .cb-box {
      width: 18px; height: 18px; border-radius: 4px; flex-shrink: 0;
      border: 2px solid rgba(9,93,64,0.25); background: var(--white);
      display: flex; align-items: center; justify-content: center;
      font-size: 0.62rem; color: transparent; transition: var(--transition);
      margin-top: 2px;
    }
    .checkbox-opt.checked .cb-box { background: var(--cta); border-color: var(--cta); color: var(--white); }

    /* Color pickers */
    .color-picker-group { display: flex; align-items: center; gap: 10px; }
    .color-preview {
      width: 40px; height: 40px; border-radius: 9px; flex-shrink: 0;
      border: 2px solid rgba(9,93,64,0.15); cursor: pointer; overflow: hidden;
    }
    .color-preview input[type="color"] {
      width: 100%; height: 100%; border: none; padding: 0; cursor: pointer;
      background: none;
    }
    .color-hex-input { flex: 1; }

    /* File upload */
    .file-upload-zone {
      border: 2px dashed rgba(9,93,64,0.25); border-radius: var(--radius-lg);
      padding: 28px; text-align: center; cursor: pointer;
      background: var(--bg); transition: var(--transition); position: relative;
    }
    .file-upload-zone:hover,
    .file-upload-zone.drag-over {
      border-color: var(--cta); background: rgba(0,128,96,0.04);
    }
    .file-upload-zone input[type="file"] {
      position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
    }
    .fuz-icon { font-size: 2rem; color: var(--cta); margin-bottom: 10px; opacity: 0.60; }
    .fuz-main { font-size: 0.90rem; font-weight: 800; color: var(--heading); margin-bottom: 4px; }
    .fuz-sub  { font-size: 0.78rem; color: var(--muted); }
    .fuz-types { display: inline-flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; justify-content: center; }
    .fuz-type { font-size: 0.68rem; font-weight: 800; padding: 2px 9px; border-radius: 100px; background: var(--alt); color: var(--heading); }
    .file-preview {
      display: none; align-items: center; gap: 10px;
      background: #dcfce7; border: 1.5px solid #86efac;
      border-radius: var(--radius); padding: 10px 14px; margin-top: 10px;
    }
    .file-preview.show { display: flex; }
    .file-preview i { color: var(--cta); }
    .file-preview span { font-size: 0.84rem; font-weight: 700; color: #14532d; flex: 1; }
    .file-preview button { background: none; border: none; cursor: pointer; color: #6b7280; font-size: 0.80rem; transition: var(--transition); }
    .file-preview button:hover { color: var(--error); }

    /* Section divider */
    .form-section-divider {
      border: none; border-top: 1.5px solid var(--alt); margin: 26px 0;
    }
    .form-section-title {
      font-size: 0.78rem; font-weight: 900; text-transform: uppercase;
      letter-spacing: 0.08em; color: var(--cta); margin-bottom: 16px;
      display: flex; align-items: center; gap: 8px;
    }
    .form-section-title::after {
      content: ''; flex: 1; height: 1px; background: var(--alt);
    }

    /* Tip box */
    .form-tip {
      display: flex; align-items: flex-start; gap: 10px;
      background: rgba(211,225,98,0.18); border: 1px solid rgba(211,225,98,0.40);
      border-radius: var(--radius); padding: 12px 14px; margin-bottom: 20px;
    }
    .form-tip i { color: var(--heading); font-size: 0.90rem; flex-shrink: 0; margin-top: 1px; }
    .form-tip p { font-size: 0.84rem; color: var(--heading); font-weight: 600; margin: 0; line-height: 1.55; }
    .form-tip a { color: var(--cta); font-weight: 800; text-decoration: underline; }

    /* Step Navigation Buttons */
    .form-nav-btns {
      display: flex; align-items: center; justify-content: space-between;
      margin-top: 32px; padding-top: 24px;
      border-top: 1.5px solid var(--alt); gap: 12px;
    }
    .btn-back {
      display: inline-flex; align-items: center; gap: 7px;
      background: var(--white); border: 2px solid rgba(9,93,64,0.20);
      color: var(--muted); font-size: 0.90rem; font-weight: 800;
      padding: 12px 22px; border-radius: 10px; cursor: pointer;
      font-family: inherit; transition: var(--transition);
    }
    .btn-back:hover { border-color: var(--cta); color: var(--cta); }
    .btn-next {
      display: inline-flex; align-items: center; gap: 8px;
      background: var(--cta); color: var(--white);
      font-size: 0.93rem; font-weight: 900;
      padding: 13px 28px; border-radius: 10px; cursor: pointer;
      font-family: inherit; border: none; transition: var(--transition);
      box-shadow: 0 6px 20px rgba(0,128,96,0.30);
    }
    .btn-next:hover { background: var(--heading); transform: translateY(-2px); }
    .btn-submit {
      display: inline-flex; align-items: center; gap: 9px;
      background: var(--cta); color: var(--white);
      font-size: 0.96rem; font-weight: 900;
      padding: 15px 32px; border-radius: 11px; cursor: pointer;
      font-family: inherit; border: none; transition: var(--transition);
      box-shadow: 0 8px 28px rgba(0,128,96,0.35);
    }
    .btn-submit:hover { background: var(--heading); transform: translateY(-2px); }
    .btn-save-progress {
      font-size: 0.78rem; font-weight: 700; color: var(--muted);
      background: none; border: none; cursor: pointer;
      font-family: inherit; display: flex; align-items: center; gap: 5px;
      transition: var(--transition);
    }
    .btn-save-progress:hover { color: var(--cta); }

    /* =========================================================
       REVIEW STEP — Summary Cards
    ========================================================= */
    .review-sections { display: flex; flex-direction: column; gap: 14px; margin-bottom: 26px; }
    .review-card {
      background: var(--bg); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.10);
      overflow: hidden;
    }
    .review-card-header {
      display: flex; align-items: center; justify-content: space-between;
      padding: 14px 18px; background: var(--alt);
    }
    .rch-left { display: flex; align-items: center; gap: 10px; }
    .rch-icon {
      width: 32px; height: 32px; border-radius: 8px;
      background: var(--heading); color: var(--lime);
      display: flex; align-items: center; justify-content: center;
      font-size: 0.80rem; flex-shrink: 0;
    }
    .rch-title { font-size: 0.86rem; font-weight: 900; color: var(--heading); }
    .rch-edit {
      display: inline-flex; align-items: center; gap: 5px;
      font-size: 0.76rem; font-weight: 800; color: var(--cta);
      background: var(--white); border: 1.5px solid rgba(9,93,64,0.15);
      padding: 4px 12px; border-radius: 100px; cursor: pointer;
      transition: var(--transition); font-family: inherit;
    }
    .rch-edit:hover { background: var(--cta); color: var(--white); border-color: var(--cta); }
    .review-body { padding: 16px 18px; }
    .review-row {
      display: flex; gap: 10px; padding: 6px 0;
      border-bottom: 1px solid rgba(9,93,64,0.07); font-size: 0.86rem;
    }
    .review-row:last-child { border-bottom: none; }
    .review-row-key { font-weight: 800; color: var(--heading); min-width: 160px; flex-shrink: 0; }
    .review-row-val { color: var(--text); }
    .review-row-val.empty { color: var(--muted); font-style: italic; }
    .review-complete-badge {
      display: inline-flex; align-items: center; gap: 5px;
      font-size: 0.68rem; font-weight: 800; padding: 2px 9px; border-radius: 100px;
    }
    .review-complete-badge.done { background: #dcfce7; color: #15803d; }
    .review-complete-badge.partial { background: #fef3c7; color: #92400e; }

    /* Confirm checkboxes */
    .confirm-checks { display: flex; flex-direction: column; gap: 10px; margin-bottom: 26px; }

    /* =========================================================
       STEP PANELS
    ========================================================= */
    .step-panel { display: none; }
    .step-panel.active { display: block; }

    /* =========================================================
       SUCCESS SCREEN
    ========================================================= */
    .success-screen {
      display: none; text-align: center; padding: 56px 32px;
    }
    .success-screen.show { display: block; }
    .ss-emoji { font-size: 4rem; margin-bottom: 20px; display: block; }
    .ss-confetti { font-size: 1.5rem; margin-bottom: 4px; }
    .success-screen h2 { font-size: clamp(1.5rem, 3vw, 2rem); font-weight: 900; color: var(--heading); margin-bottom: 12px; }
    .success-screen p { font-size: 0.96rem; color: var(--muted); line-height: 1.72; margin-bottom: 28px; max-width: 520px; margin-left: auto; margin-right: auto; }
    .ss-next-steps { display: flex; flex-direction: column; gap: 12px; max-width: 500px; margin: 0 auto 28px; }
    .ss-step {
      display: flex; align-items: flex-start; gap: 12px;
      background: var(--alt); border-radius: var(--radius-lg); padding: 14px 16px; text-align: left;
    }
    .ss-step-num {
      width: 32px; height: 32px; border-radius: 50%;
      background: var(--heading); color: var(--lime);
      font-size: 0.80rem; font-weight: 900;
      display: flex; align-items: center; justify-content: center; flex-shrink: 0;
    }
    .ss-step h5 { font-size: 0.88rem; font-weight: 900; color: var(--heading); margin-bottom: 3px; }
    .ss-step p  { font-size: 0.80rem; color: var(--muted); margin: 0; }
    .ss-cta {
      display: inline-flex; align-items: center; gap: 8px;
      background: var(--cta); color: var(--white);
      font-size: 0.92rem; font-weight: 900;
      padding: 13px 26px; border-radius: 10px; transition: var(--transition);
    }
    .ss-cta:hover { background: var(--heading); transform: translateY(-2px); }

    /* =========================================================
       SIDEBAR
    ========================================================= */
    .form-layout { display: grid; grid-template-columns: 1fr 320px; gap: 28px; align-items: start; }
    .sidebar { display: flex; flex-direction: column; gap: 18px; }
    .sidebar-card {
      background: var(--white); border-radius: var(--radius-lg);
      border: 1.5px solid rgba(9,93,64,0.09); box-shadow: var(--shadow);
      overflow: hidden;
    }
    .sidebar-card-header {
      background: var(--heading); padding: 14px 18px;
      font-size: 0.84rem; font-weight: 900; color: var(--lime);
      display: flex; align-items: center; gap: 8px;
    }
    .sidebar-card-body { padding: 16px 18px; }
    .sc-item { display: flex; align-items: flex-start; gap: 9px; margin-bottom: 11px; }
    .sc-item:last-child { margin-bottom: 0; }
    .sc-icon { color: var(--cta); font-size: 0.84rem; flex-shrink: 0; margin-top: 2px; }
    .sc-text h5 { font-size: 0.84rem; font-weight: 800; color: var(--heading); margin-bottom: 2px; }
    .sc-text p  { font-size: 0.78rem; color: var(--muted); line-height: 1.55; margin: 0; }
    .team-mini { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--alt); }
    .team-mini:last-child { border-bottom: none; padding-bottom: 0; }
    .tm-avatar { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 0.72rem; font-weight: 900; color: var(--lime); }
    .tm-info h6 { font-size: 0.82rem; font-weight: 800; color: var(--heading); }
    .tm-info span { font-size: 0.74rem; color: var(--muted); }
    .tm-online { width: 8px; height: 8px; border-radius: 50%; background: var(--success); margin-left: auto; border: 1.5px solid var(--white); }

    /* =========================================================
       FOOTER
    ========================================================= */
    .form-footer {
      background: var(--dark); padding: 22px 0;
      text-align: center; color: rgba(255,255,255,0.55);
    }
    .form-footer-inner {
      display: flex; align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: 12px;
    }
    .form-footer a { color: rgba(255,255,255,0.55); font-size: 0.80rem; transition: var(--transition); }
    .form-footer a:hover { color: var(--lime); }
    .form-footer p { font-size: 0.80rem; }
    .form-footer-links { display: flex; gap: 16px; }
    .form-footer-secure {
      display: flex; align-items: center; gap: 6px;
      font-size: 0.78rem; color: rgba(255,255,255,0.55);
    }
    .form-footer-secure i { color: var(--lime); font-size: 0.72rem; }

    /* =========================================================
       RESPONSIVE
    ========================================================= */
    @media (max-width: 1024px) {
      .form-layout { grid-template-columns: 1fr; }
      .sidebar { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
    }
    @media (max-width: 768px) {
      .form-grid { grid-template-columns: 1fr; }
      .form-grid.three { grid-template-columns: 1fr; }
      .form-card-body { padding: 22px 18px; }
      .form-card-header { padding: 18px; }
      .sidebar { grid-template-columns: 1fr; }
      .form-nav-btns { flex-wrap: wrap; }
      .btn-back, .btn-next, .btn-submit { width: 100%; justify-content: center; }
      .step-dots-container { overflow-x: auto; padding-bottom: 24px; }
      .step-dots { min-width: 400px; }
    }
    @media (max-width: 480px) {
      .form-footer-inner { flex-direction: column; text-align: center; }
    }
  