:root {
  --uwsp-card-font-family: "Libre Franklin", sans-serif;
  --uwsp-card-font: var(--uwsp-card-font-family, var(--wp--preset--font-family--body, inherit));
  --uwsp-card-border: #e2e8f0;
  --uwsp-card-border-color: #e2e8f0;
  --uwsp-card-primary-color: #512698;
  --uwsp-card-header-bg: inherit;
  --uwsp-card-header-text: var(--uwsp-card-primary-color);
  --uwsp-card-button-primary-bg: var(--uwsp-card-primary-color);
  --uwsp-card-button-primary-text: #fff;
  --uwsp-card-button-outline-bg: transparent;
  --uwsp-card-button-outline-text: var(--uwsp-card-primary-color);
  --uwsp-card-bg-color: rgba(248, 249, 250, 1) !important;
  --uwsp-card-text: #1a202c;
  --uwsp-card-radius: 4px;
  --uwsp-card-shadow: none;
}

/* em used  instead of rem for wordpress editor scaling */
.program-card {
  border: 1px solid var(--uwsp-card-border);
  border-radius: var(--uwsp-card-radius);
  background: var(--uwsp-card-bg-color);
  box-shadow: var(--uwsp-card-shadow);
  margin-bottom: 2em;
  overflow: hidden;
  transition: all 0.3s ease;
  font-family: var(--uwsp-card-font);

  /* Card Header */
  .program-card-header {
    padding: 1.5em;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: default;
    border-bottom: 1px solid var(--uwsp-card-border);
  }

  &.is-collapsible .program-card-header {
    cursor: pointer;
  }

  .program-card-title {
    margin: 0;
    color: var(--uwsp-card-header-text);
    text-transform: uppercase;
    font-size: 1.5em;
    font-weight: 700;
  }

  .program-card-toggle {
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--uwsp-card-header-text);
    padding: 0;
    display: flex;
    align-items: center;

    .dashicons {
      font-size: 1.25em;
    }
  }

  /* Card Content */
  .program-card-content {
    padding: 1em;
    transition: max-height 0.3s ease-out, opacity 0.3s ease-out;
    max-height: 2000px;
    opacity: 1;
  }

  &.is-collapsed .program-card-content {
    display: none;
    padding: 0;
    max-height: 0;
    opacity: 0;
    pointer-events: none;
  }

  &.is-collapsed .program-card-header {
    border-bottom: none;
  }

  .program-card-excerpt {
    color: var(--uwsp-card-text);
    line-height: 1.6em;
    margin-bottom: 1.5em;
  }

  /* Details Section */
  .program-card-details {
    display: flex;
    flex-direction: column;
    gap: 1em;
    margin-bottom: 2em;
  }

  .program-card-detail {
    display: flex;
    flex-direction: column;
    gap: 0.25em;
  }

  .program-card-label {
    color: var(--uwsp-card-header-text);
    font-weight: 700;
    font-size: 1.1em;
    text-transform: uppercase;
  }

  .program-card-value {
    color: var(--uwsp-card-text);
    font-size: 1em;
  }

  /* Actions Section */
  .program-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75em;
    margin-top: 1em;
  }

  .program-card-button {
    padding: 0.6em 1.25em;
    font-weight: 700;
    font-size: 0.9em;
    text-transform: uppercase;
    border-radius: 4px;
    text-decoration: none !important;
    display: inline-block;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
    border: 2px solid var(--uwsp-card-border-color);
    cursor: pointer;

    /* Primary Button (View Program) */
    &.program-card-button-primary {
      background-color: var(--uwsp-card-button-primary-bg);
      color: var(--uwsp-card-button-primary-text) !important;
      border: 1px solid var(--uwsp-card-button-primary-bg);

      &:hover {
        background-color: color-mix(in srgb, var(--uwsp-card-button-primary-bg), black 20%);
        border-color: color-mix(in srgb, var(--uwsp-card-button-primary-bg), black 20%);
      }
    }

    /* Outline Button (Grad Plan, Major Map) */
    &.program-card-button-outline {
      background-color: var(--uwsp-card-button-outline-bg);
      color: var(--uwsp-card-button-outline-text) !important;
      border: 1px solid var(--uwsp-card-button-primary-bg);

      &:hover {
        background-color: var(--uwsp-card-button-primary-bg);
        color: var(--uwsp-card-button-primary-text) !important;
      }
    }
  }

  /* Graphical Mode */
  &.program-card-graphical {
    aspect-ratio: 4 / 5;
    position: relative;
    border: none;
    display: flex !important;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 400px;
    padding: 0;
    margin: 0.5em;
    overflow: hidden;
    text-decoration: none !important;
    width: 100%;
    border-radius: 5%;

    .program-card-background {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-size: cover;
      background-position: center;
      transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
      z-index: 0;
    }

    &:hover .program-card-background {
      transform: scale(1.1);
    }

    &.no-image .program-card-background {
      background-color: var(--uwsp-card-primary-color);
    }

    .program-card-overlay {
      position: relative;
      z-index: 1;
      background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.4) 60%, transparent 100%);
      padding: 2.5em 1.5em 1.5em;
      width: 100%;
      box-sizing: border-box;
    }

    .program-card-title {
      color: #fff !important;
      font-size: 1.6em;
      line-height: 1.1;
      text-shadow: 0 2px 4px rgba(0,0,0,0.5);
      text-transform: uppercase;
      margin: 0;
      font-weight: 800;
    }

    /* Hide standard content in graphical mode if somehow present */
    .program-card-header,
    .program-card-content {
      display: none;
    }
  }
}