:root {
  --bg-color: #181a20;
  --primary-color: #282c34;
  --accent-color: #4f8cff;
  --accent-color-contrast: #000;
  --text-color: #e0e0e0;
  --error-color: #ff4d4d;
  --warning-color: #ffcc00;
  --success-color: #4caf50;
  --muted-color: #888;
  --border-color: #333;
  --font-size-base: 16px;
  --font-size-lg: 1.25rem;
  --font-size-sm: 0.875rem;
  --font-family: 'OpenSans';
  --font-family-title: 'Roboto';
  --radius: 8px;
  --transition: 0.2s ease;
  --box-shadow: rgba(0, 0, 0, 0.15);
  --box-shadow-color: rgba(79,140,255,0.25);

  --event-0-color: #4caf50;
  --event-1-color: #ff4d4d;
  --event-2-color: #ffcc00;
  --event-3-color: #bb52d9;
}

:root {
  /* jQuery UI theme variables */
  --ui-bg-header: var(--primary-color);
  --ui-bg-content: var(--bg-color);
  --ui-bg-default: var(--primary-color);
  --ui-bg-hover: var(--accent-color);
  --ui-bg-active: var(--accent-color);
  --ui-bg-highlight: var(--accent-color);
  --ui-bg-error: #ffa9a9;
  --ui-bg-overlay: #aaaaaa;
  --ui-bg-shadow: #666666;

  --ui-border-header: var(--border-color);
  --ui-border-content: var(--border-color);
  --ui-border-default: var(--border-color);
  --ui-border-hover: var(--border-color);
  --ui-border-active: var(--accent-color);
  --ui-border-highlight: var(--accent-color);
  --ui-border-error: var(--border-color);

  --ui-text-header: var(--text-color);
  --ui-text-content: var(--text-color);
  --ui-text-default: var(--text-color);
  --ui-text-hover: var(--accent-color-contrast);
  --ui-text-active: var(--accent-color-contrast);
  --ui-text-highlight: var(--accent-color-contrast);
  --ui-text-error: var(--error-color);

  --ui-icon-header: var(--text-color);
  --ui-icon-content: var(--text-color);
  --ui-icon-default: var(--text-color);
  --ui-icon-hover: var(--text-color);
  --ui-icon-active: var(--text-color);
  --ui-icon-highlight: var(--text-color);
  --ui-icon-error: var(--error-color);

  --ui-radius: var(--radius);
  --ui-shadow: 0px 0px 5px var(--ui-bg-shadow);

  /* FullCalendar variables */
  --fc-small-font-size: 0.85em;
  --fc-page-bg-color: var(--bg-color, #181a20);
  --fc-neutral-bg-color: #23272f;
  --fc-neutral-text-color: var(--muted-color, #888);
  --fc-border-color: var(--border-color, #333);
  --fc-button-text-color: var(--accent-color-contrast, #000);
  --fc-button-bg-color: var(--accent-color, #4f8cff);
  --fc-button-border-color: var(--accent-color, #4f8cff);
  --fc-button-hover-bg-color: color-mix(in srgb, var(--accent-color) 90%, white);
  --fc-button-hover-border-color: color-mix(in srgb, var(--accent-color) 90%, white);
  --fc-button-active-bg-color: var(--accent-color,#3a6fd8);
  --fc-button-active-border-color: var(--accent-color,#3a6fd8);
  --fc-event-bg-color: var(--success-color, #4caf50);
  --fc-event-border-color: var(--success-color, #4caf50);
  --fc-event-text-color: var(--accent-color-contrast, #000);
  --fc-event-selected-overlay-color: rgba(79,140,255,0.15);
  --fc-more-link-bg-color: #23272f;
  --fc-more-link-text-color: var(--accent-color, #4f8cff);
  --fc-event-resizer-thickness: 8px;
  --fc-event-resizer-dot-total-width: 8px;
  --fc-event-resizer-dot-border-width: 1px;
  --fc-non-business-color: #23272f;
  --fc-bg-event-color: var(--accent-color, #4f8cff);
  --fc-bg-event-opacity: 0.15;
  --fc-highlight-color: rgba(79,140,255,0.10);
  --fc-today-bg-color: rgba(79,140,255,0.08);
  --fc-now-indicator-color: var(--error-color, #ff4d4d);
  --fc-list-event-hover-bg-color: var(--border-color, #20232a);
}

@font-face {
  font-family: 'OpenSans';
  src: url('/plugins/fonts/OpenSans-VariableFont_wdth,wght.ttf') format('truetype');
  font-style: normal;
  font-weight: 100 900;
}
@font-face {
  font-family: 'OpenSans';
  src: url('/plugins/fonts/OpenSans-Italic-VariableFont_wdth,wght.ttf') format('truetype');
  font-style: italic;
  font-weight: 100 900;
}
@font-face {
  font-family: 'Roboto';
  src: url('/plugins/fonts/Roboto-VariableFont_wdth,wght.ttf') format('truetype');
  font-style: normal;
  font-weight: 100 900;
}
@font-face {
  font-family: 'Roboto';
  src: url('/plugins/fonts/Roboto-Italic-VariableFont_wdth,wght.ttf') format('truetype');
  font-style: italic;
  font-weight: 100 900;
}

body {
  background: var(--bg-color);
  color: var(--text-color);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-family-title);
  color: var(--accent-color);
  margin-top: 1.5em;
  margin-bottom: 0.5em;
}

a {
  color: var(--accent-color);
  text-decoration: none;
  transition: color var(--transition);
}
a:hover {
  color: color-mix(in srgb, var(--accent-color) 90%, white);
}

a:hover > i {
  color: var(--accent-color-contrast);
}

* {
  box-sizing: border-box;
}

button, input, select, textarea {
  background: var(--primary-color);
  color: var(--text-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  font-size: var(--font-size-base);
  padding: 0.5em 1em;
  transition: background var(--transition), color var(--transition);
}

button:hover, input:focus,select:focus, textarea:focus {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  outline: none;
}
.selectmenu option.withicon {
  background-repeat: no-repeat !important;
  padding-left: 20px;
}
.selectmenu option.withicon .ui-icon {
  background-position: left top;
}
.withicon .ui-icon {
  background-color: var(--ui-bg-content, #181a20);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  width: 16px !important;
  height: 16px !important;
}
.withicon .noicon{
  visibility: hidden !important;
}

input[type=checkbox]{
  scale: 1.5;
}

.card {
  background: var(--primary-color);
  border-radius: var(--radius);
  box-shadow: 0 2px 8px var(--box-shadow);
  padding: 1.5em;
  margin: 1em 0;
  border: 1px solid var(--border-color);
}
.chip {
  color: var(--accent-color-contrast);
  font-size: var(--font-size-sm);
  background: var(--accent-color);
  border-radius: var(--radius);
  padding: 0.25em 0.75em;
  text-align: center;
  font-weight: 600;
  white-space: nowrap;
  box-shadow: 0 1px 4px var(--box-shadow-color);
  margin-right: 0.5em;
  margin-bottom: 0.2em;
  letter-spacing: 0.5px;
  border: 1px solid var(--accent-color);
  transition: background var(--transition), color var(--transition);
}
.chip-green, .chip.green, .chip.success {
  background: var(--success-color);
  border: 1px solid var(--success-color);
  box-shadow: 0 1px 4px color-mix(in srgb, var(--success-color) 90%, rgb(0, 0, 0));
}
.chip-red, .chip.red, .chip.error {
  background: var(--error-color);
  border: 1px solid var(--error-color);
  box-shadow: 0 1px 4px color-mix(in srgb, var(--error-color) 90%, rgb(0, 0, 0));
}

.chip-0{
  background: var(--event-0-color);
  border: 1px solid var(--event-0-color);
  box-shadow: 0 1px 4px color-mix(in srgb, var(--event-0-color) 90%, rgb(0, 0, 0));
}
.chip-1{
  background: var(--event-1-color);
  border: 1px solid var(--event-1-color);
  box-shadow: 0 1px 4px color-mix(in srgb, var(--event-1-color) 90%, rgb(0, 0, 0));
}
.chip-2{
  background: var(--event-2-color);
  border: 1px solid var(--event-2-color);
  box-shadow: 0 1px 4px color-mix(in srgb, var(--event-2-color) 90%, rgb(0, 0, 0));
}
.chip-jo, .chip-3{
  background: var(--event-3-color);
  border: 1px solid var(--event-3-color);
  box-shadow: 0 1px 4px color-mix(in srgb, var(--event-3-color) 90%, rgb(0, 0, 0));
}
.accordion {
  display: none;
}

hr {
  border: none;
  border-top: 1px solid var(--border-color);
  margin: 2em 0;
}

::-webkit-scrollbar {
  width: 8px;
  background: var(--bg-color);
}
::-webkit-scrollbar-thumb {
  background: var(--primary-color);
  border-radius: var(--radius);
}

.text-center {
  text-align: center;
}
.flex-row{
  display:flex;
  flex-direction: row;
}
.flex-column{
  display:flex;
  flex-direction: column;
}
.flex-gap {
  gap: 1em;
}
.flex-gap-sm {
  gap: 0.5em;
}
.flex-jc {
  justify-content: center;
}
.flex-ja {
  justify-content: space-around;
}
.flex-jb {
  justify-content: space-between;
}
.flex-je {
  justify-content: space-evenly;
}
.flex-ac{
  align-items: center;
}


.grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1em;
}
.grid-col4{
  grid-template-columns: repeat(4, 1fr);
}
.grid-col5{
  grid-template-columns: repeat(5, 1fr);
}

.rank-image, .event-orbat .rank-image {
  width: 32px;
  height: 32px;
  margin-right: 0.2em;
  border: none;
  background: none;
  box-shadow: none;
}


form .sortable-slots > .form-dynamic-slot {
  display: grid;
  grid-template-columns: auto 1fr 1fr 1fr 1fr auto auto;
  gap: 1em;
  align-items: center;
  justify-content: center;
  border: 1px solid aliceblue;
  border-radius: 6px;
  margin: 0.5em 0;
  padding: 0.5em 1em;
}

.sortable-slots .dynamicDivider, .sortable-slots .dynamicTitle, .sortable-slots .fullwidth{
  grid-column-start: 2;
  grid-column-end: 7;
}

a > i , button > i:only-child {
  background: none;
  border: none;
  color: var(--accent-color);
  font-size: 1.1em;
  margin: 0.3em 0.5em;
  border-radius: var(--radius);
  transition: background var(--transition), color var(--transition);
}

button:hover > i:only-child{
  color: var(--accent-color-contrast);
}

a > i:hover {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
}

@media (max-width: 768px) {
  .respohidden{
    display: none;
  }


  .form-group.grid.grid-col4, .form-group.grid.grid-col5 {
    display: grid;
    grid-template-columns: 1fr 40px;
    grid-template-rows: repeat(4, auto);
    gap: 0.5em 1em;
  }
  /* Place labels and checkboxes in zig-zag */
  .form-group.grid.grid-col4 > div:nth-child(1) { grid-column: 1; grid-row: 1; }
  .form-group.grid.grid-col4 > div:nth-child(2) { grid-column: 1; grid-row: 2; }
  .form-group.grid.grid-col4 > div:nth-child(3) { grid-column: 1; grid-row: 3; }
  .form-group.grid.grid-col4 > div:nth-child(4) { grid-column: 1; grid-row: 4; }
  .form-group.grid.grid-col4 > div:nth-child(5) { grid-column: 2; grid-row: 1; }
  .form-group.grid.grid-col4 > div:nth-child(6) { grid-column: 2; grid-row: 2; }
  .form-group.grid.grid-col4 > div:nth-child(7) { grid-column: 2; grid-row: 3; }
  .form-group.grid.grid-col4 > div:nth-child(8) { grid-column: 2; grid-row: 4; }
  /* Place labels and checkboxes in zig-zag */
  .form-group.grid.grid-col5 > div:nth-child(1) { grid-column: 1; grid-row: 1; }
  .form-group.grid.grid-col5 > div:nth-child(2) { grid-column: 1; grid-row: 2; }
  .form-group.grid.grid-col5 > div:nth-child(3) { grid-column: 1; grid-row: 3; }
  .form-group.grid.grid-col5 > div:nth-child(4) { grid-column: 1; grid-row: 4; }
  .form-group.grid.grid-col5 > div:nth-child(5) { grid-column: 1; grid-row: 5; }
  .form-group.grid.grid-col5 > div:nth-child(6) { grid-column: 2; grid-row: 1; }
  .form-group.grid.grid-col5 > div:nth-child(7) { grid-column: 2; grid-row: 2; }
  .form-group.grid.grid-col5 > div:nth-child(8) { grid-column: 2; grid-row: 3; }
  .form-group.grid.grid-col5 > div:nth-child(9) { grid-column: 2; grid-row: 4; }
  .form-group.grid.grid-col5 > div:nth-child(10) { grid-column: 2; grid-row: 5; }

  form .sortable-slots > .form-dynamic-slot{
    grid-template-rows: auto 1fr 1fr 1fr 1fr auto auto;
    grid-template-columns: 1fr;
    justify-items: center;
  }
  form .dynamic-add{
    flex-direction: column;
  }
  form .dynamic-add > *{
    width: 100%;
  }
  form .checkbox-group{
    justify-content: space-between;
  }
}

/* FullCalendar */
.fc-daygrid-dot-event.fc-event-mirror, .fc-daygrid-dot-event:hover {
  background: var(--border-color);
}

/**********************
***********************
***********************/

/* 404 Error Page*/
#error404 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 80vh;
  text-align: center;
  gap: 1.5em;
}

#error404 h1 {
  font-size: 3rem;
  color: var(--error-color);
  font-family: var(--font-family-title);
  margin-bottom: 0.5em;
  margin-top: 0;
  letter-spacing: 2px;
}

#error404 p {
  font-size: 1.25rem;
  color: var(--muted-color);
  margin-bottom: 1.5em;
}

#error404 button {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  border: none;
  border-radius: var(--radius);
  font-size: var(--font-size-lg);
  padding: 0.75em 2em;
  cursor: pointer;
  box-shadow: 0 2px 8px var(--box-shadow);
  transition: background var(--transition), color var(--transition), box-shadow var(--transition);
}

#error404 button:hover {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  box-shadow: 0 4px 16px var(--box-shadow-color);
}

@media (max-width: 600px) {
  #error-404 h1 {
    font-size: 2rem;
  }
  #error-404 p {
    font-size: 1rem;
  }
  #error-404 button {
    font-size: var(--font-size-base);
    padding: 0.6em 1.2em;
  }
}

/* Dialogs */
.ui-dialog .ui-dialog-content {
  margin: 0;
  padding: 1em 0 !important;
}


/* Login */
#login, #register, #reset_password, #setup {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100vh;
}

#login img, #register img, #reset_password img, #setup img {
  max-width: 100px;
  margin-bottom: 2em;
}

#login form, #register form, #reset_password form, #setup form {
  display: flex;
  flex-flow: column;
  background: var(--primary-color);
  padding: 2em;
  border-radius: var(--radius);
  box-shadow: 0 2px 8px var(--box-shadow);
  max-width: 700px;
}

#login label, #register label, #reset_password label, #setup label {
  display: block;
  margin-bottom: 0.5em;
}

#login input, #register input, #reset_password input, #setup input {
  margin-bottom: 1em;
}
#login .buttons, #register .buttons, #reset_password .buttons, #setup .buttons {
  display: flex;
  justify-content: space-between;
}
#login button, #register button, #reset_password button, #setup button {
  cursor: pointer;
}
#login .errors, #register .errors, #reset_password .errors, #setup .errors {
  min-height: 1.5em;
  margin-bottom: 1em;
  color: var(--error-color);
}

