@layer components {
  .page-content {
    width: 100%;
    margin-top: var(--space-10);
    padding-inline: 10rem;
    gap: var(--space-8);

    @media (max-width: 1024px) {
      padding-inline: var(--space-10);
    }

    @media (max-width: 768px) {
      padding-inline: var(--space-6);
    }
  }

  .page-description {
    max-width: 35rem;
    color: var(--color-text-app);
    font-weight: 510;
    line-height: 140%;
  }

  /* --------- nomination section -------- */
  .nomination-section {
    position: relative;
    @media (max-width: 1024px) {
      flex-direction: column;
      align-items: center;
    }
  }

  .nomination-form,
  .sidebar {
    border-radius: var(--space-3);
    background-color: var(--color-white);
  }

  /* ----------- nomination form -------------- */
  .nomination-form {
    flex: 1;
    width: 100%;
    max-width: 56rem;
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    border: 1px solid var(--color-border);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.06);

    @media (max-width: 1024px) {
      max-width: 100%;
    }

    @media (max-width: 768px) {
      padding: var(--space-5);
    }
  }

  .form-toggle {
    display: inline-flex;
    align-self: flex-start;
    gap: var(--space-2);
    padding: var(--space-1);
    border-radius: 8px;
    background-color: #f2f2f2;
  }

  .form-toggle__btn {
    padding: 0.5rem 1.125rem;
    border-radius: 8px;
    background: transparent;
    color: var(--color-text-300);
    font-size: 0.875rem;
    font-weight: 510;
    transition:
      background 0.2s ease,
      color 0.2s ease,
      box-shadow 0.2s ease;
  }

  .form-toggle__btn.is-active {
    background-color: var(--color-white);
    color: var(--color-text-600);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  }

  .form-toggle__btn:focus-visible,
  .add-link:focus-visible,
  .section-toggle:focus-visible {
    outline: 2px solid rgba(14, 165, 164, 0.3);
    outline-offset: 2px;
  }

  .form-panel {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .form-panel[hidden] {
    display: none;
  }

  .form-placeholder {
    min-height: 28rem;
  }

  .form-section {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding-bottom: var(--space-6);
    border-bottom: 1px solid #eef1f4;
  }

  .form-section:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
  }

  .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .section-toggle {
    border: none;
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    transition: background 0.2s ease;
  }

  .section-toggle:hover {
    background-color: #f1f4f5;
  }

  .section-title {
    font-size: 1.375rem;
    font-weight: 510;
  }

  .section-caret {
    width: 0.75rem;
    height: 0.75rem;
    border-right: 2px solid var(--color-text-300);
    border-bottom: 2px solid var(--color-text-300);
    transform: rotate(45deg);
    transition: transform 0.2s ease;
  }

  .form-section.is-collapsed .section-caret {
    transform: rotate(-135deg);
  }

  .form-section.is-collapsed .section-body {
    display: none;
  }

  .form-section.is-collapsed {
    padding-bottom: var(--space-3);
  }

  .section-body {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .field {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .field label {
    font-size: 1rem;
    font-weight: 510;
    color: var(--color-text-600);
  }

  .field input,
  .field textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: var(--radius-md);
    border: 1px solid #e6e7ea;
    background-color: #f7f7f7;
    color: var(--color-text-600);
    font-size: 0.95rem;
    font-weight: 500;
  }

  .field textarea {
    min-height: 8rem;
    resize: vertical;
  }

  .field input:focus-visible,
  .field textarea:focus-visible {
    outline: 2px solid rgba(14, 165, 164, 0.2);
    border-color: var(--color-primary-500);
  }

  .required {
    color: #ef4444;
    margin-left: 0.25rem;
  }

  .optional {
    color: var(--color-text-300);
    font-weight: 500;
    font-size: 0.875rem;
    margin-left: 0.25rem;
  }

  .field-grid {
    display: grid;
    gap: var(--space-4);
  }

  .field-grid.two-col {
    grid-template-columns: repeat(2, minmax(0, 1fr));

    @media (max-width: 768px) {
      grid-template-columns: 1fr;
    }
  }

  .profile-upload {
    display: flex;
    align-items: center;
    gap: var(--space-4);
  }

  .profile-upload__preview {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 50%;
    background-color: #f1f1f1;
    border: 1px solid #e1e3e8;
    background-size: cover;
    background-position: center;
  }

  .profile-upload__preview.has-image {
    border-color: transparent;
  }

  .profile-upload__controls {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .profile-upload input[type="file"] {
    position: absolute;
    left: -9999px;
  }

  .upload-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.9rem;
    border-radius: 999px;
    background-color: #f0f0f0;
    font-size: 0.875rem;
    font-weight: 510;
    color: #888888;
    max-width: fit-content;
  }

  .profile-upload__hint {
    font-size: 0.75rem;
    color: var(--color-text-300);
  }

  .link-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .add-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: transparent;
    color: var(--color-text-300);
    font-size: 0.875rem;
    font-weight: 510;
    padding: 0;
  }

  .add-link span {
    font-size: 1rem;
    line-height: 1;
  }

  .submit-btn {
    align-self: flex-start;
    padding: 0.85rem 2rem;
    border-radius: 999px;
    background-color: var(--color-primary-500);
    color: var(--color-white);
    font-size: 1rem;
    font-weight: 510;
    box-shadow: 0 12px 24px rgba(14, 165, 164, 0.24);
    transition:
      transform 0.2s ease,
      box-shadow 0.2s ease;
  }

  .submit-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 30px rgba(14, 165, 164, 0.3);
  }

  .submit-btn:focus-visible {
    outline: 2px solid rgba(14, 165, 164, 0.3);
    outline-offset: 3px;
  }

  /* ------------------------------------------ */

  /*------------- sidebar styles -------------- */
  .sidebar {
    position: sticky;
    top: 5rem;
    height: fit-content;

    .sidebar-heading {
      font-size: 1.125rem;
    }

    ol {
      list-style-type: none;

      span {
        border-radius: 50%;
        width: 1.625rem;
        height: 1.625rem;
        font-weight: 510;
        background-color: #0ea5a52d;
        color: var(--color-primary-600);
      }

      @media (max-width: 1024px) {
        flex-direction: row;
        flex-wrap: wrap;
      }
    }

    ol,
    .step:last-of-type {
      background-color: #f7f7f7;
      border-radius: 0.5rem;
    }

    .step-heading {
      font-size: 0.875rem;
    }

    .step-description {
      max-width: 15rem;
      font-size: 0.875rem;
      font-weight: 510;
      line-height: 140%;
      color: var(--color-text-app);
    }

    .step .step-description:last-of-type {
      min-width: 100%;
    }

    @media (max-width: 1024px) {
      position: relative;
      top: 0;
    }
  }
  /* ------------------------------------------------ */
}
