/* 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, 900px);
    inline-size: fit-content;
    margin-block-start: var(--block-space);
    max-inline-size: 100%;
    margin-inline: auto;
    position: relative;

    @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;
      }
    }

    /* Meta grid — Fizzy's exact 2×2 layout */
    .card__meta {
      --meta-spacer-block: 0.5ch;
      --meta-spacer-inline: 0.75ch;

      align-items: center;
      color: var(--card-text-color);
      display: grid;
      font-size: var(--text-x-small);
      font-weight: 500;
      grid-template-areas:
        "avatars-author text-added text-updated avatars-assignees"
        "avatars-author text-author text-assignees avatars-assignees";
      grid-template-columns: auto auto 1fr auto;
      inline-size: fit-content;
      text-transform: uppercase;

      strong,
      .local-time-value {
        font-weight: 900;
      }

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

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

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

    .card__meta-avatars--author { grid-area: avatars-author; }
    .card__meta-avatars--assignees { grid-area: avatars-assignees; }
    .card__meta-text--added { grid-area: text-added; }
    .card__meta-text--author { grid-area: text-author; }
    .card__meta-text--updated { grid-area: text-updated; }
    .card__meta-text--assignees { grid-area: text-assignees; }

    .card__meta-avatars {
      align-self: center;
    }

    .card__meta-avatars--author {
      margin-inline-end: var(--meta-spacer-inline);
    }

    .card__meta-avatars--assignees {
      display: flex;
      margin-inline-start: var(--meta-spacer-inline);
    }

    .card__meta-text {
      line-height: 1;
      white-space: nowrap;

      .icon {
        --icon-size: 0.9em;
        margin-inline-end: 0.5ch;
        vertical-align: top;
      }
    }

    /* Top row */
    .card__meta-text:nth-of-type(odd) {
      border-block-end: var(--card-border);
      padding-block-end: var(--meta-spacer-block);
    }

    /* Bottom row */
    .card__meta-text:nth-of-type(even) {
      padding-block-start: var(--meta-spacer-block);
    }

    /* Left column */
    .card__meta-text:nth-of-type(-n+2) {
      border-inline-end: var(--card-border);
      padding-inline-end: var(--meta-spacer-inline);
    }

    /* Right column */
    .card__meta-text:nth-of-type(n+3) {
      padding-inline-start: var(--meta-spacer-inline);
    }

    .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-bg-color: color-mix(in srgb, var(--card-color) 4%, var(--color-canvas));
    --card-content-color: color-mix(in srgb, var(--card-color) 30%, var(--color-ink));
    --card-text-color: color-mix(in srgb, var(--card-color) 75%, var(--color-ink));
    --card-border: 1px solid color-mix(in srgb, var(--card-color) 33%, var(--color-ink-inverted));
    --card-padding-inline: 1.5em;
    --card-padding-block: 1.5em;
    --border-radius: 0.2em;

    background-color: var(--card-bg-color);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    inline-size: 100%;
    padding: var(--card-padding-block) var(--card-padding-inline);
    position: relative;

    html[data-theme="dark"] & {
      box-shadow: 0 0 0 1px var(--color-ink-lighter);
    }

    @media (prefers-color-scheme: dark) {
      html:not([data-theme]) & {
        box-shadow: 0 0 0 1px var(--color-ink-lighter);
      }
    }
  }

  .action-perma .card__header {
    align-items: center;
    display: flex;
    gap: 1ch;
    margin-block-start: calc(-1 * var(--card-padding-block));
    margin-inline: calc(-1 * var(--card-padding-inline)) calc(-0.5 * var(--card-padding-inline));
    min-inline-size: 0;
  }

  .action-perma .card__board {
    align-items: center;
    align-self: start;
    background-color: var(--card-color);
    border-radius: var(--border-radius) 0 var(--border-radius) 0;
    color: var(--color-ink-inverted);
    display: inline-flex;
    font-weight: 600;
    max-inline-size: 100%;
    min-inline-size: 0;
    padding-block: 0.25lh;
    padding-inline: var(--card-padding-inline) 1ch;
  }

  .action-perma .card__board-name {
    border-inline-start: 1px solid color-mix(in hsl, transparent 75%, currentColor);
    color: currentColor;
    display: flex;
    margin-inline-start: 1ch;
    min-inline-size: 0;
    padding-inline-start: 1ch;
    text-transform: uppercase;
  }

  .action-perma .card__body {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    inline-size: 100%;
    padding-block: calc(var(--card-padding-block) * 0.75) var(--card-padding-block);
  }

  .action-perma .card__title {
    color: var(--card-content-color);
    font-weight: 900;
    line-height: 1.15;
    margin: 0;
    text-wrap: balance;
  }

  /* 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 cards — risk show page list items (mini board-card style)
  /* ======================================================================== */

  .action-card {
    --card-bg-color: color-mix(in srgb, var(--card-color) 4%, var(--color-canvas));
    --card-content-color: color-mix(in srgb, var(--card-color) 30%, var(--color-ink));
    --card-text-color: color-mix(in srgb, var(--card-color) 75%, var(--color-ink));
    --card-border: 1px solid color-mix(in srgb, var(--card-color) 33%, var(--color-ink-inverted));

    background-color: var(--card-bg-color);
    border-radius: 0.2em;
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    gap: 0.5ch;
    padding: 0.75em 1em;
    position: relative;

    html[data-theme="dark"] & {
      box-shadow: 0 0 0 1px var(--color-ink-lighter);
    }

    @media (prefers-color-scheme: dark) {
      html:not([data-theme]) & {
        box-shadow: 0 0 0 1px var(--color-ink-lighter);
      }
    }
  }

  .action-card__link {
    content: "";
    inset: 0;
    position: absolute;
    z-index: 0;
  }

  .action-card__header {
    align-items: center;
    display: flex;
    font-size: var(--text-x-small);
    font-weight: 600;
    gap: 1ch;
    justify-content: space-between;
    text-transform: uppercase;
  }

  .action-card__type {
    background-color: var(--card-color);
    border-radius: 0.2em;
    color: var(--color-ink-inverted);
    font-size: 0.75em;
    padding: 0.15em 0.5em;
  }

  .action-card__status {
    color: var(--card-text-color);
    display: flex;
    align-items: center;
    gap: 0.3ch;
  }

  .action-card__title {
    color: var(--card-content-color);
    font-size: var(--text-medium);
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
  }

  .action-card__description {
    color: var(--card-content-color);
    font-size: var(--text-small);
    line-height: 1.4;
    margin: 0;
    opacity: 0.8;
  }

  .action-card__meta {
    align-items: center;
    color: var(--card-text-color);
    display: flex;
    flex-wrap: wrap;
    font-size: var(--text-x-small);
    font-weight: 600;
    gap: 0.75ch;
    text-transform: uppercase;
  }

  .action-card__meta-text {
    align-items: center;
    display: flex;
    gap: 0.3ch;
    line-height: 1;
    white-space: nowrap;

    .icon {
      --icon-size: 1em;
    }
  }

  .action-card__meta-text + .action-card__meta-text {
    border-inline-start: var(--card-border);
    padding-inline-start: 0.75ch;
  }

  .action-card__meta-text--overdue {
    color: oklch(var(--lch-red-medium));
    font-weight: 700;
  }

  /* Steps icon inside meta — exact same size as text for alignment */
  .action-card__meta .steps__icon {
    block-size: 1em;
    inline-size: 1em;
  }

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