:root {

}


/* -------------------------------------------------- */
/* BADGES */
/* -------------------------------------------------- */

.badge-list-wrapper {
  position: relative;
  display: flex;

  .badge-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-md);
    max-height: 36px;
    overflow: hidden;
    transition: max-height 0.3s ease;
  }

  &.expanded {
    .badge-list {
      max-height: none;
    }

    .badge-list-toggle {
      transform: rotate(180deg);
    }
  }

  .badge-list-toggle {
    padding: 8px;
    border: none;
    background: transparent;
    cursor: pointer;
    transition: transform 0.3s ease;

    &.hidden {
      display: none;
    }

    svg {
      display: block;
    }
  }
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  padding: 6px 10px;
  width: fit-content;
  border-radius: var(--radius-pill);
  background: var(--badge-default);
}

.badge-category {
  background: var(--badge-category);
}


/* -------------------------------------------------- */
/* EVENT CARD */
/* -------------------------------------------------- */
#person-history-wrapper {
  a {
    color: var(--gin-color-text);
    text-decoration: none;
  }
}

.person-history-event-item {
  position: relative;
  overflow: visible;
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  box-shadow: var(--gin-shadow-l1);
  
  .meta {
    color: var(--color-text-muted);
    font-size: 14px;
    margin-bottom: var(--space-sm);
  }

  .title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: var(--space-md);

    a {
      text-decoration: none;
      color: #000;
      font-size: 16px;
      line-height: 24px;
    }
  }

  .status {
    margin-top: var(--space-sm);
  }

  .status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    padding: 4px 8px;
    width: fit-content;
    border-radius: var(--radius-sm);
  }

  .status-invited { background: var(--status-invited); }
  .status-captured { background: var(--status-captured); }

  .status-pending-opt-in,
  .status-pending_opt_in {
    background: var(--status-pending);
  }

  .status-registered { background: var(--status-registered); }
  .status-deregistered { background: var(--status-deregistered); }
  .status-attended { background: var(--status-attended); }

  /* ticket cutout effect */

  .ticket-hole-front,
  .ticket-hole-back {
    &::before {
      content: "";
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 24px;
      height: 24px;
      border-radius: 50%;
      border: 1px solid var(--color-border);
      background: #fff;
      z-index: 2;
    }

    &::after {
      content: "";
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 24px;
      height: 30px;
      background: #fff;
      z-index: 3;

      @media (max-width: 767px) {
        width: 12px; 
        height: 26px;
      }
    }
  }

  .ticket-hole-front {
    &::before { 
      left: -16px; 
      
      @media (max-width: 767px) {
        left: -13px; 
      }
    }

    &::after { 
      left: -25px; 

      @media (max-width: 767px) {
        left: -13px; 
      }
    }
  }

  .ticket-hole-back {
    &::before { 
      right: -16px; 

      @media (max-width: 767px) {
        right: -13px; 
      }
    }

    &::after { 
      right: -25px; 

      @media (max-width: 767px) {
        right: -13px; 
      }
    }
  }
}


/* -------------------------------------------------- */
/* CRM LAYOUT */
/* -------------------------------------------------- */