/* Navigation */
#menu {
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 220px;
  background: var(--primary-color);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 2em;
  box-shadow: 2px 0 8px var(--box-shadow);
  z-index: 100;
  overflow-y: auto;
}

#menu .logo {
  margin-bottom: 2em;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

#menu .logo img {
  max-width: 120px;
  max-height: 120px;
  width: auto;
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: var(--radius);
  object-fit: contain;
}

#menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#menu li {
  width: 90%;
  margin-bottom: 1em;
}

#menu li.active {
  position: relative;
}

#menu li.active::before {
  content: '';
  display: block;
  position: absolute;
  left: 0.7em;
  top: 50%;
  transform: translateY(-50%);
  width: 0.7em;
  height: 0.7em;
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  border-radius: 50%;
  z-index: 1;
}

#menu a {
  display: block;
  width: 100%;
  padding: 0.75em 1em;
  padding-left: 2em; /* add padding-left to make space for dot and icon */
  color: var(--text-color);
  background: none;
  border-radius: var(--radius);
  text-align: left;
  font-size: var(--font-size-base);
  transition: background var(--transition), color var(--transition);
  box-sizing: border-box;
  overflow: hidden;
}

#menu li:not(.logo) a:hover {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
}

#menu a > i {
  margin-right: 0.5em;
}
#menu .menu-footer {
  margin-top: auto;
  display: flex;
  flex-flow: row;
  margin-bottom: 2em;
  box-sizing: border-box;
  justify-content: space-between;
  align-items: center;
}
#menu .menu-footer *, #menu .menu-footer *:hover {
  font-size: var(--font-size-sm);
  color: var(--muted-color);
  background: none;
}
#menu .menu-footer a{
  width: fit-content;
  margin: 0;
  padding: 0;
  padding: 0 0.5em ;
}

