/* ==========================================
   Legal Information - Mobile Button Width (Steps 2 and 3)
   ========================================== */
@media (max-width: 767px) {
  .legal-information-channel .pd-form-content__actions[data-step="2"] [data-form-continue],
  .legal-information-channel .pd-form-content__actions[data-step="3"] [data-form-continue] {
    width: auto !important;
  }

  .legal-information-book .pd-form-content__actions[data-step="2"] [data-form-continue] {
    width: auto !important;
  }

  .legal-information-right .pd-form-content__actions[data-step="2"] [data-form-continue] {
    width: auto !important;
  }
}

/* ==========================================
   legal-information-banner
   ========================================== */
/* Mobile First */
.legal-information-banner, 
.legal-information-banner__container {
  width: 100%;
}

.legal-information-banner {
  margin-top: -72px;
}

.legal-information-banner pd-internal-banner {
  display: block;
}   

/* Tablet (≥ 768px y ≤ 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .legal-information-banner {
    margin-top: -80px;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .legal-information-banner {
    margin-top: 0;
  }
}

/* ==========================================
   legal-information-declaration
   ========================================== */
/* Mobile First */
.legal-information-declaration {
  background-color: var(--pd-neutral-000);
  box-sizing: border-box;
  padding: var(--pd-spacing-8) var(--pd-spacing-4);
  width: 100%;
}

.legal-information-declaration__container {
  margin: 0 auto;
  max-width: 1280px;
  padding: 0;
}

.legal-information-declaration__grid {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-6);
}

.legal-information-declaration__media {
  display: none;
  width: 100%;
}

.legal-information-declaration__image {
  border-radius: var(--pd-spacing-3);
  display: block;
  height: auto;
  object-fit: cover;
  width: 100%;
}

.legal-information-declaration__content {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-6);
  width: 100%;
}

.legal-information-declaration__text {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
}

.legal-information-declaration__text p {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 24px;
  margin: 0;
}

.legal-information-declaration__cta {
  display: flex;
  justify-content: center;
}

.legal-information-declaration__cta .pd-button {
  --pd-button-justify-content: center;
  --pd-button-horizontal-padding: var(--pd-spacing-6);
  --pd-button-horizontal-padding-desktop: var(--pd-spacing-6);
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .legal-information-declaration {
    padding: var(--pd-spacing-16) var(--pd-spacing-5);
  }

  .legal-information-declaration__container {
    padding: 0;
  }

  .legal-information-declaration__grid {
    align-items: start;
    column-gap: var(--pd-spacing-8);
    display: grid;
    grid-template-columns: 480px 1fr;
    row-gap: var(--pd-spacing-8);
  }

  .legal-information-declaration__media {
    display: block;
  }

  .legal-information-declaration__image {
    width: 480px;
  }

  .legal-information-declaration__content {
    align-self: center;
    gap: var(--pd-spacing-6);
    justify-content: center;
    margin-top: -8px;
  }

  .legal-information-declaration__text p {
    font-size: var(--pd-font-size-base);
  }

  .legal-information-declaration__cta {
    justify-content: flex-start;
  }
}

/* ==========================================
   legal-information-channel
   ========================================== */
/* Mobile First */
.legal-information-channel {
  background-color: var(--pd-container-100);
  padding: var(--pd-spacing-8) 0;
  width: 100%;
}

.legal-information-channel__container {
  margin: 0 auto;
  max-width: 1280px;
  padding: 0 var(--pd-spacing-4);
}

.legal-information-channel__content {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.legal-information-channel__description {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: var(--pd-spacing-1) 0 0;
  max-width: 800px;
  text-align: center;
}

.legal-information-channel__info-alert {
  align-items: center;
  background-color: var(--pd-information-100);
  border: 1px solid var(--pd-information-500);
  border-radius: var(--pd-spacing-2);
  box-sizing: border-box;
  display: flex;
  gap: var(--pd-spacing-3);
  margin: var(--pd-spacing-4) 0 0;
  max-width: 800px;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.legal-information-channel__info-alert-icon {
  flex-shrink: 0;
  padding-top: var(--pd-spacing-1);
}

.legal-information-channel__info-alert-text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

.legal-information-channel__info-alert-text a {
  color: var(--pd-neutral-900);
}

.legal-information-channel__info-alert-text span {
  font-weight: var(--pd-font-weight-bold);
}

.legal-information-channel__show-form-button {
  margin: var(--pd-spacing-4) 0;
  text-decoration: underline;
}

.legal-information-channel__form-container {
  width: 100%;
}

.legal-information-channel__form-container--hidden {
  display: none;
}

.legal-information-channel__form-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-md);
  font-weight: var(--pd-font-weight-regular);
  line-height: 26px;
  margin: 0 0 var(--pd-spacing-4);
}

.legal-information-channel__form-grid {
  display: grid;
  gap: var(--pd-spacing-4);
  grid-template-columns: 1fr;
  width: 100%;
}

.legal-information-channel__form-step {
  display: block;
}

.legal-information-channel__form-step--hidden {
  display: none;
}

.legal-information-channel__field {
  width: 100%;
}

.legal-information-channel__field--full {
  grid-column: 1 / -1;
}

.legal-information-channel__label-with-optional {
  display: flex;
  align-items: flex-start;
  gap: var(--pd-spacing-2);
  width: 100%;
}

.legal-information-channel__label-with-optional > div {
  width: 100%;
}

.legal-information-channel__label-with-optional pd-input {
  flex: 1;
}

.legal-information-channel__label-with-optional pd-upload {
  flex: 1;
}