.person-entity-form,
.many-to-many-entity-person-event-form,
body:not(:has(.subscription-page-content)) .uv-crm-entity-person-show {
  display: flex;
  gap: 2%;
  padding: var(--gin-spacing-s);
  background: var(--gin-bg-layer);
  box-shadow: var(--gin-shadow-l1);
  border-radius: var(--gin-border-l);
  border: 1px solid var(--gin-border-color-layer);

  @media (min-width: 1440px) {
    display: grid;
    grid-template-columns: minmax(0, 11fr) minmax(0, 9fr);
  }

  &:has(> .layout-node-form) {
    display: block;
  }

  .layout-region-node-main {
    @media (min-width: 1440px) {
      display: grid;
      grid-template-columns: minmax(0, 11fr) minmax(0, 9fr);
      gap: 2%;
    }
  }

  i {
    margin-right: 10px;
    width: 22px;
    height: 22px;

  }

  .icon-cake { 
    content: url('/modules/custom/uv_admin/icons/cake.svg'); 
  }

  .icon-informal { 
    content: url('/modules/custom/uv_admin/icons/anrede.svg'); 
  }

  .icon-star { 
    content: url('/modules/custom/uv_admin/icons/vip.svg'); 
  }

  .icon-person { 
    content: url('/modules/custom/uv_admin/icons/person.svg'); 
  }

  .icon-pin {
    content: url('/modules/custom/uv_admin/icons/vertraulich.svg'); 
  }

  .icon-mail-arrow { 
    content: url('/modules/custom/uv_admin/icons/mail-arrow.svg'); 
  }

  .icon-mitglieder { 
    content: url('../icons/mitglieder.svg'); 
  }

  .union {
    content: url('../icons/union.svg'); 
  }

  .icon-land { 
    content: url('../icons/land.svg'); 
  }

  .icon-mitglied_seit { 
    content: url('../icons/mitglied_seit.svg'); 
  }

  .icon-funktion { 
    content: url('../icons/funktion.svg'); 
  }

  .icon-finanzen { 
    content: url('../icons/finanzen.svg'); 
  }

  .icon-phone { 
    content: url('../icons/phone.svg'); 
  }

  .icon-mail { 
    content: url('../icons/mail.svg'); 
  }

  .icon-social { 
    content: url('../icons/social.svg'); 
  }

  .icon-pin { 
    content: url('../icons/pin.svg'); 
  }

  .field--name-field-gender {
    display: inline-block;
  }

  .crm-left-column {
    .field--name-field-vip,
    .field--name-field-informal {
      display: inline-flex;
      margin-right: 10px;
      margin-block: 0 !important;

      .form-type-checkbox {
        margin-block: 0 !important;
      }
    }
  }

  .crm-right-column {
    .field--name-field-privacy-policy,
    .field--name-field-marketing {
      display: inline-flex;
      margin-right: 10px;
      margin-block: 0 !important;

      .form-type-checkbox {
        margin-block: 0 !important;
      }
    }

    .field--name-field-tags,
    .field--name-field-themes {
      .form-select {
        width: 100% !important;
      }
    }

    .field--name-field-childcare,
    .field--name-field-companions {
      .form-text,
      .form-email {
        max-width: 100%;
        width: 100%;
      }
    }
  }

  .divider-vertical {
    width: 1px;
    min-width: 1px;
    height: auto;
    border: none;
    background: var(--color-divider);
    margin: 0 20px;
    order: 2;
  }

  .person-detail {
    > .person-data-group {
      padding: var(--gin-spacing-s);
      background: var(--gin-bg-layer);
      box-shadow: var(--gin-shadow-l1);
      border-radius: var(--gin-border-l);
      border: 1px solid var(--gin-border-color-layer);
      position: relative;

      .field__item:has(> i) {
        display: flex;
        align-items: center;
        align-items: start;
      } 

      .gin-layer-wrapper {
        padding: 0;
        border: 0;
        box-shadow: none;
      }

      b {
        display: block;
      }

      b,
      .field__label,
      .field__item:not(:last-child),
      .field:not(:last-child),
      .field--name-field-email .field__item:not(:last-child),
      .view-crm-n2m-list .view-content > div:not(:last-child) {
        margin-bottom: 16px;
      }

      .field--name-field-themes:not(:last-child) {
        margin-bottom: 28px;
      }
    }

    > .person-data-group:not(:last-child) {
      margin-bottom: 16px;
    }

    .social-media-links--platforms {
      position: absolute;
      right: var(--gin-spacing-s);
      top: var(--gin-spacing-s);
    }

    .field-content {
      display: flex;
      align-items: center;
    }

    &.crm-right-column {
      > .person-data-group {
        padding: 0;
        border: 0;
        box-shadow: none;
      }
    }
  }

  @media (min-width: 768px) {
    padding: var(--gin-spacing-l);

    .person-detail > .person-data-group {
      padding: var(--gin-spacing-l);
    }

    .social-media-links--platforms {
      right: var(--gin-spacing-l);
      top: var(--gin-spacing-l);
    }
  }

  @media (max-width: 1024px) {
    flex-direction: column;
    gap: 24px;

    .content.person-detail.crm-left-column,
    .content.person-detail.crm-right-column {
      width: 100%;
      order: unset;
    }

    .divider-vertical {
      display: none;
    }
  }
}

.person-entity-form,
.many-to-many-entity-person-event-form {
  flex-wrap: wrap;

  .crm-left-column,
  .crm-right-column {
    min-width: 0;
    max-width: 100%;
  }

  .crm-right-column + .fieldset {
    flex: 0 0 48%;
  }
}


/* -------------------------------------------------- */
/* PERSON EDIT */
/* -------------------------------------------------- */