#pwa-grant-permission{
  
  position: fixed;
  top: 1em;
  right: 1em;
  z-index: 300;
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  border: none;
  border-radius: 4px;
  font-size: 1em;
  padding: 0.5em 1em;
  cursor: pointer;
}
#pwa-grant-permission > *{
  color: var(--accent-color-contrast);
}

@media (max-width: 768px) {
  #menu {
    position: fixed;
    left: 0;
    top: 0;
    width: 80vw;
    max-width: 320px;
    height: 100vh;
    z-index: 200;
  }
  #menu-toggle {
    display: block;
    position: fixed;
    top: 1em;
    left: 0em;
    z-index: 300;
    background: var(--accent-color);
    border: none;
    border-radius: 4px;
    font-size: 2em;
    padding: 0.2em 0.5em;
    cursor: pointer;
  }
  #menu-toggle *{
    color: var(--accent-color-contrast);
  }
}
@media (min-width: 769px) {
  #menu-toggle {
    display: none;
  }
}

/* Content */
#content {
  margin-left: 220px;
  padding: 1em;
}

#content.jointops-temp-view {
  margin-left: 0;
}
@media (max-width: 768px) {
  #content {
    margin-left: 0;
    padding: 2em;
    margin-top: 4em;
  }
  #content.jointops-temp-view {
    margin-top: 0;
  }
}




