    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    body {
      font-family: 'Satoshi', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
      line-height: 1.6;
      background-color: #434935;
      color: white;
      min-height: 100vh;
    }

    /* Main container */
    .bg-\[#434935\] {
      background-color: #434935 !important;
    }

    .flex {
      display: flex !important;
    }

    .items-start {
      align-items: flex-start !important;
    }

    .justify-center {
      justify-content: center !important;
    }

    .min-h-\[90vh\] {
      min-height: 90vh !important;
    }

    /* Form container */
    .w-full {
      width: 100% !important;
    }

    .max-w-4xl {
      max-width: 56rem !important;
    }

    .bg-transparent {
      background-color: transparent !important;
    }

    .px-5 {
      padding-left: 1.25rem !important;
      padding-right: 1.25rem !important;
    }
    .px-0 {
      padding-left: 0 !important;
      padding-right: 0 !important;
    }

    .py-12 {
      padding-top: 3rem !important;
      padding-bottom: 3rem !important;
    }

/* Prevent footer overlap on desktop */
.assessment-bottom-space {
  padding-bottom: 10rem !important;
}

    .relative {
      position: relative !important;
    }

    .mt-10 {
      margin-top: 2.5rem !important;
    }

    .h-fit {
      height: fit-content !important;
    }

    /* Header */
    .fixed {
      position: fixed !important;
    }

    .top-0 {
      top: 0 !important;
    }

    .max-w-full {
      max-width: 100% !important;
    }

    .z-50 {
      z-index: 50 !important;
    }

    .transition-colors {
      transition-property: color, background-color, border-color, text-decoration-color, fill, stroke !important;
      transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
      transition-duration: 150ms !important;
    }

    .duration-300 {
      transition-duration: 300ms !important;
    }

    .bg-rgb\(177,
    \ 190,
    \ 168\) {
      background-color: rgb(177, 190, 168) !important;
    }

    .bg-opacity-90 {
      --tw-bg-opacity: 0.9 !important;
    }

    .backdrop-blur-2xl {
      backdrop-filter: blur(40px) !important;
    }

    .shadow-md {
      box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1) !important;
    }

    /* Header content */
    .px-5 {
      padding-left: 1.25rem !important;
      padding-right: 1.25rem !important;
    }

    .md\:px-10 {
      padding-left: 2.5rem !important;
      padding-right: 2.5rem !important;
    }

    .py-5 {
      padding-top: 1.25rem !important;
      padding-bottom: 1.25rem !important;
    }

    .md\:py-5 {
      padding-top: 1.25rem !important;
      padding-bottom: 1.25rem !important;
    }

    .w-\[100vw\] {
      width: 100vw !important;
    }

    .cursor-pointer {
      cursor: pointer !important;
    }

    .space-x-4> :not([hidden])~ :not([hidden]) {
      margin-left: 1rem !important;
    }

    /* Logo styling - exact match to screenshot */
    .logo-img {
      max-width: none !important;
      width: auto !important;
      height: 40px !important;
      object-fit: contain !important;
      background: transparent !important;
      display: block !important;
    }

    @media (min-width: 768px) {
      .logo-img {
        height: 60px !important;
      }
    }

    /* Extra top padding below fixed header */
    .pt-20 {
      padding-top: 8rem !important;
    }

    .pt-10 {
      padding-top: 2.5rem !important;
    }
    .pt-8 {
      padding-top: 2rem !important;
    }
    .pt-6 {
      padding-top: 1.5rem !important;
    }

    /* Form content */
    .mb-8 {
      margin-bottom: 2rem !important;
    }

.overflow-hidden {
  overflow: hidden !important;
}

