/* Action show page — adapted from Fizzy's card-perma.css */

@layer components {
  .action-perma {
    --actions-block-inset: 1.5rem;
    --half-btn-height: 1.25rem;
    --padding-inline: calc(var(--block-space-double) + var(--block-space));
    --padding-block: calc(var(--block-space-double) + var(--block-space-half));
    --color-container: color-mix(in srgb, var(--card-color) 33%, var(--color-canvas));

    align-items: start;
    display: grid;
    grid-template-areas:
      "card"
      "notch-bottom"
      "closure-message";
    grid-template-columns: minmax(0, var(--main-width));
    inline-size: fit-content;
    margin-block-start: var(--block-space);
    max-inline-size: 100%;
    margin-inline: auto;
    position: relative;

    &:has(dialog[open]) .action-perma__bg {
      position: relative;
      z-index: 2;
    }

    @media (max-width: 639px) {
      --half-btn-height: 1.25rem;
      --padding-inline: 1.5ch;

      inline-size: calc(100% + 2 * var(--padding-inline));
      margin-inline: calc(-1 * var(--padding-inline));
      max-inline-size: none;
    }

    .card {
      --card-aspect-ratio: 2 / 0.95;
      --lexxy-bg-color: var(--card-bg-color);

      border: none;
    }

    .card__header {
      @media (max-width: 639px) {
        flex-wrap: wrap;
        gap: var(--card-header-space) unset;
      }
    }

    .card__body {
      position: relative;

      @media (max-width: 639px) {
        flex-direction: column;
        padding-block: var(--card-padding-block) calc(var(--card-padding-block) * 1.5);
        position: static;
      }
    }

    .card__content {
      display: flex;
      flex-direction: column;
      gap: 1ch;
    }

    .card__title {
      font-size: clamp(var(--text-medium), 6vw, var(--text-x-large));
      margin-block-end: 0.5ch;

      @media (max-width: 639px) {
        margin-block-end: 0.75ch;
      }
    }

    .card__description {
      color: var(--card-content-color);
      line-height: 1.5;

      @media (max-width: 639px) {
        margin-block-end: 1ch;
      }
    }

    .card__meta {
      @media (min-width: 640px) {
        font-size: var(--text-small);
      }

      @media (max-width: 639px) {
        inline-size: 100%;

        .card__meta-avatars--author {
          display: none;
        }
      }
    }

    .card__footer {
      --btn-size: 2.5rem;

      display: flex;
      gap: 0.5ch;
      inline-size: 100%;
      text-align: start;
    }
  }

  /* Background container */
  .action-perma__bg {
    background-color: var(--color-container);
    border-radius: 0.2em;
    grid-area: card;
    padding: clamp(2rem, 4vw, var(--padding-block));

    @media (max-width: 639px) {
      padding: clamp(0.25rem, 2vw, var(--padding-block));
      padding-block-end: clamp(2.5rem, 4vw, var(--padding-block));
    }

    @media (min-width: 640px) and (max-width: 799px) {
      padding-inline: var(--padding-inline);
    }
  }

  /* Card inside the perma layout */
  .action-perma .card {
    --card-padding-inline: 1.5em;
    --card-padding-block: 1.5em;
    --border-radius: 0.2em;
  }

  .action-perma .card__board {
    align-items: center;
    align-self: start;
  }

  .action-perma .card__body {
    padding-block: calc(var(--card-padding-block) * 0.75) var(--card-padding-block);

    @media (max-width: 639px) {
      flex-direction: column;
    }
  }

  .action-perma .card__title {
    margin: 0;
  }

  /* Inline edit form (Fizzy-style turbo_frame swap) */
  .action-edit-form {
    display: flex;
    flex-direction: column;
    gap: 1ch;
  }

  .action-edit-form__field {
    display: flex;
    flex-direction: column;
    gap: 0.25ch;
  }

  .action-edit-form__label {
    font-size: var(--text-x-small);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--card-text-color);
  }

  .action-edit-form__title {
    font-size: clamp(var(--text-medium), 6vw, var(--text-x-large));
    font-weight: 900;
    line-height: 1.15;
    color: var(--card-content-color);
    resize: none;

    @supports (field-sizing: content) {
      field-sizing: content;
      min-block-size: 1lh;
    }
  }

  .action-edit-form__row {
    display: flex;
    gap: 1ch;

    @media (max-width: 479px) {
      flex-direction: column;
    }
  }

  .action-edit-form__field--half {
    flex: 1;
  }

  /* Notch (bottom action buttons) */
  .action-perma__notch {
    align-items: center;
    color: color-mix(in srgb, var(--card-color) 40%, var(--color-ink));
    display: inline-flex;
    gap: var(--inline-space);
    grid-area: notch-bottom;
    inline-size: auto;
    justify-content: center;
    margin-inline: auto;
    position: relative;
    text-align: center;
    z-index: 0;

    &:has(.btn) {
      translate: 0 calc(-1 * var(--half-btn-height));
    }

    form {
      background-color: var(--color-canvas);
      border-radius: 99rem;
    }

    .btn:not(.btn--plain, .btn--reversed) {
      --btn-background: var(--card-color);
      --btn-color: var(--color-ink-inverted);
    }

    .btn--reversed {
      --btn-background: var(--color-canvas);
      --btn-color: var(--card-color);
      --btn-border-color: var(--color-container);
    }

    @media (max-width: 639px) {
      flex-direction: column;
    }
  }

  /* Closure message */
  .action-perma__closure-message {
    color: var(--card-color);
    grid-area: closure-message;
    margin-block: var(--block-space) var(--block-space-double);
    padding-inline: 1ch;

    .btn--plain {
      --btn-color: var(--card-color);
      text-decoration: underline;
    }

    @media (max-width: 799px) {
      margin-block: var(--block-space-half);
      translate: 0 calc(-0.5 * var(--half-btn-height));
    }

    @media (min-width: 800px) {
      .action-perma__notch:has(.btn) ~ & {
        margin-block: var(--block-space-half) var(--block-space);
        translate: 0 calc(-0.5 * var(--half-btn-height));
      }
    }
  }

  /* When completed, use green color scheme */
  &:has(.card__closed) .card {
    --card-bg-color: color-mix(in srgb, var(--color-action-complete) 4%, var(--color-canvas));
    --card-content-color: color-mix(in srgb, var(--color-action-complete) 30%, var(--color-ink));
    --card-text-color: color-mix(in srgb, var(--color-action-complete) 75%, var(--color-ink));
    --card-border: 1px solid color-mix(in srgb, var(--color-action-complete) 33%, var(--color-ink-inverted));
  }

  &:has(.card__closed) .card__board {
    background-color: var(--color-action-complete);
  }

  /* Completion stamp — Fizzy's exact pattern */
  .action-perma .card__closed {
    --stamp-color: color-mix(in srgb, var(--color-action-complete) 65%, transparent);

    align-items: center;
    backdrop-filter: blur(2px);
    background-color: color-mix(in srgb, var(--card-bg-color) 90%, transparent);
    border-radius: 0.2em;
    border: 0.5ch solid var(--stamp-color);
    color: var(--color-ink-dark);
    display: flex;
    flex-direction: column;
    font-weight: bold;
    inset: auto 0 -1lh auto;
    justify-content: center;
    max-inline-size: 25ch;
    min-inline-size: 16ch;
    padding: 1ch;
    pointer-events: none;
    position: absolute;
    rotate: 5deg;
    transform-origin: top right;
    z-index: 2;
  }

  .action-perma .card__closed-title {
    color: var(--stamp-color);
    font-size: 1.3em;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
  }

  .action-perma .card__closed-date {
    font-family: var(--font-mono);
    text-transform: uppercase;
  }

  .action-perma .card__closed-by {
    border-block-end: 1px dashed currentcolor;
  }

  /* Due date display — distinct from steps */
  .action-perma__due-date {
    align-items: center;
    color: var(--card-text-color);
    display: inline-flex;
    gap: 0.5ch;
    margin-block-start: 1.5ch;
  }

  .action-perma__due-date--overdue {
    color: oklch(var(--lch-red-medium));
  }

  .action-perma__danger {
    margin-block-start: var(--block-space-double);
    text-align: center;
  }

  /* Action list container on risk show page */
  .action-cards {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
}