/* Forms*/
form label{
  margin: 0.5em 0;
  font-weight: 500;
  color: var(--text-color);
  display: block;
}

form input[type="text"],
form select,
form textarea {
  background: var(--bg-color);
  color: var(--text-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  font-size: var(--font-size-base);
  padding: 0.5em 1em;
  margin-bottom: 1em;
  box-sizing: border-box;
  width: 100%;
  transition: background var(--transition), color var(--transition);
}

form textarea {
  min-height: 8em;
  resize: vertical;
}

form input[type="text"]:focus,
form select:focus ,
form textarea:focus {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  outline: none;
}

form .checkbox-group {
  display: flex;
  align-items: center;
  margin: 1em 0;
}

form .checkbox-group input[type="checkbox"] {
  margin-right: 0.5em;
  accent-color: var(--accent-color);
  vertical-align: middle;
  height: 1rem;
  width: 1rem;
}

form .checkbox-group label {
  display: inline-block;
  margin-bottom: 0;
  margin-top: 0;
  margin-right: 1em;
  vertical-align: middle;
}

form input[type="submit"] {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  border: none;
  border-radius: var(--radius);
  font-size: var(--font-size-lg);
  padding: 0.75em 1em;
  cursor: pointer;
  margin-top: 1em;
  width: 100%;
  transition: background var(--transition), color var(--transition);
  text-wrap: auto;
}

form input[type="submit"]:hover {
  background: color-mix(in srgb, var(--accent-color) 90%, white);
}

form .form-group {
  margin-bottom: 1em;
  border: 1px solid var(--border-color);
  padding: 1em;
  border-radius: var(--radius);
}
form .form-dynamic-slots:not(.sortable-slots){
  display: flex;
  flex-flow: column;
}

form .form-dynamic-slot{
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 1em;
  align-items: center;
  justify-content: center;
  border: 1px solid aliceblue;
  border-radius: 6px;
  margin: 0.5em 0;
  padding: 0.5em 1em;
}

form .form-dynamic-slot > div{
  height: 100%;
}

form .dynamic-add{
  display: flex;
  gap: 0.5em;
  align-items: flex-start;
  margin-bottom: 1em;
  margin-top: 0.5em;
}
form .dynamic-add input{
  width: 20%;
}
form .guide {
  margin-bottom: 0.5em;
}
form label i {
  margin-left: 0.5em;
}

/* Events */
.event-detail  {
  display: flex;
  flex-direction: row;
  background: var(--primary-color);
  border-radius: var(--radius);
  box-shadow: 0 2px 12px var(--box-shadow-color);
  border: 1px solid var(--border-color);
  padding: 2em;
  gap: 2em;
  margin: 2em 0;
}

.event-detail .event-info {
  width: 50%;
  max-width: 500px;
  display: flex;
  flex-direction: column;
  gap: 1em;
  background: none;
}

.event-detail h3 {
  margin: 0 0 0.5em 0;
  font-size: var(--font-size-lg);
  color: var(--accent-color);
  font-family: var(--font-family-title);
  letter-spacing: 1px;
}

.event-detail img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius);
  box-shadow: 0 2px 8px var(--box-shadow);
  margin: 1em 0;
  border: 1px solid var(--border-color);
  background: var(--bg-color);
  object-fit: contain;
}
.event-detail .chip img {
  margin: 0 0.2em;
  background: none;
  border: none;
  box-shadow: none;
}

.event-detail .chip:last-child {
  margin-right: 0;
}

.event-detail .event-date {
  color: var(--muted-color);
  font-size: var(--font-size-sm);
  background: none;
  padding: 0.1em 0.5em;
  border-radius: var(--radius);
  margin-right: 0.5em;
  margin-bottom: 0.2em;
  font-weight: 500;
}