/* Avoid clipping of controls inside assessment container */
#assessment-container .overflow-hidden {
  overflow: visible !important;
}

    .space-y-8> :not([hidden])~ :not([hidden]) {
      margin-top: 2rem !important;
    }

    .space-y-6> :not([hidden])~ :not([hidden]) {
      margin-top: 1.5rem !important;
    }

    .p-2 {
      padding: 0.5rem !important;
    }

    /* Typography */
    .text-center {
      text-align: center !important;
    }

    .text-white {
      color: rgb(255 255 255) !important;
    }

    .text-3xl {
      font-size: 1.875rem !important;
      line-height: 2.25rem !important;
    }

    /* Larger heading for Step 2 title */
    #step2 h2 {
      font-size: 2.25rem !important; /* Reduced by 2px from 2.375rem */
      line-height: 1.2 !important;
    }

    .text-2xl {
      font-size: 1.5rem !important;
      line-height: 2rem !important;
    }

    .text-lg {
      font-size: 1.125rem !important;
      line-height: 1.75rem !important;
    }

    .text-sm {
      font-size: 0.875rem !important;
      line-height: 1.25rem !important;
    }

    .font-bold {
      font-weight: 700 !important;
    }

    .font-semibold {
      font-weight: 600 !important;
    }

    .font-medium {
      font-weight: 500 !important;
    }

    .mb-4 {
      margin-bottom: 1rem !important;
    }

    .mb-8 {
      margin-bottom: 2rem !important;
    }

    .leading-tight {
      line-height: 1.25 !important;
    }

    .block {
      display: block !important;
    }

    /* Form inputs */
    .w-full {
      width: 100% !important;
    }

    .flex-1 {
      flex: 1 1 0% !important;
      min-width: 0 !important;
    }

    .p-6 {
      padding: 1.5rem !important;
    }

    .py-6 {
      padding-top: 1.5rem !important;
      padding-bottom: 1.5rem !important;
    }

    .px-4 {
      padding-left: 1rem !important;
      padding-right: 1rem !important;
    }

    .px-6 {
      padding-left: 1.5rem !important;
      padding-right: 1.5rem !important;
    }

    .px-8 {
      padding-left: 2rem !important;
      padding-right: 2rem !important;
    }

    .py-3 {
      padding-top: 0.75rem !important;
      padding-bottom: 0.75rem !important;
    }

    .py-4 {
      padding-top: 1rem !important;
      padding-bottom: 1rem !important;
    }

    .text-xl {
      font-size: 1.25rem !important;
      line-height: 1.75rem !important;
    }

    .text-black {
      color: rgb(0 0 0) !important;
    }

    .bg-white\/90 {
      background-color: rgb(255 255 255 / 0.9) !important;
    }

    .border-2 {
      border-width: 2px !important;
    }

    .border-white\/15 {
      border-color: rgb(255 255 255 / 0.15) !important;
    }

    .border-white\/20 {
      border-color: rgb(255 255 255 / 0.2) !important;
    }

    .border-red-400 {
      border-color: rgb(248 113 113) !important;
    }

    .rounded-lg {
      border-radius: 0.75rem !important;
    }

    /* Input field shape to match prototype */
    input[type="text"],
    input[type="number"],
    input[type="tel"],
    input:not([type]) {
      border-radius: 0.75rem !important;
      border: 2px solid rgba(255, 255, 255, 0.35) !important;
      box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), 0 1px 2px rgba(0, 0, 0, 0.08) !important;
      background-color: rgba(255, 255, 255, 0.9) !important;
    }

    .rounded-xl {
      border-radius: 0.75rem !important;
    }

    .rounded-2xl {
      border-radius: 1rem !important;
    }

    .border-none {
      border-style: none !important;
    }

    /* Phone input group - fix alignment */
    .phone-input-group {
      display: flex !important;
      align-items: center !important;
      gap: 0.5rem !important;
      flex-direction: row !important;
    }