.legal-information-channel__divider {
  border-bottom: 1px solid var(--pd-container-500);
  width: 100%;
}

.legal-information-channel__optional-text {
  color: var(--pd-neutral-600);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 24px;
  margin-top: 24px;
  white-space: nowrap;
}

.legal-information-channel__info-text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

.legal-information-channel__info-alert--step3 {
  margin: 0 0 var(--pd-spacing-4) 0;
  max-width: 100%;
}

.legal-information-channel__report-options-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}

.legal-information-channel__report-option-item {
  padding: var(--pd-spacing-2) 0;
  width: 100%;
}

.legal-information-channel__report-option-item--separated {
  border-top: 1px solid var(--pd-container-500);
}

.legal-information-channel__error-message {
  color: var(--pd-error-500);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: var(--pd-spacing-4) 0 0;
}

.legal-information-channel__conditional-fields {
  display: block;
}

.legal-information-channel__conditional-fields--hidden {
  display: none;
}

.pd-form-content__description.legal-information-channel__conditional-fields--hidden {
  display: none;
}

.legal-information-channel__confirmation {
  align-items: center;
  display: flex;
  flex-direction: column;
  margin-top: var(--pd-spacing-6);
  text-align: center;
  width: 100%;
}

.legal-information-channel__confirmation--hidden {
  display: none !important;
}

.legal-information-channel__confirmation-image {
  display: flex;
  justify-content: center;
  margin: var(--pd-spacing-4) 0;
  width: 100%;
}

.legal-information-channel__confirmation-image img {
  height: auto;
  max-width: 243px;
  width: 100%;
}

.legal-information-channel__confirmation-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-md);
  font-weight: var(--pd-font-weight-regular);
  line-height: 1.4;
  margin: 0;
}

.legal-information-channel__confirmation-message {
  color: var(--pd-neutral-700);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 1.5;
  margin: var(--pd-spacing-2) 0 var(--pd-spacing-4);
}

.legal-information-channel__confirmation pd-button {
  width: 100%;
}

/* Override pd-form-content background colors for this section */
.legal-information-channel .pd-form-content__steps {
  background-color: var(--pd-neutral-000);
}

.legal-information-channel .pd-form-content__form {
  background-color: var(--pd-neutral-000);
  height: 100%;
}

@media (min-width: 1024px) {
  .legal-information-channel .pd-form-content__form {
    flex: 1;
    min-height: 0;
  }
}

.legal-information-channel .pd-form-content__step-number {
  background-color: transparent;
}

.legal-information-channel .pd-form-content__description {
  padding: var(--pd-spacing-4);
  border-radius: 8px;
}

/* Hide form wrapper when showing confirmation */
.legal-information-channel__form-wrapper--hidden {
  display: none !important;
}

/* Mobile: Button width auto for steps 2 and 3 */
@media (max-width: 767px) {
  .legal-information-channel .pd-form-content__actions[data-step="2"] [data-form-continue],
  .legal-information-channel .pd-form-content__actions[data-step="3"] [data-form-continue] {
    width: auto !important;
  }
}

/* Tablet (≥ 768px y ≤ 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .legal-information-channel__description {
    font-size: var(--pd-font-size-base);
    line-height: 24px;
  }

  .legal-information-channel__form-container--hidden {
    display: none;
  }

  .legal-information-channel__confirmation pd-button {
    width: auto;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .legal-information-channel {
    padding: var(--pd-spacing-16) 0;
  }

  .legal-information-channel__form-title {
    font-size: var(--pd-font-size-xl);
    line-height: 32px;
  }

  .legal-information-channel__show-form-button,
  button.legal-information-channel__show-form-button,
  .pd-button.legal-information-channel__show-form-button {
    display: none !important;
  }

  .legal-information-channel__form-container--hidden {
    display: block;
  }

  .legal-information-channel__description {
    font-size: var(--pd-font-size-base);
    line-height: 24px;
  }

  .legal-information-channel__form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .legal-information-channel__field--full {
    grid-column: span 2;
  }

  .legal-information-channel__confirmation-image {
    margin: var(--pd-spacing-8) 0;
  }

  .legal-information-channel__confirmation-title {
    font-size: var(--pd-font-size-2xl);
  }

  .legal-information-channel__confirmation-message {
    font-size: var(--pd-font-size-base);
    margin: var(--pd-spacing-2) 0 var(--pd-spacing-6);
  }

  .legal-information-channel__confirmation pd-button {
    width: auto;
  }
}

/* Mobile First */
.pd-input-checkbox-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-2);
  width: 100%;
}

.pd-input-checkbox {
  align-items: center;
  background-color: var(--pd-neutral-000);
  border: 1px solid var(--pd-container-700);
  border-radius: var(--pd-spacing-2);
  box-sizing: border-box;
  cursor: pointer;
  display: flex;
  gap: var(--pd-spacing-3);
  padding: var(--pd-spacing-3) var(--pd-spacing-4);
  transition: border-color 0.2s ease;
  user-select: none;
  width: 100%;
}