.event-detail a {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}
.event-detail a i {
  padding: 0.3em 0.5em;
  width: fit-content;
  margin: 0;
}
.event-detail a:hover i {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
}

.event-detail .event-info > span.event-info {
  background: var(--bg-color);
  color: var(--text-color);
  border-radius: var(--radius);
  padding: 0.7em 1em;
  margin-top: 1em;
  font-size: var(--font-size-base);
  box-shadow: 0 1px 4px var(--box-shadow);
  border: 1px solid var(--border-color);
  white-space: pre-wrap;
  width: 100%;
  box-sizing: border-box;
}

.event-detail .event-info > span {
  margin-bottom: 0.3em;
}

.event-detail .event-orbat {
  width: 50%;
  height: fit-content;
  display: grid;
  grid-template-columns: auto 1fr 2fr 1fr;
  gap: 0.7em;
  background: var(--primary-color);
  border-radius: var(--radius);
  border: 1px solid var(--border-color);
  box-shadow: 0 2px 8px var(--box-shadow);
  padding: 1.2em 1em;
  margin: 0;
  align-items: center;
}

.event-detail .event-orbat img{
  margin: 0;
}

.event-detail .orbat-slot-title {
  font-family: var(--font-family-title);
  font-size: var(--font-size-base);
  color: var(--accent-color);
  font-weight: 600;
  margin: 0.7em 0 0.3em 0;
  text-align: left;
  letter-spacing: 1px;
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 0.2em;
}

.event-detail .orbat-slot-divider {
  border-bottom: 4px dotted var(--accent-color);
  margin: 0;
  padding: 0;
  line-height: 0;
  height: 0;
}
.event-detail .orbat-slot-title,
.event-detail .orbat-slot-divider,
.event-detail .fullwidth,
.event-detail .event-orbat > form.full{
  grid-column: 1/5;
}

.event-detail .event-chips{
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1em;
}

.event-detail .orbat-slot-name {
  font-size: var(--font-size-base);
  color: var(--text-color);
  font-weight: 500;
  margin-right: 0.5em;
  display: inline-block;
}

.event-detail .orbat-slot-kit {
  font-size: var(--font-size-sm);
  color: var(--muted-color);
  margin-right: 0.5em;
  display: inline-block;
}

.event-detail .orbat-slot-participate {
  font-size: var(--font-size-lg);
  color: var(--accent-color);
  margin-left: 0.5em;
  transition: color var(--transition);
  display: inline-block;
}
.event-detail span.orbat-slot-participate{
  color: var(--accent-color);
  font-size: var(--font-size-base);
}

.event-detail .orbat-slot-participate:hover {
  color: color-mix(in srgb, var(--accent-color) 90%, white);
}

.event-detail .tooltip {
  margin-left: 0.3em;
  color: var(--accent-color);
  cursor: help;
  font-size: var(--font-size-sm);
}

.event-detail .orbat-slot-participate.custom{
  width: 100%;
}
.event-detail .orbat-slot-participate.custom form {
  display: flex;
}
.event-detail .orbat-slot-participate.custom input, .event-detail .orbat-slot-participate.custom select{
  width: 100%;
  margin: 0;
}

.jointops-temp-view .tmp-controls{
  display: flex;
  flex-flow: row wrap;
  gap: 1em;
}
.jointops-temp-view .tmp-controls label{
  display: none;
}

@media (max-width: 769px) {
  .event-detail .orbat-slot-participate.custom a{
    margin: 0;
    padding: 0;
  }
  .event-detail span.orbat-slot-participate,
  .event-detail .orbat-slot-name,
  .event-detail .event-info > span.event-info{
    font-size: var(--font-size-sm);
  }
}

/* Event Detail in admin */
.event-user-list .event-item {
  display: grid;
  grid-template-columns: 2fr 1fr 2fr;
  align-items: center;
  background: var(--primary-color);
  border-radius: var(--radius);
  border: 1px solid var(--border-color);
  box-shadow: 0 2px 8px var(--box-shadow);
  padding: 1em;
  margin-bottom: 0.7em;
  gap: 0.5em;
  transition: box-shadow var(--transition), border-color var(--transition);
}

.event-user-list .event-item:last-child {
  margin-bottom: 0;
}