/* Make +91 box match other input heights without shrinking phone input */
.phone-input-group #phone {
  height: auto !important;
  line-height: 1.75rem !important; /* match text-lg/xtl leading */
}
.phone-input-group .w-18 {
  height: auto !important;
  padding-top: 1.5rem !important;   /* same as .p-6 */
  padding-bottom: 1.5rem !important;/* same as .p-6 */
}

    .w-18 {
      width: 4.5rem !important;
      font-size: 1rem !important;
      text-align: center !important;
      padding: 1rem 0.75rem !important;
    }

    /* Weight/Height input groups */
    .measurement-group {
      display: grid !important;
      grid-template-columns: 1fr auto !important; /* input grows, unit hugs right */
      column-gap: 0.75rem !important;
      align-items: center !important;
      width: 100% !important;
    }

    .height-input-group {
      display: grid !important;
      grid-template-columns: 1fr auto !important; /* inputs on left, unit on right */
      column-gap: 0.75rem !important;
      align-items: center !important;
      width: 100% !important;
    }

    .height-inputs {
      display: flex !important;
      gap: 0.25rem !important;
      align-items: center !important;
      flex-wrap: nowrap !important;
      min-width: 0 !important;
    }

    .w-20 {
      width: 5rem !important;
    }

    .w-72 {
      width: 18rem !important;
    }

    .text-center {
      text-align: center !important;
    }

    .mx-1 {
      margin-left: 0.25rem !important;
      margin-right: 0.25rem !important;
    }
    .ml-5 {
      margin-left: 1.25rem !important;
    }

    /* Unit Selector */
    .unit-selector {
      display: flex !important;
      align-items: center !important;
      background-color: rgba(255, 255, 255, 0.9) !important;
      border-radius: 0.75rem !important;
      padding: 0.25rem !important;
      border: 2px solid rgba(255, 255, 255, 0.35) !important;
      box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.15), 0 1px 2px rgba(0, 0, 0, 0.08) !important;
      min-width: 64px !important;
      flex-shrink: 0 !important;
      height: 3rem !important; /* visually match input height */
      margin-left: 0 !important;
    }

    /* Step 2 specific: keep height group left-aligned */
    #step2 .height-input-group {
      justify-content: flex-start !important;
      gap: 0.75rem !important;
    }
    
    #step2 .height-inputs.align-left {
      margin-left: 0 !important;
    }
    
    #step2 .unit-selector {
      margin-left: 0 !important;
    }

    .unit-btn {
      flex: 1 1 0% !important;
      padding: 0.5rem 0.75rem !important;
      border-radius: 0.5rem !important;
      cursor: pointer !important;
      transition: all 0.3s ease !important;
      font-size: 0.875rem !important;
      font-weight: 600 !important;
      text-align: center !important;
      border: none !important;
      background: transparent !important;
      color: #434935 !important;
      opacity: 0.7 !important;
    }

    .unit-btn.active {
      background-color: #434935 !important;
      color: white !important;
      opacity: 1 !important;
      box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1) !important;
    }

    .unit-btn:hover:not(.active) {
      opacity: 1 !important;
      background-color: rgb(67 73 53 / 0.1) !important;
    }

    /* Error messages */
    .text-red-400 {
      color: rgb(248 113 113) !important;
    }

    .mt-2 {
      margin-top: 0.5rem !important;
    }

    .ml-1 {
      margin-left: 0.25rem !important;
    }

    /* Privacy text */
    .text-white\/70 {
      color: rgb(255 255 255 / 0.7) !important;
    }

    .text-center {
      text-align: center !important;
    }

    .italic {
      font-style: italic !important;
    }

    .mt-6 {
      margin-top: 1.5rem !important;
    }

    .-top-6 {
      top: -1.5rem !important;
    }

    .-bottom-8 {
      bottom: -2rem !important;
    }

    /* Navigation */
    .fixed {
      position: fixed !important;
    }

    .bottom-0 {
      bottom: 0 !important;
    }

    .left-0 {
      left: 0 !important;
    }

    .right-0 {
      right: 0 !important;
    }

    .bg-\[#434935\] {
      background-color: #434935 !important;
    }

    .border-t {
      border-top-width: 1px !important;
    }

    .border-white\/10 {
      border-color: rgb(255 255 255 / 0.1) !important;
    }

    .max-w-md {
      max-width: 28rem !important;
    }

    .mx-auto {
      margin-left: auto !important;
      margin-right: auto !important;
    }

    /* Progress dots */
    .progress-dots {
      display: flex !important;
      justify-content: center !important;
      align-items: center !important;
      margin-bottom: 1rem !important;
      gap: 0.5rem !important;
    }

    .progress-dot {
      width: 0.75rem !important;
      height: 0.75rem !important;
      border-radius: 50% !important;
      transition: all 0.3s ease !important;
    }

    .progress-dot.active {
      background-color: #B5EC2C !important;
      transform: scale(1.25) !important;
    }

    .progress-dot.completed {
      background-color: #B5EC2C !important;
      opacity: 0.6 !important;
    }

    .progress-dot.inactive {
      background-color: rgba(255, 255, 255, 0.3) !important;
    }

    /* Navigation buttons */
    .navigation-buttons {
      display: flex !important;
      gap: 1rem !important;
      flex-direction: row !important;
      align-items: center !important;
      justify-content: space-between !important;
    }

    .btn {
      border-radius: 1rem !important;
      font-weight: 600 !important;
      font-size: 1.125rem !important;
      transition: all 0.3s ease !important;
      transform: translateY(0) !important;
      box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1) !important;
      border: none !important;
      cursor: pointer !important;
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
      margin: 0.5rem !important;
  height: 56px !important; /* ensure consistent button height */
    }

    .btn:hover {
      transform: translateY(-4px) !important;
    }

    .btn:active {
      transform: translateY(-2px) !important;
    }

    .btn-back {
      flex: 1 !important;
      padding: 1rem 1.5rem !important;
      border: 2px solid rgb(255 255 255 / 0.2) !important;
      color: white !important;
      background: transparent !important;
    }

    .btn-back:hover {
      background-color: rgb(255 255 255 / 0.1) !important;
    }

    .btn-next {
      flex: 1 !important;
      padding: 1rem 1.5rem !important;
      background-color: #B5EC2C !important;
      color: #434935 !important;
    }

    .btn-next:hover {
      background-color: #A5DC1C !important;
    }

    .btn-full {
  width: 100% !important;
  flex: none !important;
    }