.pd-input-checkbox:hover:not(.pd-input-checkbox--error):not(.pd-input-checkbox--disabled) {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox--checked {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox--disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.pd-input-checkbox--error {
  border-color: var(--pd-error-500);
}

.pd-input-checkbox--error:focus-visible {
  border-color: var(--pd-error-500);
  box-shadow: 0 0 0 3px rgba(209, 58, 59, 0.1);
}

.pd-input-checkbox__box {
  align-items: center;
  background-color: var(--pd-neutral-000);
  border: 1px solid var(--pd-container-700);
  border-radius: var(--pd-spacing-1);
  display: flex;
  flex-shrink: 0;
  height: 24px;
  justify-content: center;
  position: relative;
  transition: border-color 0.2s ease, background-color 0.2s ease;
  width: 24px;
}

.pd-input-checkbox--checked .pd-input-checkbox__box {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox:hover:not(.pd-input-checkbox--disabled) .pd-input-checkbox__box {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox:focus-visible .pd-input-checkbox__box {
  outline: 2px solid var(--pd-primary-500);
  outline-offset: 2px;
}

.pd-input-checkbox__icon {
  display: flex;
  flex-shrink: 0;
}

.pd-input-checkbox__label {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-base);
  font-weight: var(--pd-font-weight-normal);
  line-height: 24px;
}

.pd-input-checkbox__label a {
  color: var(--pd-neutral-900);
  text-decoration: underline;
  cursor: pointer;
}

.pd-input-checkbox__label a:hover {
  color: var(--pd-primary-500);
}

.pd-input-checkbox__input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}

.pd-input-checkbox__error-message {
  color: var(--pd-error-500);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

/* Tablet (≥ 768px y ≤ 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .pd-input-checkbox__box {
    height: 24px;
    width: 24px;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .pd-input-checkbox__box {
    height: 24px;
    width: 24px;
  }
}

/* Mobile First */
.pd-form-content-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
  margin: var(--pd-spacing-4) auto 0;
  max-width: 1280px;
  width: 100%;
}

.pd-form-content {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-6);
  width: 100%;
}

.pd-form-content__steps {
  background-color: var(--pd-form-content-bg-color, var(--pd-container-100));
  border-radius: 8px;
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  gap: var(--pd-spacing-2);
  justify-content: space-between;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__step {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-2);
  position: relative;
}

.pd-form-content__step-number {
  align-items: center;
  background-color: var(--pd-form-content-step-number-bg-color, var(--pd-container-100));
  border: 2px solid var(--pd-container-500);
  border-radius: 50%;
  box-sizing: border-box;
  color: var(--pd-neutral-800);
  display: flex;
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-base);
  font-weight: var(--pd-font-weight-semi-bold);
  height: 42px;
  justify-content: center;
  position: relative;
  width: 42px;
  z-index: 1;
}

.pd-form-content__step--active .pd-form-content__step-number {
  background-color: transparent;
  border-color: var(--pd-accent-500);
}

.pd-form-content__step-label {
  display: none;
}

/* Connector line for mobile (horizontal) */
.pd-form-content__connector {
  align-self: center;
  background-color: var(--pd-container-500);
  flex: 1;
  height: 1px;
  margin: 0 calc(-1 * var(--pd-spacing-2) + 4px);
  max-width: calc(100% - 84px);
  min-width: 0;
  position: relative;
  z-index: 0;
}

/* Active connector line for mobile (horizontal) - when step is active but not completed */
.pd-form-content__connector--current {
  background-color: var(--pd-container-500);
}

/* Completed connector line for mobile (horizontal) - when step is completed */
.pd-form-content__connector--active {
  background-color: var(--pd-accent-500);
}

.pd-form-content__form-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__form {
  background-color: var(--pd-form-content-bg-color, var(--pd-container-100));
  border-radius: 8px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__description {
  background-color: var(--pd-neutral-000);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: var(--pd-form-content-description-padding, 0);
  width: 100%;
}

.pd-form-content__actions {
  align-items: center;
  display: flex;
  gap: var(--pd-spacing-4);
  justify-content: flex-end;
  width: 100%;
}

.pd-form-content__actions--single {
  justify-content: flex-end;
}

.pd-form-content__actions--single pd-button {
  width: 100%;
}

.pd-form-content__actions--multiple {
  justify-content: space-between;
}

/* Tablet (≥ 768px y ≤ 1023px) - Same as mobile */
@media (min-width: 768px) and (max-width: 1023px) {
  .pd-form-content__actions--single pd-button {
    width: auto;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .pd-form-content-wrapper {
    gap: var(--pd-spacing-8);
    margin: var(--pd-spacing-8) 0 0;
  }

  .pd-form-content {
    flex-direction: row;
    gap: var(--pd-spacing-4);
  }

  .pd-form-content__steps {
    flex: 0 0 320px;
    flex-direction: column;
    gap: var(--pd-spacing-1);
    justify-content: center;
    padding: var(--pd-spacing-8) var(--pd-spacing-6);
    position: relative;
  }

  .pd-form-content__step {
    flex-direction: row;
    gap: var(--pd-spacing-2);
  }

  /* Connector line for desktop (vertical) - overrides mobile horizontal line */
  .pd-form-content__connector {
    align-self: flex-start;
    background-color: transparent;
    border-left: 1px solid var(--pd-container-500);
    flex: 0 0 auto;
    height: var(--pd-spacing-12);
    margin-left: 21px;
    max-width: none;
    width: 0;
  }

  /* Active connector line for desktop (vertical) - when step is active but not completed */
  .pd-form-content__connector--current {
    border-left: 1px solid var(--pd-container-500);
  }

  /* Completed connector line for desktop (vertical) - when step is completed */
  .pd-form-content__connector--active {
    border-left: 1px solid var(--pd-accent-500);
  }

  .pd-form-content__step-number {
    font-size: var(--pd-font-size-md);
  }

  .pd-form-content__step-label {
    color: var(--pd-neutral-600);
    display: block;
    font-family: var(--pd-font-secondary);
    font-size: var(--pd-font-size-md);
    font-weight: var(--pd-font-weight-normal);
    text-align: left;
  }

  .pd-form-content__step--active .pd-form-content__step-label {
    color: var(--pd-neutral-900);
  }

  .pd-form-content__form-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  .pd-form-content__form {
    flex: 1;
    min-height: 0;
    padding: var(--pd-spacing-8) var(--pd-spacing-6);
  }

  .pd-form-content__actions {
    margin-left: calc(320px + var(--pd-spacing-4));
    width: calc(100% - 320px - var(--pd-spacing-4));
    max-width: calc(1280px - 320px - var(--pd-spacing-4));
  }

  .pd-form-content__actions--single pd-button {
    width: auto;
  }
}

/* Demo content styles for storybook */
.pd-form-content__demo-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-xl);
  font-weight: var(--pd-font-weight-semi-bold);
  margin: 0 0 var(--pd-spacing-6);
}