.event-user-list .event-name {
  margin: 0;
  font-size: var(--font-size-base);
  color: var(--accent-color);
  font-family: var(--font-family-title);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.event-user-list .event-name a {
  color: var(--accent-color);
  text-decoration: none;
  transition: color var(--transition);
}

.event-user-list .event-name a:hover {
  color: color-mix(in srgb, var(--accent-color) 90%, white);
}

.event-user-list .event-date,
.event-user-list .event-slot {
  font-size: var(--font-size-sm);
  padding: 0.25em 0.75em;
  text-align: center;
  font-weight: 500;
  white-space: nowrap;
  margin: 0;
}

.event-user-list .event-date,
.event-user-list .event-kit {
  color: var(--muted-color);
  background: none;
}


@media (max-width: 700px) {
  .event-user-list .event-item {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    gap: 0.3em;
    padding: 0.7em 0.5em;
  }
  .event-user-list .event-name,
  .event-user-list .event-date,
  .event-user-list .event-slot {
    font-size: var(--font-size-sm);
    padding: 0.2em 0.5em;
  }
}


@media (max-width: 900px) {
  .event-detail {
    flex-direction: column;
    padding: 1em;
    gap: 1em;
  }
  .event-detail .event-info,
  .event-detail .event-orbat {
    width: 100%;
    padding: 1em 0.5em;
  }
}

@media (max-width: 600px) {
  .event-detail {
    padding: 0.5em;
    gap: 0.5em;
  }
  .event-detail .event-info,
  .event-detail .event-orbat {
    padding: 0.5em 0.2em;
    font-size: var(--font-size-sm);
  }
  .event-detail img {
    margin: 0.5em 0;
  }
  .event-detail .chip,
  .event-detail a {
    font-size: var(--font-size-sm);
    padding: 0.2em 0.5em;
  }
}

/* Events Admin */

.events-list {
  margin: 2em auto;
  max-width: 900px;
  padding: 0.5em;
  display: flex;
  flex-direction: column;
  gap: 1em;
}

.events-list .event-item {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  align-items: center;
  background: var(--primary-color);
  border-radius: var(--radius);
  border: 1px solid var(--border-color);
  box-shadow: 0 2px 8px var(--box-shadow);
  padding: 1em;
  transition: box-shadow var(--transition), border-color var(--transition);
  gap: 0.5em;
}

.events-list .event-item.active {
  border-color: var(--accent-color);
  box-shadow: 0 2px 12px var(--box-shadow-color);
}

.events-list .event-item > h3{
  margin : 0;
}


.events-list .event-item.inactive {
  opacity: 0.6;
}

.events-list .event-item:hover {
  box-shadow: 0 4px 16px var(--box-shadow-color);
  border-color: var(--accent-color);
}

.events-list .event-item a {
  color: var(--accent-color);
  font-weight: bold;
  font-size: 1.1em;
  text-decoration: none;
  transition: color var(--transition);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


.events-list .event-date {
  color: var(--muted-color);
  font-size: var(--font-size-sm);
  text-align: left;
  white-space: nowrap;
}

.events-list .event-type, .events-list .event-participation {
  color: var(--text-color);
  font-size: var(--font-size-sm);
  background: var(--ui-bg-hover, #4f8cff);
  border-radius: var(--radius);
  padding: 0.25em 0.75em;
  text-align: center;
  font-weight: 500;
  white-space: nowrap;
}
.events-list .event-type.event-type-0{
  background: var(--event-0-color);
  color: var(--accent-color-contrast);
}
.events-list .event-type.event-type-1{
  background: var(--event-1-color);
  color: var(--accent-color-contrast);
}
.events-list .event-type.event-type-2{
  background: var(--event-2-color);
  color: var(--accent-color-contrast);
}
.events-list .event-type.event-type-3{
  background: var(--event-3-color);
  color: var(--accent-color-contrast);
}

.events-list .event-participation.no{
  background: var(--error-color);
  color: var(--accent-color-contrast);
}

.events-list .buttons {
  display: flex;
  gap: 0.5em;
  justify-content: flex-end;
  align-items: center;
}



.events-list .buttons a, .events-list .buttons button {
  background: none;
  border: none;
  color: var(--text-color);
  font-size: 1.1em;
  padding: 0.3em 0.5em;
  border-radius: var(--radius);
  transition: background var(--transition), color var(--transition);
  display: flex;
  align-items: center;
  cursor: pointer;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.events-list .buttons a:hover, .events-list .buttons button:hover {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
}
.events-list .buttons button:hover > i {
  color: var(--accent-color-contrast);
}

.user-event-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1em;
  background: var(--primary-color);
  padding: 2em;
  border-radius: var(--radius);
}
#groups-container{
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
#groups-container .group-selector{
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5em;
}
#groups-container .group-selector input, #groups-container .group-selector select{
  margin: 0;
}
button#add-group{
  margin: 1em 0;
}

.jo-group-list{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1em;
}
.jo-group-list .highlight{
  color: var(--accent-color);
}

@media (max-width: 768px) {
  .events-list .event-item {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 0.5em;
  }
  .events-list .event-item a,
  .events-list .event-date,
  .events-list .event-type,
  .events-list .buttons {
    font-size: var(--font-size-sm);
  }
  .events-list .event-type {
    padding: 0.2em 0.5em;
  }
  
  .events-list .buttons{
    justify-content: space-between;
  }
  .events-list .buttons > a{
    flex: 1;
    justify-content: center;
  }

  .jo-group-list{
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5em;
  }
  .jo-group-list .jo-group-url-edit{
    padding-bottom: 1.5em;
  }
  .jo-group-list > *{
    text-align: center;
  }
}

/* Alerts */
.alert-box {
  position: fixed;
  bottom: 2em;
  right: 2em;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.75em;
  pointer-events: none;
}

.alert {
  min-width: 260px;
  max-width: 350px;
  background: var(--primary-color);
  color: var(--text-color);
  border-radius: var(--radius);
  border: 1px solid var(--border-color);
  box-shadow: 0 2px 12px var(--box-shadow);
  padding: 1em 1.5em;
  font-size: var(--font-size-base);
  margin-bottom: 0;
  opacity: 1;
  transition: opacity 0.8s var(--transition), transform 0.4s var(--transition);
  pointer-events: auto;
  position: relative;
}

.alert.fade-out {
  opacity: 0;
  transform: translateY(20px) scale(0.95);
  transition: opacity 0.8s var(--transition), transform 0.4s var(--transition);
}

.alert.info {
  border-left: 5px solid var(--accent-color);
}
.alert.success {
  border-left: 5px solid #4caf50;
}
.alert.warning {
  border-left: 5px solid #ff9800;
}
.alert.error {
  border-left: 5px solid var(--error-color);
}

@media (max-width: 600px) {
  .alert-box {
    right: 0.5em;
    bottom: 0.5em;
    left: 0.5em;
    align-items: center;
  }
  .alert {
    min-width: 180px;
    max-width: 95vw;
    padding: 0.7em 1em;
    font-size: var(--font-size-sm);
  }
}

/* Dashboard */