/* Ensure back and done buttons have the same height even when one is full-width */
.navigation-buttons .btn-back,
.navigation-buttons .btn-next {
  height: 56px !important;
}

    

    /* Hidden class */
    .hidden {
      display: none !important;
    }

    /* Ensure navigation container is always visible */
    #navigationContainer {
      display: block !important;
      visibility: visible !important;
      opacity: 1 !important;
    }

    /* Responsive design - Pure CSS without frameworks */
    @media (max-width: 480px) {
      .container {
        padding: 1rem !important;
      }

      .phone-input-group {
        flex-direction: row !important;
        gap: 0.25rem !important;
      }

      .phone-input-group .w-18 {
        width: 3.5rem !important;
        font-size: 0.875rem !important;
        flex-shrink: 0 !important;
        padding: 1rem 0.5rem !important;
      }

      /* Mobile: Keep grid layout but adjust alignment */
      .measurement-group {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        column-gap: 0.5rem !important;
        align-items: center !important;
      }

      .height-input-group {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        column-gap: 0.5rem !important;
        align-items: center !important;
      }

      .height-inputs {
        justify-content: flex-start !important;
        gap: 0.25rem !important;
      }

      /* Mobile: Fine-tune height input alignment */
      #step2 .height-input-group {
        column-gap: 0.5rem !important;
      }
      
      #step2 .height-inputs.align-left {
        margin-left: 0 !important;
        justify-content: flex-start !important;
      }

      .navigation-buttons {
        flex-direction: row !important;
        gap: 0.5rem !important;
      }

      .navigation-buttons .btn {
        flex: 1 !important;
        padding: 0.75rem 1rem !important;
        font-size: 1rem !important;
      }

      .text-3xl {
        font-size: 1.5rem !important;
      }

      .p-6 {
        padding: 1rem !important;
      }
    }

    @media (min-width: 481px) and (max-width: 768px) {
      .phone-input-group .w-18 {
        width: 3rem !important;
        font-size: 0.875rem !important;
      }

      /* Tablet: Use grid layout for proper alignment */
      .measurement-group {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        column-gap: 0.75rem !important;
        align-items: center !important;
      }

      .height-input-group {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        column-gap: 0.75rem !important;
        align-items: center !important;
      }
      
      #step2 .height-input-group {
        column-gap: 0.75rem !important;
      }
      
      #step2 .height-inputs.align-left {
        margin-left: 0 !important;
        justify-content: flex-start !important;
      }

      .navigation-buttons {
        flex-direction: row !important;
        gap: 0.75rem !important;
      }

      .navigation-buttons .btn {
        flex: 1 !important;
      }
    }

    @media (min-width: 769px) {
      .phone-input-group .w-18 {
        width: 3.5rem !important;
        font-size: 0.875rem !important;
      }
      
      /* Desktop: Ensure grid layout with proper alignment */
      .measurement-group {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        column-gap: 0.75rem !important;
      }
      
      .height-input-group {
        display: grid !important;
        grid-template-columns: 1fr auto !important;
        column-gap: 0.75rem !important;
      }
      
      #step2 .height-input-group {
        column-gap: 0.75rem !important;
      }
      
      #step2 .height-inputs.align-left {
        margin-left: 0 !important;
        justify-content: flex-start !important;
      }
    }

    /* Step transitions */
    .step {
      transition: all 0.5s ease-out !important;
    }

    .step.hidden {
      display: none !important;
    }

    .step.active {
      display: block !important;
    }