.pd-form-content__demo-text {
  color: var(--pd-neutral-700);
}

/* Mobile First */
.pd-upload {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-2);
  width: 100%;
}

.pd-upload__label {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-base);
  font-weight: var(--pd-font-weight-normal);
  line-height: 28px;
  margin: 0;
}

.pd-upload__label .pd-input__label-optional {
  display: inline;
  margin-left: var(--pd-spacing-1);
}

.pd-upload__dropzone {
  align-items: center;
  border: 2px dashed var(--pd-accent-500);
  border-radius: var(--pd-spacing-2);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-6);
  justify-content: center;
  min-height: 112px;
  padding: var(--pd-spacing-6);
  position: relative;
  transition: border-color 0.2s ease, background-color 0.2s ease;
  width: 100%;
}

.pd-upload__dropzone--dragging {
  border-color: var(--pd-primary-500);
  background-color: var(--pd-container-100);
}

.pd-upload__dropzone--disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.pd-upload__dropzone--error {
  border-color: var(--pd-error-500);
}

.pd-upload__dropzone--error:focus-within {
  border-color: var(--pd-error-500);
  box-shadow: 0 0 0 3px rgba(209, 58, 59, 0.1);
}

.pd-upload__input {
  display: none;
}

.pd-upload__content {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-6);
}

.pd-upload__content .pd-button[data-upload-trigger] {
  justify-content: center;
  width: 280px;
}

.pd-upload__icon {
  flex-shrink: 0;
}

.pd-upload__text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-base);
  font-weight: var(--pd-font-weight-normal);
  line-height: 24px;
  margin: 0;
  text-align: center;
}

.pd-upload__info {
  width: 100%;
}

.pd-upload__info-text {
  color: var(--pd-neutral-black);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-xs);
  font-weight: var(--pd-font-weight-normal);
  line-height: 18px;
  margin: 0;
}

.pd-upload__files {
  display: none;
  flex-direction: column;
  gap: var(--pd-spacing-2);
  margin-top: var(--pd-spacing-4);
  width: 100%;
}

.pd-upload__files:not(:empty) {
  display: flex;
}

.pd-upload__file-item {
  align-items: center;
  background-color: var(--pd-information-100);
  border-radius: var(--pd-spacing-2);
  box-sizing: border-box;
  display: flex;
  gap: var(--pd-spacing-1);
  padding: var(--pd-spacing-2) var(--pd-spacing-1);
  transition: background-color 0.3s ease;
  width: 100%;
}

.pd-upload__file-item--complete {
  background-color: var(--pd-success-100);
}

.pd-upload__file-icon {
  flex-shrink: 0;
}

.pd-upload__file-info {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
}

.pd-upload__file-name {
  color: var(--pd-neutral-black);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-xs);
  font-weight: var(--pd-font-weight-normal);
  line-height: 18px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pd-upload__file-remove {
  align-items: center;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  flex-shrink: 0;
  justify-content: center;
  padding: var(--pd-spacing-1);
  transition: opacity 0.2s ease;
}

.pd-upload__file-remove:hover {
  opacity: 0.7;
}

.pd-upload__file-remove:active {
  opacity: 0.5;
}

.pd-upload__error-message {
  color: var(--pd-error-500);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

.pd-upload__error-message--hidden {
  display: none;
}

/* Tablet (≥ 768px y ≤ 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .pd-upload__dropzone {
    min-height: 130px;
    padding: var(--pd-spacing-8);
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .pd-upload__dropzone {
    min-height: 150px;
    padding: var(--pd-spacing-10);
  }

  .pd-upload__label {
    font-size: var(--pd-font-size-md);
    line-height: 30px;
  }
}

/* ==========================================
   legal-information-book
   ========================================== */
/* Mobile First */
.legal-information-book {
  background-color: var(--pd-neutral-000);
  padding: var(--pd-spacing-8) 0;
  width: 100%;
}

.legal-information-book__container {
  margin: 0 auto;
  max-width: 1280px;
  padding: 0 var(--pd-spacing-4);
}

.legal-information-book__content {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.legal-information-book__description {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: var(--pd-spacing-1) 0 0;
  max-width: 800px;
  text-align: center;
}

.legal-information-book__show-form-button {
  margin: var(--pd-spacing-4) 0;
  text-decoration: underline;
}

.legal-information-book__show-form-button ::slotted(*) {
  text-decoration: underline;
}

.legal-information-book__form-container {
  width: 100%;
}

.legal-information-book__form-container--hidden {
  display: none;
}

.legal-information-book__form-step {
  display: block;
}

.legal-information-book__form-step--hidden {
  display: none;
}

.legal-information-book__confirmation--hidden {
  display: none !important;
}

.legal-information-book__form-wrapper--hidden {
  display: none !important;
}

.legal-information-book__form-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-md);
  font-weight: var(--pd-font-weight-regular);
  line-height: 38px;
  margin: 0 0 var(--pd-spacing-4);
}