.dashboard {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 1.5em;
  margin: 2em 0;
  padding: 0.5em;
}
.dashboard-group{
  display: flex;
  flex-direction: row;
  gap: 1.5em;
  flex-wrap: wrap;
  width: 100%;
  margin-bottom: 2em;
}

.dashboard-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  box-sizing: border-box;
  background: var(--primary-color);
  border-radius: var(--radius);
  box-shadow: 0 2px 8px var(--box-shadow);
  border: 1px solid var(--border-color);
  padding: 1.5em 1em;
  min-width: 220px;
  max-width: 320px;
  flex: 0 0 auto;
  transition: box-shadow var(--transition), border-color var(--transition);
  margin: 0;
}

.dashboard-item h3 {
  margin: 0 0 0.5em 0;
  font-size: var(--font-size-lg);
  color: var(--accent-color);
  font-family: var(--font-family-title);
  letter-spacing: 1px;
}

.dashboard-item p {
  margin: 0 0 0.5em 0;
  font-size: var(--font-size-base);
  color: var(--text-color);
  font-weight: 500;
}

.dashboard-item a {
  display: block;
  color: var(--accent-color);
  background: none;
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  margin: 0.2em 0;
  padding: 0.2em 0.5em;
  text-decoration: none;
  transition: background var(--transition), color var(--transition);
  font-weight: 500;
}

.dashboard-item a:hover {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
}

.dashboard-item.warning, .dashboard-item h3:contains("Warning") {
  border-left: 5px solid var(--error-color);
}
.dashboard-item canvas{
  width: 300px;
  max-height: 150px;
  height: auto;
  margin-top: auto;
}


.user-graphs{
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  width: 100%;
}
.user-graphs canvas{
  max-width: 300px;
  max-height: 300px;
  height: auto;
}

@media (max-width: 900px) {
  .dashboard {
    gap: 1em;
  }
  .dashboard-item {
    min-width: 160px;
    max-width: 220px;
    padding: 1em 0.7em;
  }
}

@media (max-width: 700px) {
  .dashboard {
    flex-direction: column;
    gap: 0.7em;
    padding: 0.2em;
  }
  .dashboard-item {
    min-width: 0;
    max-width: 100%;
    width: 100%;
    padding: 0.7em 0.5em;
  }
}


/* Settings */

#settingsMenu {
  margin: 2em 0 1em 0;
  width: 100%;
}

#settingsMenu ul {
  display: flex;
  flex-direction: row;
  gap: 0.5em;
  padding: 0;
  margin: 0;
  list-style: none;
  justify-content: flex-start;
  align-items: center;
}

#settingsMenu li {
  margin: 0;
  padding: 0;
}

#settingsMenu a {
  display: block;
  padding: 0.5em 1.2em;
  background: var(--primary-color);
  color: var(--text-color);
  border-radius: var(--radius);
  font-size: var(--font-size-base);
  text-decoration: none;
  transition: background var(--transition), color var(--transition);
  border: 1px solid var(--border-color);
  margin: 0;
  font-weight: 500;
}

#settingsMenu a.active,
#settingsMenu a:hover {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  border-color: var(--accent-color);
}

.settings-form{
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
}

.settings-form > *{
  grid-column: 1 / -1; /* spans from first to last column */
}

.settings-form label {
  justify-self: start;
}

.settings-form input[type="checkbox"] {
  justify-self: start;
}

/* Optional: style .checkbox-group to remove extra wrapping */
.settings-form .checkbox-group {
  display: contents;
}
.settings-form .checkbox-group > label {
  max-width: 500px;
  padding: 0.5em 0;
}

@media (max-width: 768px) {
  #settingsMenu ul {
    flex-direction: column;
    gap: 0.3em;
    align-items: flex-start;
  }
  #settingsMenu ul li {
    min-width: 100%;
  }
  #settingsMenu a {
    font-size: var(--font-size-sm);
    padding: 0.5em 0.8em;
  }

  .settings-form .checkbox-group > label {
  max-width: none;
  }
}

/* Ranks */
.ranks-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.2em;
  margin: 2em 0;
  padding: 0;
}

.rank-item {
  position: relative;
  background: var(--primary-color);
  border-radius: var(--radius);
  box-shadow: 0 2px 8px var(--box-shadow);
  border: 1px solid var(--border-color);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.2em 1em;
  transition: box-shadow var(--transition), border-color var(--transition);
  cursor: grab;
}

.rank-item:hover {
  box-shadow: 0 4px 16px var(--box-shadow-color);
  border-color: var(--accent-color);
}

.rank-item img {
  width: 64px;
  height: 64px;
  object-fit: contain;
  border-radius: var(--radius);
  margin-bottom: 0.8em;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
}

.rank-item h3 {
  margin: 0.2em 0 0.1em 0;
  font-size: var(--font-size-lg);
  color: var(--accent-color);
  font-family: var(--font-family-title);
  text-align: center;
}

.rank-item span {
  font-size: var(--font-size-sm);
  color: var(--muted-color);
  margin-top: 0.2em;
  text-align: center;
  font-weight: 500;
}
.rank-item .close {
  position: absolute;
  top: 0;
  right: 0;
  margin: 0.5em;
  color: var(--error-color);
  cursor: pointer;
}


@media (max-width: 700px) {
  .ranks-list {
    grid-template-columns: 1fr 1fr;
    gap: 0.7em;
  }
  .rank-item {
    padding: 0.7em 0.5em;
  }
  .rank-item img {
    width: 48px;
    height: 48px;
  }
}

@media (max-width: 500px) {
  .ranks-list {
    grid-template-columns: 1fr;
    gap: 0.5em;
  }
}


/* Orbat Admin */

.orbat-items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 1em;
  margin: 1.5em 0;
  padding: 0;
}