.person-entity-form {
  .layout-region-node-main {
    @media (min-width: 1440px) {
      display: grid;
      grid-template-columns: minmax(0, 11fr) minmax(0, 9fr);
      gap: 2%;
    }
  }

  .field-multiple-table tr .form-item:not(:last-of-type) {
    margin: 0;

    .form-element--type-select {
      width: 100%;
    }
  }
}

/* general information */
.person-entity-form .field--name-field-gender fieldset {
  margin: 0;
}


/* Contact information */
.field--type-uv-extended-address-item,
.field--type-extended-email,
.field--type-extended-telephone {
  margin-block-end: var(--gin-spacing-xl);

  .field-multiple-table thead th {
    background-color: transparent!important;

    h4 {
      color: var(--gin-color-title);
      font-size: 14px;
      padding: 0;
    }
  }

  tr {
    display: flex;
    width: 100%;
    align-items: center;
  }

  td {
    padding: 0;

    &:has(.ajax-progress) {
      position: relative;
      width: 32px;
      height: 32px;
      min-width: 32px;

      input {
        margin-right: 0;
        display: none;
      }

      .ajax-progress {
        position: absolute;
        right: 50%;
        top: 50%;
        transform: translate(50%, -50%);
        margin: 0;
      }
    }

    &:has(.form-submit) {
      display: flex;
    }
  }

  th.field-label {
    display: table-cell;
    padding: 0;

    + th {
      display: none;
    }
  }

  table .form-submit.button {
    font-size: 0;
    position: relative;
    background-color: transparent;
    width: 16px;
    height: 16px;
    background: url('/modules/custom/uv_admin/icons/close.svg') center / 16px 16px no-repeat;
    margin-right: 0;
    border: 0 !important;
    box-shadow: none;
    margin: 0;
    padding: 0;
  }

  .ajax-progress__message {
    display: none;
  }
  
  .tabledrag-cell {
    display: none;
  }

  .ajax-new-content {
    gap: 20px;
    display: flex;
    align-items: center;
    width: 100%;
  }

  .js-form-type-select {
    gap: 20px;
    display: flex;
    flex-shrink: 0;

    .form-required {
      display: none;
    }
  }

  td:has(.js-form-type-email),
  td:has(.phone_ajax_wrapper) {
    gap: 20px;
    display: flex;
    margin-block: 0;
    align-items: center;
    width: 100%;
  }

  table {
    thead {
      th:last-child {
        display: none;
      }

      th.field-label {
        + th {
          display: none;
        }
      }
    }
  }

  .phone_ajax_wrapper,
  .js-form-type-email {
    width: 100%;
    margin-block: 0;
    
    input {
      width: 100%;
    }
  }

  .form-type--checkbox {
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
    flex-shrink: 0;
    justify-content: end;
    margin: 0;
    position: relative;
    width: 72px;
    height: 40px;
    cursor: pointer;

    label {
      margin: 0;
      display: none;
    }

    &:hover, &:active, &:focus {
      label {
        display: block;
        color: #555;
        margin-right: 10px;
      }
    }

    input {
      font-size: 0;
      position: relative;
      background-color: transparent;
      width: 27px;
      height: 27px;
      background: url('/modules/custom/uv_admin/icons/standard.svg') center / 27px 27px no-repeat;
      margin-right: 0;
      border: 0 !important;
      box-shadow: none;
      margin: 0 auto;
      cursor: pointer;

      &:checked {
        background: url('/modules/custom/uv_admin/icons/standard_green.svg') center / 27px 27px no-repeat;
      }
    }
  }
}

.field--type-extended-email,
.field--type-extended-telephone {
  & .js-form-type-select {
    flex-shrink: inherit;
  }

  .form-type--checkbox {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;

    label {
      position: absolute;
      bottom: -8px;
      margin: 0;
    }

    &:hover, &:active, &:focus {
      label {
        margin-right: 0;
      }
    }
  }

  .form-type--select {
    min-width: 155px;
  }
}


.person-entity-add-form,
.person-entity-edit-form {
  .form-type--email {
    position: relative;

    &:before {
      content: url('/modules/custom/uv_admin/icons/mail.svg');
      position: absolute;
      left: 8px;
      top: 10px; /* hotfix:  ToDO optimize svg */
      pointer-events: none;
    }

    input {
      padding-left: calc(var(--input-padding-horizontal) + 24px);
    }
  }

  .form-type--select {
    max-height: 40px;
  }
}