.legal-information-book__company-info {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-1);
  margin-bottom: var(--pd-spacing-6);
}

.legal-information-book__company-text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

.legal-information-book__form-fields {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
}

.legal-information-book__form-grid {
  display: grid;
  gap: var(--pd-spacing-4);
  grid-template-columns: 1fr;
  width: 100%;
}

.legal-information-book__fields-row {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
  width: 100%;
}

.legal-information-book__field {
  width: 100%;
}

.legal-information-book__field--full {
  grid-column: 1 / -1;
}

.legal-information-book__info-texts {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
}

.legal-information-book__info-texts a {
  text-decoration: underline;
}

.pd-form-content__description.legal-information-book__description-step3 {
  display: none;
}

.legal-information-book__info-text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

.legal-information-book__info-alert {
  align-items: center;
  background-color: var(--pd-information-100);
  border-radius: var(--pd-spacing-2);
  box-sizing: border-box;
  display: flex;
  gap: var(--pd-spacing-3);
  margin: var(--pd-spacing-4) 0 0;
  max-width: 800px;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.legal-information-book__info-alert-icon {
  flex-shrink: 0;
}

.legal-information-book__info-alert-text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

.legal-information-book__confirmation {
  align-items: center;
  display: flex;
  flex-direction: column;
  margin-top: var(--pd-spacing-6);
  text-align: center;
  width: 100%;
}

.legal-information-book__confirmation-image {
  display: flex;
  justify-content: center;
  margin: var(--pd-spacing-4) 0;
  width: 100%;
}

.legal-information-book__confirmation-image img {
  height: auto;
  max-width: 243px;
  width: 100%;
}

.legal-information-book__confirmation-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-md);
  font-weight: var(--pd-font-weight-regular);
  line-height: 1.4;
  margin: 0;
}

.legal-information-book__confirmation-message {
  color: var(--pd-neutral-700);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 1.5;
  margin: var(--pd-spacing-2) 0 var(--pd-spacing-4);
}

.legal-information-book__confirmation pd-button {
  width: 100%;
}

/* Tablet (≥ 768px y ≤ 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .legal-information-book__description {
    font-size: var(--pd-font-size-base);
    line-height: 24px;
  }

  .legal-information-book__form-container--hidden {
    display: none;
  }

  .legal-information-book__confirmation pd-button {
    width: auto;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .legal-information-book {
    padding: var(--pd-spacing-16) 0;
  }

  .legal-information-book__form-title {
    font-size: var(--pd-font-size-2xl);
  }

  .legal-information-book__show-form-button,
  button.legal-information-book__show-form-button,
  .pd-button.legal-information-book__show-form-button {
    display: none !important;
  }

  .legal-information-book__form-container--hidden {
    display: block;
  }

  .legal-information-book__description {
    font-size: var(--pd-font-size-base);
    line-height: 24px;
  }

  .legal-information-book__company-text {
    font-size: var(--pd-font-size-md);
  }

  .legal-information-book__fields-row {
    flex-direction: row;
    gap: var(--pd-spacing-4);
  }

  .legal-information-book__fields-row .legal-information-book__field {
    width: 50%;
  }

  .legal-information-book__form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .legal-information-book__field--full {
    grid-column: span 2;
  }

  .legal-information-book__confirmation-title {
    font-size: var(--pd-font-size-2xl);
  }

  .legal-information-book__confirmation-message {
    font-size: var(--pd-font-size-base);
    margin: var(--pd-spacing-2) 0 var(--pd-spacing-6);
  }

  .legal-information-book__confirmation pd-button {
    width: auto;
  }

  .legal-information-book__confirmation-image {
    margin: var(--pd-spacing-8) 0;
  }
}

/* Mobile First */
.pd-form-content-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
  margin: var(--pd-spacing-4) auto 0;
  max-width: 1280px;
  width: 100%;
}

.pd-form-content {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-6);
  width: 100%;
}

.pd-form-content__steps {
  background-color: var(--pd-form-content-bg-color, var(--pd-container-100));
  border-radius: 8px;
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  gap: var(--pd-spacing-2);
  justify-content: space-between;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__step {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-2);
  position: relative;
}

.pd-form-content__step-number {
  align-items: center;
  background-color: var(--pd-form-content-step-number-bg-color, var(--pd-container-100));
  border: 2px solid var(--pd-container-500);
  border-radius: 50%;
  box-sizing: border-box;
  color: var(--pd-neutral-800);
  display: flex;
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-base);
  font-weight: var(--pd-font-weight-semi-bold);
  height: 42px;
  justify-content: center;
  position: relative;
  width: 42px;
  z-index: 1;
}

.pd-form-content__step--active .pd-form-content__step-number {
  background-color: transparent;
  border-color: var(--pd-accent-500);
}

.pd-form-content__step-label {
  display: none;
}

/* Connector line for mobile (horizontal) */
.pd-form-content__connector {
  align-self: center;
  background-color: var(--pd-container-500);
  flex: 1;
  height: 1px;
  margin: 0 calc(-1 * var(--pd-spacing-2) + 4px);
  max-width: calc(100% - 84px);
  min-width: 0;
  position: relative;
  z-index: 0;
}

/* Active connector line for mobile (horizontal) - when step is active but not completed */
.pd-form-content__connector--current {
  background-color: var(--pd-container-500);
}