.orbat-items a {
  display: block;
  background: var(--primary-color);
  color: var(--text-color);
  border-radius: var(--radius);
  border: 1px solid var(--border-color);
  padding: 0.7em 1.2em;
  text-align: center;
  font-size: var(--font-size-base);
  font-weight: 500;
  text-decoration: none;
  transition: background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);
  box-shadow: 0 2px 8px var(--box-shadow);
  cursor: pointer;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  height: 100%;
  box-sizing: border-box;
}

.orbat-items a:hover,
.orbat-items a:focus {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  border-color: var(--accent-color);
  box-shadow: 0 4px 16px var(--box-shadow-color);
}
.orbat-items .orbat-item{
  display: flex;
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
}
.orbat-items .orbat-item > a:first-child{
  flex:1;
  border-radius: var(--radius) 0 0 var(--radius);
}
.orbat-items .orbat-item > a:last-child{
  flex: 0 0 auto;
  border-radius: 0 var(--radius) var(--radius) 0;
}
.orbat-items .orbat-item > a:only-child{
  flex: 1;
  border-radius: var(--radius);
}


@media (max-width: 600px) {
  .orbat-items {
    grid-template-columns: 1fr 1fr;
    gap: 0.4em;
  }
  .orbat-items a {
    font-size: var(--font-size-sm);
    padding: 0.5em 0.7em;
  }
}

/* Users */

.user-table {
  display: grid;
  grid-auto-rows: minmax(48px, auto);
  background: var(--primary-color);
  border-radius: var(--radius);
  box-shadow: 0 2px 8px var(--box-shadow);
  border: 1px solid var(--border-color);
  margin: 2em 0;
}

.user-header {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  font-family: var(--font-family-title);
  font-size: var(--font-size-base);
  font-weight: 600;
  padding: 1em 0.5em;
  text-align: center;
  border-bottom: 1px solid var(--border-color);
}

.user-table .user-name,
.user-table .user-events,
.user-table .user-course,
.user-table .buttons {
  min-width: 50px;
  background: var(--primary-color);
  color: var(--text-color);
  font-size: var(--font-size-base);
  padding: 0.8em 0.5em;
  border-bottom: 1px solid var(--border-color);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.user-table .buttons {
  min-width: fit-content;
}

.user-table .user-name {
  font-weight: 500;
  justify-content: flex-start;
  text-align: left;
}
.user-table .user-name > i{
  margin: 0 0.5em;
}

.user-table .user-course select {
  background: var(--bg-color);
  color: var(--text-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  padding: 0.3em 0.7em;
  width: 100%;
  transition: background var(--transition), color var(--transition);
}

.user-table .user-course select:focus {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
  outline: none;
}

.user-table .buttons {
  gap: 0.5em;
  justify-content: flex-end;
}

.user-table .buttons a {
  background: none;
  border: none;
  color: var(--accent-color);
  font-size: 1.1em;
  padding: 0.3em 0.5em;
  border-radius: var(--radius);
  transition: background var(--transition), color var(--transition);
  display: flex;
  align-items: center;
}

.user-table .buttons a:hover {
  background: var(--accent-color);
  color: var(--accent-color-contrast);
}

.user-waiting-item{
  display: flex;
  flex-flow: row;
  justify-content: space-between;
}

@media (max-width: 900px) {
  .user-table {
    font-size: var(--font-size-sm);
  }
  .user-header,
  .user-table .user-name,
  .user-table .user-course,
  .user-table .buttons {
    padding: 0.5em 0.2em;
  }
}

@media (max-width: 600px) {
  .user-table {
    grid-auto-rows: minmax(36px, auto);
    font-size: var(--font-size-sm);
  }
  .user-header,
  .user-table .user-name,
  .user-table .user-course,
  .user-table .buttons {
    padding: 0.3em 0.1em;
  }
}

/* Profile */

.profile-courses, .profile-events {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1em;
  margin: 2em 0;
  padding: 0.5em;
  background: var(--primary-color);
  border-radius: var(--radius);
  box-shadow: 0 2px 8px var(--box-shadow);
  border: 1px solid var(--border-color);
  align-items: center;
}

.profile-courses .name, .profile-events .name , .profile-events .name a {
  font-weight: 600;
  color: var(--accent-color);
  font-family: var(--font-family-title);
  font-size: var(--font-size-base);
  padding: 0.5em 0.2em;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.profile-courses .given_at, .profile-events .date {
  font-size: var(--font-size-sm);
  color: var(--muted-color);
  padding: 0.5em 0.2em;
  text-align: left;
  white-space: nowrap;
}

.profile-courses .given_by_name, .profile-events .type {
  font-size: var(--font-size-sm);
  color: var(--text-color);
  padding: 0.5em 0.2em;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}


.profile-courses .status, .profile-events .slot {
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--text-color);
  padding: 0.5em 0.2em;
  text-align: left;
  white-space: nowrap;
}
.profile-courses .status-0 {
  color: var(--muted-color);
}
.profile-courses .status-2 {
  color: var(--success-color);
}

@media (max-width: 768px) {
  .profile-courses, .profile-events {
    grid-template-columns: 3fr 1fr;
    font-size: var(--font-size-sm);
    padding: 0.2em;
    gap: 0.3em;
  }
  .profile-courses .name,
  .profile-courses .given_at,
  .profile-courses .given_by_name,
  .profile-courses .status {
    padding: 0.2em 0.1em;
  }
  .profile-courses .given_by_name,
  .profile-courses .given_at {
    display: none;
  }
  
  .profile-events .chip,
  .profile-events .type, 
  .profile-events .slot {
    display: none;
  }

}

/* Changelog */
#changelog {
  margin: 2em 0;
  padding: 1em 0.5em !important;
}
#changelog p {
  margin: 0;
}
#changelog ul {
  margin: 0;
}
