h2 {
  margin-inline: auto;
}

/*********************
  Code Playground Structure

  .code-windows
    .intro (h2, p)
    .code-window (h3)
      details
        summary
        .code-example
          .code-window-body
          .code-window-header

*********************/
.code-windows {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  margin-inline: auto;
  max-width: var(--max-content-width);
  padding-block-start: 4rem;
  padding-block-end: 8rem;
  padding-inline: clamp(16px, 4vw, 32px);

  .code-window {
    --code-heading-font-size: clamp(0.75rem, 3.2vw, 1.25rem);
    background-color: var(--colour-primary-2);
    border: 1px solid var(--colour-primary-7);
    border-radius: 12px;
    box-shadow: var(--surface-shadow-1);
    min-width: 100%;
    overflow-x: auto;
    padding: 1.25rem;
    position: relative;
    transition: border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
    width: 100%;

    &:hover {
      border-color: var(--brand-highlight-1);
      box-shadow: var(--surface-shadow-2);
      transform: translateY(-4px);
    }

    @media (prefers-color-scheme: dark) {
      background-color: var(--colour-primary-5);
    }

    &:has(.coming-soon-label) {
      cursor: not-allowed;
      opacity: 0.7;

      &:hover {
        border-color: transparent;
      }
    }

    h3 {
      border-bottom: var(--colour-primary-7) 1px solid;
      font-family: var(--font-primary);
      font-size: var(--code-heading-font-size);
      font-weight: 400;
      margin-block-end: 1rem;
      padding-block-end: 1rem;
      text-align: left;
    }

    .coming-soon-label {
      background-color: transparent;
      border: 1px solid var(--brand-highlight-1);
      border-radius: 0.25rem;
      color: var(--brand-highlight-1);
      font-size: 0.75rem;
      font-weight: bold;
      padding: 0.25rem 0.5rem;
      pointer-events: none;
      position: absolute;
      right: 0;
      text-wrap: nowrap;
      top: 0;
    }

    details {
      border: 2px solid transparent;
      border-radius: 0.25rem;
      height: 0;
      overflow: clip;
      transition: height 0.3s ease;

      .close {
        display: none;
      }

      .close,
      .expand {
        font-weight: 300;
      }

      &[open] {
        height: auto;
        background-color: var(--colour-primary-3);
        border-color: var(--brand-highlight-1);
        box-shadow: inset 0 0 0 1px var(--colour-primary-6);
        padding: 1.5rem;

        .close {
          display: unset;
        }

        .expand {
          display: none;
        }

        .title-bar {
          border: 2px solid pink;
        }

        .code-window-header {
          border: 2px solid transparent;
        }

        .code-window-body {
          align-content: center;
          align-items: center;
          background-color: var(--colour-primary-6);
          border-radius: .5em;
          display: flex;
          justify-content: center;
          padding: 2rem 3cqw;
          width: 100cqi;

          @media (width >= 768px) {
            padding: 3rem 4cqw;
            width: 50cqi;
          }

          .code-window-header {
            .intro-bar {
              padding-block: 2rem;
              text-align: left;

              h4 {
                border-bottom: 4px solid var(--colour-primary-9);
                font-size: clamp(0.875rem, 1vw, 1.25rem);
                letter-spacing: .05em;
                margin-bottom: .5rem;
                padding-bottom: .5rem;
                text-transform: uppercase;
              }
            }
          }
        }
      }

      summary {
        align-items: center;
        border: 1px solid var(--colour-primary-7);
        border-radius: 999px;
        cursor: pointer;
        display: flex;
        font-size: var(--code-heading-font-size);
        font-weight: 600;
        height: 2rem;
        justify-content: center;
        position: absolute;
        right: 16px;
        top: 16px;
        width: 2rem;

        &:hover {
          background-color: var(--brand-highlight-1);
          color: var(--colour-primary-2);
        }
      }
    }

    .code-example {
      container-type: inline-size;
      container-name: code-example;
      display: grid;
      gap: 1rem;

      @media (width >= 768px) {
        display: grid;
        gap: 2rem;
        grid-template-columns: 1fr 1fr;
      }

      @media (width >= 1200px) {
        gap: 3rem;
        margin-inline: 0.5rem;
      }

      p {
        text-align: left;
      }
    }
    code {
      color: var(--colour-secondary-9);
      font-size: var(--standard-font-size);
      line-height: 1.5;
      white-space: pre;
    }

    &:has(.coming-soon-label) {
      details {
        .close,
        .expand,
        .code-example {
          display: none;

        }

        &[open] {
          height: 0;
          padding: 0;
        }


          &:hover {
            border-color: transparent;
          }
      }
    }
  }
} 

.where-you-can-find-me {
  .social-icons {
    gap: 1rem;

    @media (width < 768px) {
      grid-template-columns: repeat(2, 1fr);
    }

    .social-icon {
      border: 1px solid var(--colour-primary-6);
      border-radius: 12px;
      background-color: var(--colour-primary-2);
      padding: 1rem;
      transition: transform 0.2s ease, border-color 0.3s ease, box-shadow 0.3s ease;

      .icon {
        background-color: var(--colour-primary-4);
        border-radius: 999px;
        height: 56px;
        width: 56px;
      }

      &:hover {
        border-color: var(--brand-highlight-1);
        box-shadow: var(--surface-shadow-1);
        transform: translateY(-3px);
      }
    }
  }
}