.person-entity-add-form,
.person-entity-edit-form {
  .form-type--tel {
    position: relative;

    &:before {
      content: url('/modules/custom/uv_admin/icons/phone.svg');
      position: absolute;
      left: 8px;
      top: 11px; /* hotfix:  ToDO optimize svg */
      pointer-events: none;
    }

    input {
      padding-left: calc(var(--input-padding-horizontal) + 24px);
    }
  }

  .form-type--select {
    max-height: 40px;
  }
}

.field--type-uv-extended-address-item {
  thead th.field-label {
    display: table-cell;
  }

  td {
    &:has(.ajax-new-content) {
      width: 100%;
    }

    &:has(.form-submit) {
      align-self: end;
      margin-left: 15px;
      margin-bottom: 17px;
    }

    &:has(.ajax-progress) {
      .ajax-progress {
        bottom:0;
        margin: 0;
        transform: unset;
      }
    }
  }

  .chosen-drop {
    margin-left: 0;
  }

  .uv-core-address-autocomplete {
    padding: 0;

    :not(.js-form-type-textfield) {
      > label {
        display: none;
      }
    }
  } 

  tbody .form-item.form-type--select {
    margin: 0;

    select {
      width: 100%;
    }
  }

  [id^="field-address-"][id*="-address-ajax-wrapper"] {
    > div {
      display: grid;
      /* align-items: end; */
      gap: 20px;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      align-items: end;

      input,
      > * {
        width: 100%;
        margin-block-end: 0 !important;
      }
    }

    [id^="edit-field-address-"][id*="-address-country-code"] {
      flex: 1;

      .country {
        width: 100%!important;

        .chosen-single {
          display: flex;
          align-items: center;
        }
      }
    }
  }

  .address-container-inline {
    display: grid;
    gap: 20px;

    > * {
      width: 100%;
      margin-block: 0 !important;
    }
  }

  fieldset.uv-core-address-autocomplete div[class*="line1"],
  fieldset.uv-core-address-autocomplete div[class*="line2"],
  fieldset.uv-core-address-autocomplete div[class*="line3"] {
    grid-column: 1 / span 2;
  }

  fieldset.uv-core-address-autocomplete .address-container-inline {
    grid-column: 1 / span 2;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: end;

    select {
      height: 40px;
    }
  }

  tr {
    [id^="edit-field-address-"][id$="-address"],
    [id^="edit-field-address-"][id*="-address--"] {
      &:has(> :nth-child(6)) {
        .form-type--checkbox {
          &:hover, &:active, &:focus {
            label {
              display: block;
              color: #555;
            }
          }
        }
      }
    }
  }
 
  .form-type--checkbox {
    align-items: end;

    input {
      font-size: 0;
      position: relative;
      background-color: transparent;
      width: 27px !important;
      height: 27px !important;
      background: url('/modules/custom/uv_admin/icons/standard.svg') center / 27px 27px no-repeat !important;
      margin-right: 0;
      border: 0 !important;
      box-shadow: none;
      margin: 0 auto;
      cursor: pointer;

      &:checked {
        background: url('/modules/custom/uv_admin/icons/standard_green.svg') center / 27px 27px no-repeat !important;

        &:before {
          display: none;
        }
      }

      &:before {
        display: none;
      }  
    }

    &:last-child {
      grid-column: 1 / span 2;
      margin: 0;
    }
  }

  .draggable {
    min-height: 113px;

    > td:nth-child(2) {
      width: 100%;

      &:has(.ajax-progress__throbber) {
        div[class*="js-form-item-address"] {
          display: none;
        }
      }
    }
  }

  .address-container-inline {
    + .form-type--checkbox {
      margin: 0;
    }

    .form-type--textfield + .form-type--select {
      margin-top: 10px !important;
    }

    select, .chosen-container {
      width: 100% !important; 
    }
  }

  div[class*="-address-country-code"] {
    .ajax-progress{
      right: -25px;
      top: 25px;
    }
  }

  .ajax-new-content {
    .form-type--checkbox {
      margin: 0;
    }
  }
}

fieldset.uv-core-address-autocomplete {
  border: 0;
  width: 100%;
  position: relative;

  .fieldset__wrapper {
    margin: 0;
  } 
}