/* Completed connector line for mobile (horizontal) - when step is completed */
.pd-form-content__connector--active {
  background-color: var(--pd-accent-500);
}

.pd-form-content__form-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__form {
  background-color: var(--pd-form-content-bg-color, var(--pd-container-100));
  border-radius: 8px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__description {
  background-color: var(--pd-neutral-000);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: var(--pd-form-content-description-padding, 0);
  width: 100%;
}

.pd-form-content__actions {
  align-items: center;
  display: flex;
  gap: var(--pd-spacing-4);
  justify-content: flex-end;
  width: 100%;
}

.pd-form-content__actions--single {
  justify-content: flex-end;
}

.pd-form-content__actions--single pd-button {
  width: 100%;
}

.pd-form-content__actions--multiple {
  justify-content: space-between;
}

/* Tablet (≥ 768px y ≤ 1023px) - Same as mobile */
@media (min-width: 768px) and (max-width: 1023px) {
  .pd-form-content__actions--single pd-button {
    width: auto;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .pd-form-content-wrapper {
    gap: var(--pd-spacing-8);
    margin: var(--pd-spacing-8) 0 0;
  }

  .pd-form-content {
    flex-direction: row;
    gap: var(--pd-spacing-4);
  }

  .pd-form-content__steps {
    flex: 0 0 320px;
    flex-direction: column;
    gap: var(--pd-spacing-1);
    justify-content: center;
    padding: var(--pd-spacing-8) var(--pd-spacing-6);
    position: relative;
  }

  .pd-form-content__step {
    flex-direction: row;
    gap: var(--pd-spacing-2);
  }

  /* Connector line for desktop (vertical) - overrides mobile horizontal line */
  .pd-form-content__connector {
    align-self: flex-start;
    background-color: transparent;
    border-left: 1px solid var(--pd-container-500);
    flex: 0 0 auto;
    height: var(--pd-spacing-12);
    margin-left: 21px;
    max-width: none;
    width: 0;
  }

  /* Active connector line for desktop (vertical) - when step is active but not completed */
  .pd-form-content__connector--current {
    border-left: 1px solid var(--pd-container-500);
  }

  /* Completed connector line for desktop (vertical) - when step is completed */
  .pd-form-content__connector--active {
    border-left: 1px solid var(--pd-accent-500);
  }

  .pd-form-content__step-number {
    font-size: var(--pd-font-size-md);
  }

  .pd-form-content__step-label {
    color: var(--pd-neutral-600);
    display: block;
    font-family: var(--pd-font-secondary);
    font-size: var(--pd-font-size-md);
    font-weight: var(--pd-font-weight-normal);
    text-align: left;
  }

  .pd-form-content__step--active .pd-form-content__step-label {
    color: var(--pd-neutral-900);
  }

  .pd-form-content__form-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  .pd-form-content__form {
    flex: 1;
    min-height: 0;
    padding: var(--pd-spacing-8) var(--pd-spacing-6);
  }

  .pd-form-content__actions {
    margin-left: calc(320px + var(--pd-spacing-4));
    width: calc(100% - 320px - var(--pd-spacing-4));
    max-width: calc(1280px - 320px - var(--pd-spacing-4));
  }

  .pd-form-content__actions--single pd-button {
    width: auto;
  }
}

/* Demo content styles for storybook */
.pd-form-content__demo-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-xl);
  font-weight: var(--pd-font-weight-semi-bold);
  margin: 0 0 var(--pd-spacing-6);
}

.pd-form-content__demo-text {
  color: var(--pd-neutral-700);
}

/* ==========================================
   legal-information-right
   ========================================== */
/* Mobile First */
.legal-information-right {
  background-color: var(--pd-container-100);
  padding: var(--pd-spacing-8) 0;
  width: 100%;
}

.legal-information-right__container {
  margin: 0 auto;
  max-width: 1280px;
  padding: 0 var(--pd-spacing-4);
}

.legal-information-right__content {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.legal-information-right__description {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: var(--pd-spacing-1) 0 0;
  max-width: 800px;
  text-align: center;
}

.legal-information-right__show-form-button {
  margin: var(--pd-spacing-4) 0;
  text-decoration: underline;
}

.legal-information-right__form-container {
  width: 100%;
}

.legal-information-right__form-container--hidden {
  display: none;
}

.legal-information-right__form-step {
  display: block;
}

.legal-information-right__form-step--hidden {
  display: none;
}

.legal-information-right__confirmation--hidden {
  display: none !important;
}

.legal-information-right__form-wrapper--hidden {
  display: none !important;
}

.legal-information-right__error-message--hidden {
  display: none;
}

.legal-information-right__form-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-md);
  font-weight: var(--pd-font-weight-regular);
  line-height: 38px;
  margin: 0 0 var(--pd-spacing-4);
}

.legal-information-right__form-title--subtitle {
  font-size: var(--pd-font-size-lg);
  margin: var(--pd-spacing-6) 0 var(--pd-spacing-4);
}

.legal-information-right__form-grid {
  display: grid;
  gap: var(--pd-spacing-4);
  grid-template-columns: 1fr;
  width: 100%;
}

.legal-information-right__field {
  width: 100%;
}

.legal-information-right__field--full {
  grid-column: 1 / -1;
}

.legal-information-right__upload-info {
  color: var(--pd-neutral-700);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-xs);
  font-weight: var(--pd-font-weight-normal);
  line-height: 18px;
  margin: var(--pd-spacing-2) 0 0;
}

.legal-information-right__info-text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

.legal-information-right__instruction-text {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0 0 var(--pd-spacing-2);
}