.mailer-entity-navision-add-form,
.organization-entity-add-form,
.crm-category-entity-other-add-form,
.mailer-entity-mailer-add-form {
  max-width: var(--content-width-small);
}

.view-events-n2m-list,
.view-uv-mailer-subscriber-select,
.view-crm-declarations,
.view-crm-categories,
.view-crm-mailers,
.view-crm-organizations,
.view-crm-persons {
  .entity-logger li,
  .item-list ul li, 
  .menu-item {
    list-style: none;
    margin-left: 0;
  }
}


/* style close button / remove button */
.field--name-uv-n2m-field-person-person,
.field--name-field-local-application,
.field--name-field-expertise-experience,
.field--name-field-expertise-state-level,
.field--name-field-professional-expertise,
.field--name-uv-n2m-field-person-organization,
.field--name-uv-n2m-field-person-navision,
.field--name-uv-n2m-field-person-mailer {
  td {   
    &:has(.button) {
      display: flex;
      padding: var(--gin-spacing-m);
    }

    .button.form-submit {
      font-size: 0;
      position: relative;
      background-color: transparent;
      width: 16px;
      height: 16px;
      background: url('/modules/custom/uv_admin/icons/close.svg') center / 16px 16px no-repeat;
      border: 0 !important;
      box-shadow: none;
      margin: 0;
      padding: 0;

      &:hover, &:active, &:focus, &:disabled {
        background-color: transparent;
        border: 0 !important
      }
    }

    .ajax-progress {
      margin: 0;
      position: absolute;
      left: 23px;
      top: 27px;    
    }
  }

  .form-element.chosen-container-single {
    width: 100% !important;
  }
}

.field--name-uv-n2m-field-person-organization,
.field--name-uv-n2m-field-person-navision,
.field--name-uv-n2m-field-person-mailer {
  thead {
    display: none;
  }

  tr {
    display: flex;
    justify-content: space-between;
    align-items: center;
    
    td {
      min-width: 0;

      &:nth-child(2) {
        flex: 1 0 65%;
        padding-left: 0;
      }

      &:nth-child(3) {
        padding-left: 0;
        flex-shrink: 1;
      }


      &:first-child {
        order: +1;
        flex: 0 0 auto;
        padding: 0;
      }
    }
  }

  .form-type--entity-autocomplete,
  .form-type--select {
    margin: 0;
  }

  .claro-autocomplete {
    width: 100%;
  }
}

.field--name-uv-n2m-field-person-mailer {
  tr {
    td {
      &:nth-child(2),
      &:nth-child(3) {
        flex: 0 0 auto; 
      }
    }
  }
}

.field--name-uv-n2m-field-person-organization {
  tr {
    td:last-child {
      display: none;
    }
  }
}

.field--name-uv-n2m-field-person-person,
.field--name-field-local-application,
.field--name-field-expertise-experience,
.field--name-field-expertise-state-level,
.field--name-field-professional-expertise {
  thead {
    th:first-of-type {
      border-radius: var(--gin-border-m);
      border: 0;
      background: transparent;
      padding: 0;

      h4 {
        color: var(--gin-color-title);
        font-size: 14px;
        padding: 0;
      }
    }

    th:nth-child(2) {
      display: none;
    }
  }

  tbody tr {
    display: flex;
    justify-content: space-between;
    
    td {
      min-width: 0;

      &:has(.button) {
        align-items: center;
        padding-right: 0;
      }
    }
  }

  .field-multiple-drag{
    display: none;
  }
}

.form-managed-file {
  .button.remove-button {
    font-size: 0;
    position: relative;
    background-color: transparent;
    width: 16px;
    height: 16px;
    background: url('/modules/custom/uv_admin/icons/close.svg') center / 16px 16px no-repeat;
    margin-right: 0;
    border: 0 !important;
    box-shadow: none;

    &:hover, &:active, &:focus, &:disabled {
      background-color: transparent;
      border: 0!important
    }
  }
}

.ief-entity-operations {
  .button.form-submit:nth-child(2) {
    font-size: 0;
    position: relative;
    background-color: transparent;
    width: 16px;
    height: 16px;
    background: url('/modules/custom/uv_admin/icons/close.svg') center / 16px 16px no-repeat;
    margin-right: 0;
    border: 0 !important;
    box-shadow: none;

    &:hover, &:active, &:focus, &:disabled {
      background-color: transparent;
      border: 0!important
    }
  }
}

.field--type-social-media-links-field {
  input {
    width: 100%;
  }
}