.legal-information-right__rights-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}

.legal-information-right__right-item {
  padding: var(--pd-spacing-2) 0;
  width: 100%;
}

.legal-information-right__right-item--separated {
  padding-top: var(--pd-spacing-2);
}

.legal-information-right__error-message {
  color: var(--pd-error-500);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: var(--pd-spacing-4) 0 0;
}

.legal-information-right__confirmation {
  align-items: center;
  display: flex;
  flex-direction: column;
  margin-top: var(--pd-spacing-6);
  text-align: center;
  width: 100%;
}

.legal-information-right__confirmation-image {
  display: flex;
  justify-content: center;
  margin: var(--pd-spacing-4) 0;
  width: 100%;
}

.legal-information-right__confirmation-image img {
  height: auto;
  max-width: 243px;
  width: 100%;
}

.legal-information-right__confirmation-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-md);
  font-weight: var(--pd-font-weight-regular);
  line-height: 1.4;
  margin: 0;
}

.legal-information-right__confirmation-message {
  color: var(--pd-neutral-700);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 1.5;
  margin: var(--pd-spacing-2) 0 var(--pd-spacing-4);
}

.legal-information-right__confirmation pd-button {
  width: 100%;
}

/* Override pd-form-content background colors for this section */
.legal-information-right .pd-form-content__steps {
  background-color: var(--pd-neutral-000);
}

.legal-information-right .pd-form-content__step-number {
  background-color: var(--pd-neutral-000);
}

.legal-information-right .pd-form-content__form-wrapper {
  background-color: var(--pd-neutral-000);
  border-radius: 8px;
}

.legal-information-right .pd-form-content__form {
  background-color: var(--pd-neutral-000);
  border-radius: 8px;
}

/* Tablet (≥ 768px y ≤ 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .legal-information-right__description {
    font-size: var(--pd-font-size-base);
    line-height: 24px;
  }

  .legal-information-right__form-container--hidden {
    display: none;
  }

  .legal-information-right__confirmation pd-button {
    width: auto;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .legal-information-right {
    padding: var(--pd-spacing-16) 0;
  }

  .legal-information-right__form-title {
    font-size: var(--pd-font-size-2xl);
  }

  .legal-information-right__show-form-button,
  button.legal-information-right__show-form-button,
  .pd-button.legal-information-right__show-form-button {
    display: none !important;
  }

  .legal-information-right__form-container--hidden {
    display: block;
  }

  .legal-information-right__description {
    font-size: var(--pd-font-size-base);
    line-height: 24px;
  }

  .legal-information-right__form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .legal-information-right__field--full {
    grid-column: span 2;
  }

  .legal-information-right__confirmation-image {
    margin: var(--pd-spacing-8) 0;
  }

  .legal-information-right__confirmation-title {
    font-size: var(--pd-font-size-2xl);
  }

  .legal-information-right__confirmation-message {
    font-size: var(--pd-font-size-base);
    margin: var(--pd-spacing-2) 0 var(--pd-spacing-6);
  }

  .legal-information-right__confirmation pd-button {
    width: auto;
  }
}

/* Mobile First */
.pd-input-checkbox-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-2);
  width: 100%;
}

.pd-input-checkbox {
  align-items: center;
  background-color: var(--pd-neutral-000);
  border: 1px solid var(--pd-container-700);
  border-radius: var(--pd-spacing-2);
  box-sizing: border-box;
  cursor: pointer;
  display: flex;
  gap: var(--pd-spacing-3);
  padding: var(--pd-spacing-3) var(--pd-spacing-4);
  transition: border-color 0.2s ease;
  user-select: none;
  width: 100%;
}

.pd-input-checkbox:hover:not(.pd-input-checkbox--error):not(.pd-input-checkbox--disabled) {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox--checked {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox--disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.pd-input-checkbox--error {
  border-color: var(--pd-error-500);
}

.pd-input-checkbox--error:focus-visible {
  border-color: var(--pd-error-500);
  box-shadow: 0 0 0 3px rgba(209, 58, 59, 0.1);
}

.pd-input-checkbox__box {
  align-items: center;
  background-color: var(--pd-neutral-000);
  border: 1px solid var(--pd-container-700);
  border-radius: var(--pd-spacing-1);
  display: flex;
  flex-shrink: 0;
  height: 24px;
  justify-content: center;
  position: relative;
  transition: border-color 0.2s ease, background-color 0.2s ease;
  width: 24px;
}

.pd-input-checkbox--checked .pd-input-checkbox__box {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox:hover:not(.pd-input-checkbox--disabled) .pd-input-checkbox__box {
  border-color: var(--pd-success-500);
}

.pd-input-checkbox:focus-visible .pd-input-checkbox__box {
  outline: 2px solid var(--pd-primary-500);
  outline-offset: 2px;
}

.pd-input-checkbox__icon {
  display: flex;
  flex-shrink: 0;
}

.pd-input-checkbox__label {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-base);
  font-weight: var(--pd-font-weight-normal);
  line-height: 24px;
}

.pd-input-checkbox__label a {
  color: var(--pd-neutral-900);
  text-decoration: underline;
  cursor: pointer;
}

.pd-input-checkbox__label a:hover {
  color: var(--pd-primary-500);
}

.pd-input-checkbox__input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}

.pd-input-checkbox__error-message {
  color: var(--pd-error-500);
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-sm);
  font-weight: var(--pd-font-weight-normal);
  line-height: 22px;
  margin: 0;
}

/* Tablet (≥ 768px y ≤ 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .pd-input-checkbox__box {
    height: 24px;
    width: 24px;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .pd-input-checkbox__box {
    height: 24px;
    width: 24px;
  }
}

/* Mobile First */
.pd-form-content-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
  margin: var(--pd-spacing-4) auto 0;
  max-width: 1280px;
  width: 100%;
}

.pd-form-content {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-6);
  width: 100%;
}

.pd-form-content__steps {
  background-color: var(--pd-form-content-bg-color, var(--pd-container-100));
  border-radius: 8px;
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  gap: var(--pd-spacing-2);
  justify-content: space-between;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__step {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-2);
  position: relative;
}

.pd-form-content__step-number {
  align-items: center;
  background-color: var(--pd-form-content-step-number-bg-color, var(--pd-container-100));
  border: 2px solid var(--pd-container-500);
  border-radius: 50%;
  box-sizing: border-box;
  color: var(--pd-neutral-800);
  display: flex;
  font-family: var(--pd-font-secondary);
  font-size: var(--pd-font-size-base);
  font-weight: var(--pd-font-weight-semi-bold);
  height: 42px;
  justify-content: center;
  position: relative;
  width: 42px;
  z-index: 1;
}

.pd-form-content__step--active .pd-form-content__step-number {
  background-color: transparent;
  border-color: var(--pd-accent-500);
}

.pd-form-content__step-label {
  display: none;
}

/* Connector line for mobile (horizontal) */
.pd-form-content__connector {
  align-self: center;
  background-color: var(--pd-container-500);
  flex: 1;
  height: 1px;
  margin: 0 calc(-1 * var(--pd-spacing-2) + 4px);
  max-width: calc(100% - 84px);
  min-width: 0;
  position: relative;
  z-index: 0;
}

/* Active connector line for mobile (horizontal) - when step is active but not completed */
.pd-form-content__connector--current {
  background-color: var(--pd-container-500);
}

/* Completed connector line for mobile (horizontal) - when step is completed */
.pd-form-content__connector--active {
  background-color: var(--pd-accent-500);
}

.pd-form-content__form-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__form {
  background-color: var(--pd-form-content-bg-color, var(--pd-container-100));
  border-radius: 8px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: var(--pd-spacing-4);
  width: 100%;
}

.pd-form-content__description {
  background-color: var(--pd-neutral-000);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: var(--pd-form-content-description-padding, 0);
  width: 100%;
}

.pd-form-content__actions {
  align-items: center;
  display: flex;
  gap: var(--pd-spacing-4);
  justify-content: flex-end;
  width: 100%;
}

.pd-form-content__actions--single {
  justify-content: flex-end;
}

.pd-form-content__actions--single pd-button {
  width: 100%;
}

.pd-form-content__actions--multiple {
  justify-content: space-between;
}

/* Tablet (≥ 768px y ≤ 1023px) - Same as mobile */
@media (min-width: 768px) and (max-width: 1023px) {
  .pd-form-content__actions--single pd-button {
    width: auto;
  }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .pd-form-content-wrapper {
    gap: var(--pd-spacing-8);
    margin: var(--pd-spacing-8) 0 0;
  }

  .pd-form-content {
    flex-direction: row;
    gap: var(--pd-spacing-4);
  }

  .pd-form-content__steps {
    flex: 0 0 320px;
    flex-direction: column;
    gap: var(--pd-spacing-1);
    justify-content: center;
    padding: var(--pd-spacing-8) var(--pd-spacing-6);
    position: relative;
  }

  .pd-form-content__step {
    flex-direction: row;
    gap: var(--pd-spacing-2);
  }

  /* Connector line for desktop (vertical) - overrides mobile horizontal line */
  .pd-form-content__connector {
    align-self: flex-start;
    background-color: transparent;
    border-left: 1px solid var(--pd-container-500);
    flex: 0 0 auto;
    height: var(--pd-spacing-12);
    margin-left: 21px;
    max-width: none;
    width: 0;
  }

  /* Active connector line for desktop (vertical) - when step is active but not completed */
  .pd-form-content__connector--current {
    border-left: 1px solid var(--pd-container-500);
  }

  /* Completed connector line for desktop (vertical) - when step is completed */
  .pd-form-content__connector--active {
    border-left: 1px solid var(--pd-accent-500);
  }

  .pd-form-content__step-number {
    font-size: var(--pd-font-size-md);
  }

  .pd-form-content__step-label {
    color: var(--pd-neutral-600);
    display: block;
    font-family: var(--pd-font-secondary);
    font-size: var(--pd-font-size-md);
    font-weight: var(--pd-font-weight-normal);
    text-align: left;
  }

  .pd-form-content__step--active .pd-form-content__step-label {
    color: var(--pd-neutral-900);
  }

  .pd-form-content__form-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  .pd-form-content__form {
    flex: 1;
    min-height: 0;
    padding: var(--pd-spacing-8) var(--pd-spacing-6);
  }

  .pd-form-content__actions {
    margin-left: calc(320px + var(--pd-spacing-4));
    width: calc(100% - 320px - var(--pd-spacing-4));
    max-width: calc(1280px - 320px - var(--pd-spacing-4));
  }

  .pd-form-content__actions--single pd-button {
    width: auto;
  }
}

/* Demo content styles for storybook */
.pd-form-content__demo-title {
  color: var(--pd-neutral-900);
  font-family: var(--pd-font-primary);
  font-size: var(--pd-font-size-xl);
  font-weight: var(--pd-font-weight-semi-bold);
  margin: 0 0 var(--pd-spacing-6);
}

.pd-form-content__demo-text {
  color: var(--pd-neutral-700);
}