@charset "UTF-8";
:root {
  --transition: all 0.3s ease-in-out;
  --padding-on-side: 40px;
  --margins: 1em;
  --gap: 40px;
  --gap-smaller: 20px;
  --shadow: 0 0.5em 1em rgba(0, 0, 0, 0.075);
  --text-shadow: 0 0.15em 0.15em rgba(0, 0, 0, 0.25);
  --shadow-darker: 0.07em 0.25em 0.4em rgba(0, 0, 0, 0.4);
  --border-radius-smaller: 4px;
  --border-radius: 8px;
  --border-radius-bigger: 12px;
  --content-small: 960px;
  --content-regular: 1400px;
  --content-big: 1720px;
  --font-weight-thin: 100;
  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-black: 900;
  --line-height: 1.5;
  --letter-spacing: normal;
  --font-size-10: 10px;
  --font-size-11: 11px;
  --font-size-12: 12px;
  --font-size-13: 13px;
  --font-size-14: 14px;
  --font-size-15: 15px;
  --font-size-16: 16px;
  --font-size-18: 18px;
  --font-size-20: 20px;
  --font-size-24: 24px;
  --font-size-28: 28px;
  --font-size-30: 30px;
  --font-size-36: 42px;
  --font-size-48: 48px;
  --font-size-60: 60px;
  --font-size-72: 72px;
  --font-size-90: 90px;
  --font-size-120: 120px;
  --font-basic: "Poppins", sans-serif;
  --font-heading: "Poppins", sans-serif;
  --palette-white: #ffffff;
  --palette-gray-50: #fafafa;
  --palette-gray-100: #f4f4f5;
  --palette-gray-200: #e4e4e7;
  --palette-gray-300: #d4d4d8;
  --palette-gray-400: #a1a1aa;
  --palette-gray-500: #71717a;
  --palette-gray-600: #52525b;
  --palette-gray-700: #3f3f46;
  --palette-gray-800: #27272a;
  --palette-gray-900: #18181b;
  --palette-gray-950: #09090b;
  --palette-black: #000000;
  --palette-red-400: #f87171;
  --palette-red-500: #dc1a1a;
  --palette-red-600: #aa2222;
  --palette-red-700: #991b1b;
  --palette-green-50: #f0fdf4;
  --palette-green-100: #dcfce7;
  --palette-green-500: #22c55e;
  --palette-green-600: #16a34a;
  --palette-green-700: #15803d;
  --palette-green-800: #166534;
  --palette-yellow-50: #fffbeb;
  --palette-yellow-100: #fef3c7;
  --palette-yellow-500: #eab308;
  --palette-yellow-600: #ca8a04;
  --palette-yellow-700: #a16207;
  --palette-red-50: #fef2f2;
  --palette-red-100: #fee2e2;
  --palette-red-500: #ef4444;
  --palette-red-600: #dc2626;
  --palette-red-700: #b91c1c;
  --palette-blue-50: #effbff;
  --palette-blue-100: #dbf3fe;
  --palette-blue-500: #3bbbf6;
  --palette-blue-600: #258feb;
  --palette-blue-700: #1d74d8;
  --color-page-background: var(--palette-gray-100);
  --color-surface: var(--palette-white);
  --color-surface-hover: var(--palette-gray-50);
  --color-surface-active: var(--palette-gray-100);
  --color-surface-secondary: var(--palette-gray-100);
  --color-border-subtle: var(--palette-gray-200);
  --color-border-default: var(--palette-gray-300);
  --color-border-strong: var(--palette-gray-400);
  --color-text-primary: var(--palette-gray-900);
  --color-text-secondary: var(--palette-gray-700);
  --color-text-tertiary: var(--palette-gray-500);
  --color-text-disabled: var(--palette-gray-400);
  --color-text-inverse: var(--palette-white);
  --color-primary: var(--palette-red-500);
  --color-primary-hover: var(--palette-red-600);
  --color-primary-active: var(--palette-red-700);
  --color-primary-rgb: 220, 26, 26;
  --color-primary-hover-rgb: 170, 34, 34;
  --color-secondary: var(--palette-gray-400);
  --color-success: var(--palette-green-600);
  --color-success-hover: var(--palette-green-700);
  --color-success-bg: var(--palette-green-50);
  --color-success-bg-hover: var(--palette-green-100);
  --color-success-border: var(--palette-green-600);
  --color-success-text: var(--palette-green-800);
  --color-success-rgb: 22, 163, 74;
  --color-warning: var(--palette-yellow-600);
  --color-warning-hover: var(--palette-yellow-700);
  --color-warning-bg: var(--palette-yellow-50);
  --color-warning-bg-hover: var(--palette-yellow-100);
  --color-warning-border: var(--palette-yellow-600);
  --color-warning-text: var(--palette-yellow-700);
  --color-warning-rgb: 202, 138, 4;
  --color-error: var(--palette-red-600);
  --color-error-hover: var(--palette-red-700);
  --color-error-bg: var(--palette-red-50);
  --color-error-bg-hover: var(--palette-red-100);
  --color-error-border: var(--palette-red-600);
  --color-error-text: var(--palette-red-700);
  --color-error-rgb: 220, 38, 38;
  --color-info: var(--palette-blue-600);
  --color-info-hover: var(--palette-blue-700);
  --color-info-bg: var(--palette-blue-50);
  --color-info-bg-hover: var(--palette-blue-100);
  --color-info-border: var(--palette-blue-600);
  --color-info-text: var(--palette-blue-700);
  --color-info-rgb: 37, 99, 235;
  --color-hover: var(--palette-gray-50);
  --color-focus: var(--color-primary);
  --button-shadow: 0 0.4em 0.7em rgba(var(--color-primary-rgb), 0.2);
  --button-shadow-hover: 0 0.2em 0.4em rgba(var(--color-primary-hover-rgb), 0.4);
  --input-bg: var(--color-surface);
  --input-bg-focus: var(--color-surface);
  --input-bg-disabled: var(--color-surface-secondary);
  --input-border: var(--color-border-default);
  --input-border-focus: var(--color-primary);
  --input-border-error: var(--color-error);
  --input-text: var(--color-text-primary);
  --input-placeholder: var(--color-text-tertiary);
  --button-bg: var(--color-surface-hover);
  --button-bg-hover: var(--color-surface-active);
  --button-border: var(--color-border-default);
  --button-text: var(--color-text-primary);
  --table-bg: var(--color-surface);
  --table-bg-hover: var(--color-surface-hover);
  --table-bg-stripe: var(--color-surface-secondary);
  --table-border: var(--color-border-subtle);
  --table-text: var(--color-text-primary);
  --table-text-muted: var(--color-text-secondary);
  --table-header-bg: var(--color-surface-secondary);
  --card-bg: var(--color-surface);
  --card-bg-hover: var(--color-surface-hover);
  --card-border: var(--color-border-subtle);
  --modal-bg: var(--color-surface);
  --modal-overlay: rgba(0, 0, 0, 0.5);
  --modal-border: var(--color-border-subtle);
  --sidebar-bg: var(--color-surface-secondary);
  --sidebar-border: var(--color-border-subtle);
  accent-color: var(--color-primary);
}

:root.dark {
  color-scheme: dark;
  --color-page-background: var(--palette-gray-950);
  --color-surface: var(--palette-gray-900);
  --color-surface-hover: var(--palette-gray-800);
  --color-surface-active: var(--palette-gray-700);
  --color-surface-secondary: var(--palette-gray-800);
  --color-border-subtle: var(--palette-gray-800);
  --color-border-default: var(--palette-gray-700);
  --color-border-strong: var(--palette-gray-600);
  --color-text-primary: var(--palette-gray-50);
  --color-text-secondary: var(--palette-gray-300);
  --color-text-tertiary: var(--palette-gray-500);
  --color-text-disabled: var(--palette-gray-600);
  --color-text-inverse: var(--palette-gray-900);
  --color-primary: #f12f2f;
  --color-primary-hover: #f2454e;
  --color-primary-active: #db2121;
  --color-primary-rgb: 239, 68, 68;
  --color-primary-hover-rgb: 248, 113, 113;
  --color-success: var(--palette-green-500);
  --color-success-hover: var(--palette-green-600);
  --color-success-bg: rgba(34, 197, 94, 0.1);
  --color-success-bg-hover: rgba(34, 197, 94, 0.2);
  --color-success-border: var(--palette-green-600);
  --color-success-text: var(--palette-green-500);
  --color-success-rgb: 34, 197, 94;
  --color-warning: var(--palette-yellow-500);
  --color-warning-hover: var(--palette-yellow-600);
  --color-warning-bg: rgba(234, 179, 8, 0.1);
  --color-warning-bg-hover: rgba(234, 179, 8, 0.2);
  --color-warning-border: var(--palette-yellow-600);
  --color-warning-text: var(--palette-yellow-500);
  --color-warning-rgb: 234, 179, 8;
  --color-error: var(--palette-red-500);
  --color-error-hover: var(--palette-red-600);
  --color-error-bg: rgba(239, 68, 68, 0.1);
  --color-error-bg-hover: rgba(239, 68, 68, 0.2);
  --color-error-border: var(--palette-red-600);
  --color-error-text: var(--palette-red-500);
  --color-error-rgb: 239, 68, 68;
  --color-info: var(--palette-blue-500);
  --color-info-hover: var(--palette-blue-600);
  --color-info-bg: rgba(59, 130, 246, 0.1);
  --color-info-bg-hover: rgba(59, 130, 246, 0.2);
  --color-info-border: var(--palette-blue-600);
  --color-info-text: var(--palette-blue-500);
  --color-info-rgb: 59, 130, 246;
  --color-hover: var(--palette-gray-800);
  --shadow: 0 0.5em 1em rgba(0, 0, 0, 0.15);
  --button-shadow: 0 0.4em 0.7em rgba(0, 0, 0, 0.15);
  --button-shadow-hover: 0 0.2em 0.4em rgba(0, 0, 0, 0.2);
}

@media screen and (max-width: 1720px) {
  :root {
    --padding-on-side: 30px;
    --gap: 30px;
    --font-size-12: 12px;
    --font-size-14: 13px;
    --font-size-16: 15px;
    --font-size-18: 16px;
    --font-size-20: 18px;
    --font-size-24: 20px;
    --font-size-28: 22px;
    --font-size-30: 24px;
    --font-size-36: 28px;
    --font-size-48: 32px;
    --font-size-60: 40px;
    --font-size-90: 60px;
    --font-size-120: 80px;
  }
}
@media screen and (max-width: 1200px) {
  :root {
    --padding-on-side: 24px;
    --gap: 24px;
    --line-height: 1.45;
    --font-size-10: 9px;
    --font-size-11: 10px;
    --font-size-12: 11px;
    --font-size-14: 12px;
    --font-size-16: 14px;
    --font-size-18: 15px;
    --font-size-20: 17px;
    --font-size-24: 19px;
    --font-size-28: 20px;
    --font-size-30: 22px;
    --font-size-36: 24px;
    --font-size-48: 28px;
    --font-size-60: 32px;
    --font-size-90: 40px;
    --font-size-120: 50px;
  }
}
@media screen and (max-width: 660px) {
  :root {
    --padding-on-side: 16px;
    --gap: 16px;
    --line-height: 1.4;
    --font-size-12: 11px;
    --font-size-14: 12px;
    --font-size-16: 14px;
    --font-size-18: 15px;
    --font-size-20: 16px;
    --font-size-24: 18px;
    --font-size-28: 19px;
    --font-size-30: 20px;
    --font-size-36: 22px;
    --font-size-48: 24px;
    --font-size-60: 28px;
    --font-size-90: 40px;
    --font-size-120: 44px;
  }
}
:root {
  /* ----- Stavy ----- */
  --icon-error: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='m38.06 10.25 21.07 36.49c2.69 4.67-.67 10.5-6.06 10.5H10.93c-5.39 0-8.76-5.83-6.06-10.5l21.07-36.49c2.69-4.67 9.43-4.67 12.12 0ZM32 22v15.67m0 8.77V47' /%3E%3C/svg%3E");
  --icon-success: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M44.31 21.67c-11.96 8.57-18.29 20.67-18.29 20.67s-3.43-3.96-6.33-6.14M4 32c0 15.46 12.54 28 28 28s28-12.54 28-28S47.46 4 32 4 4 16.54 4 32Z' /%3E%3C/svg%3E");
  /*---- Basic ----*/
  --icon-warning: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='22'%3E%3Cpath fill-rule='evenodd' fill='%23000' d='M2 15a2 2 0 01-2-2V1.999a2 2 0 014 0V13a2 2 0 01-2 2zm0 3a2 2 0 110 4 2 2 0 010-4z'/%3E%3C/svg%3E");
  --icon-ok: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14.6 12.8'%3E%3Cpath fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' d='M12.9 1.6l-7.2 9.7-4.1-4.9'/%3E%3C/svg%3E");
  --icon-loading: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23000'%3E%3Cpath d='M463.702 162.655L442.491 14.164c-1.744-12.174-16.707-17.233-25.459-8.481l-30.894 30.894C346.411 12.612 301.309 0 254.932 0 115.464 0 3.491 109.16.005 248.511c-.19 7.617 5.347 14.15 12.876 15.234l59.941 8.569c8.936 1.304 17.249-5.712 17.125-15.058C88.704 165.286 162.986 90 254.932 90c22.265 0 44.267 4.526 64.6 13.183l-29.78 29.78c-8.697 8.697-3.761 23.706 8.481 25.459l148.491 21.211c9.784 1.475 18.381-7.034 16.978-16.978zM499.117 249.412l-59.897-8.555c-7.738-.98-17.124 5.651-17.124 16.143 0 90.981-74.019 165-165 165a165.207 165.207 0 01-64.306-13.052l28.828-28.828c8.697-8.697 3.761-23.706-8.481-25.459L64.646 333.435c-9.753-1.393-18.39 6.971-16.978 16.978l21.21 148.492c1.746 12.187 16.696 17.212 25.459 8.481l31.641-31.626C165.514 499.505 210.587 512 257.096 512c138.794 0 250.752-108.618 254.897-247.28.22-7.632-5.317-14.224-12.876-15.308z'/%3E%3C/svg%3E");
  --icon-quote: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 371 279'%3E%3Cpath fill='%23002649' fill-rule='evenodd' stroke-width='0' d='M220.1 25.9c-29.4 23.9-29 82.5-1.4 106.6 26.5 26.5 83.4 26.5 108.1-3.3 13.1 49.7-25.4 104.1-71.4 123.2l8.5 17.1c78.5-34.1 112.7-116 93.5-195.2-7-26.6-18.7-47.2-41.8-59.7C287.8.5 243 3.5 220.2 26Zm-193.6 0c-29.4 23.9-29.1 82.5-1.4 106.6 26.5 26.4 83.4 26.5 108.1-3.3 13.1 49.7-25.4 104.1-71.4 123.2l8.5 17.1c78.5-34.1 112.7-116 93.5-195.2-7-26.6-18.7-47.2-41.8-59.7C94.1.4 49.3 3.4 26.5 25.9Z' /%3E%3C/svg%3E");
  --icon-close: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23009bab' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m1.7 1.7 20.5 20.5m.1-20.5L1.8 22.2' /%3E%3C/svg%3E");
  --icon-checked: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14.6 12.8'%3E%3Cpath fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' stroke-miterlimit='10' d='M12.9 1.6l-7.2 9.7-4.1-4.9'/%3E%3C/svg%3E");
  --icon-delete: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23009bab' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2.7 4.9h18.6M4 4.9l2 16c0 .7.7 1.2 1.4 1.2h9.2c.7 0 1.3-.5 1.4-1.2l2-16m-9.9 13-.5-9m4.8-.1-.5 9m1.2-12.9V1.8H8.9v3.1' /%3E%3C/svg%3E");
  --icon-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23009bab' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M14.6 4.3c2.9 2.9 3 7.6.2 10.5-2.8 2.8-7.5 2.8-10.5-.2S1.3 7 4.1 4.1c2.8-2.8 7.5-2.8 10.5.2ZM17 17l5 5' /%3E%3C/svg%3E");
  --icon-theme-dark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18'%3E%3Cpath fill='%23000' fill-rule='evenodd' d='M12.781 13.15c-3.821 0-6.919-3.233-6.919-6.2 0-3.253 1.948-5.365 3.072-6.607A6.939 6.939 0 0 0 8.73.34C3.926.34.31 4.236.31 9.41c0 4.436 3.616 8.331 8.42 8.331 3.942 0 7.27-2.621 8.97-6.216-1.81.933-3.299 1.625-4.919 1.625Z' /%3E%3C/svg%3E");
  --icon-theme-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='21' height='21'%3E%3Cpath fill='%23000' fill-rule='evenodd' d='M10.366 5.52c-3.078 0-5.582 2.036-5.582 5.113a5.588 5.588 0 0 0 5.582 5.582 5.588 5.588 0 0 0 5.581-5.582c0-3.077-2.504-5.113-5.581-5.113Zm0-2.063c.44 0 .797-.356.797-.798V1.65c0-1.026-.357-1.383-.797-1.383-.442 0-.798.357-.798 1.383v1.009c0 .442.356.798.798.798Zm0 14.353a.797.797 0 0 0-.798.797v1.595a.797.797 0 1 0 1.595 0v-1.595a.797.797 0 0 0-.797-.797Zm6.2-12.252 1.128-1.127c.806-.312.806-.816 0-1.128a.799.799 0 0 0-1.128 0l-1.128 1.128a.797.797 0 0 0 1.128 1.127ZM4.163 15.709l-.813 1.128c-.626.311-.626.816 0 1.128-.003.311.501.311.813 0l1.127-1.128c.312-.313.312-.627 0-1.128a.795.795 0 0 0-1.127 0Zm-.974-5.076a.797.797 0 0 0-.797-.797H.797a.796.796 0 0 0-.797.797c0 1.107.355.798.797.798h1.595c.44 0 .797.309.797-.798Zm16.745-.797h-1.595a.797.797 0 0 0-.797.797c0 1.107.356.798.797.798h1.595c.44 0 .798.309.798-.798a.798.798 0 0 0-.798-.797ZM4.162 5.558a.795.795 0 0 0 1.127 0 .795.795 0 0 0 0-1.127L4.162 3.303c-.312-.311-.816-.311-.822 0-.617.312-.617.816 0 1.128l.822 1.127Zm12.406 10.149a.797.797 0 0 0-1.127 0c-.312.483-.314.816 0 1.128l1.127 1.127a.797.797 0 0 0 1.128 0c1.004-.311 1.004-.816 0-1.127l-1.128-1.128Z' /%3E%3C/svg%3E");
  /*---- /Basic ----*/
  --icon-category: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 128 128'%3E%3Cpath fill='%23d4d9e6' stroke-width='0' d='M26.1 15.9c-10.7 1.4-11.8 18.4-.3 20.9 16 3.5 17.9-23.3.3-20.9M7.1 2.4h43.8c3 .4 6 1.6 8.4 3.5l65.6 65.8c1.1 1.9 1 4.8-.3 6.6l-46.7 46.6c-1.9 1.1-5 1-6.8-.4L5.9 59.3C4 56.9 2.8 54 2.3 50.9V7.5C2.7 4.8 4.5 3 7.1 2.4' /%3E%3C/svg%3E");
  --icon-date: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 128 128'%3E%3Cpath fill='%23d4d9e6' stroke-width='0' d='M125.9 36.3v.8c-.9 22.4-8.1 47.6-24.1 62.4-32.4.4-65.1.4-97.5 0-1.9-.7-2.7-2.9-2.1-5 .4-1.7 3.3-4 4.4-5.5 11.2-14 16.8-34.3 17.2-52.7h102.1Zm0 39.2C124 79.7 122.3 84 120 88c-3.1 5.6-12.1 19.7-18.5 19.7H24.1v12.8c0 1 1.6 2.8 2.6 2.9h96.7c1.3-.5 1.9-1.6 2.5-2.8V75.4Zm0-60.1c-.6-1.5-1.4-2.6-3-2.9h-18.7V7.6s-.4-1.1-.5-1.3c-1.3-2.3-4.5-2.4-6-.3-.1.2-.7 1.2-.7 1.3v5.1H78.6V7.5s-.4-1.1-.5-1.3c-1.2-2.3-4.5-2.4-6-.3-.1.2-.7 1.2-.7 1.3v5.1H53.3V7.4s-.4-1.1-.5-1.3c-1.2-2.3-4.5-2.4-6-.3-.1.2-.7 1.2-.7 1.3v5.1h-19c-.9 0-2.8 2-2.8 2.8v13.1h101.8v-13Z' /%3E%3C/svg%3E");
  --icon-avatar: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 128 128'%3E%3Cpath fill='%23d4d9e6' stroke-width='0' d='M41.3 68.2c14.7.6 30.4-1.1 45 0 11.4.8 22.1 8.7 26.7 19.3 4.6 10.6 2.1 22.6 2.8 33.9 0 2-1.6 3.8-3.6 4H15c-1.3-.7-2.6-1.9-2.7-3.4.7-11.4-1.9-23.6 2.8-34.4 4.6-10.6 15-18.2 26.3-19.2M61.2 3c-19.5 1.8-31.1 23.9-22 41.7 10 19.6 37.4 20.5 48.6 1.6C99.9 26 84.1.9 61.2 3' /%3E%3C/svg%3E");
  --icon-eye: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 192 192'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='10' d='M96 157.2c-48.2 0-86.2-45.1-86.2-50.8s30.4-71.6 86.7-71.6 85.7 54 85.7 61c0 10.7-21 61.3-86.2 61.3ZM61.8 96c0 21.2 17.2 38.3 38.3 38.3s38.3-17.2 38.3-38.3-17.2-38.3-38.3-38.3S61.8 74.9 61.8 96Z' /%3E%3C/svg%3E");
  --icon-eye-off: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 192 192'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='10' d='M52.3 49.7c12.3-8.9 26.8-14.8 44.2-14.8 64.7 0 85.7 54 85.7 61s-9.5 32.4-35.5 48.2m-18.7 8.4c-9.2 2.9-19.9 4.7-32 4.7-48.2 0-86.2-45.1-86.2-50.8S19.4 81 37.7 62.2m25.1 25.1c-.7 2.8-1 5.7-1 8.7 0 21.2 17.2 38.3 38.3 38.3s5.9-.3 8.7-1m17.7-9.5c7.4-7 12-16.9 12-27.8 0-21.2-17.2-38.3-38.3-38.3s-20.9 4.6-27.8 12m98.8 98.9L18.6 15.9' /%3E%3C/svg%3E");
  --icon-lock: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='5' d='M16.07 24.87h32c4.42 0 8 3.58 8 8v20c0 4.42-3.58 8-8 8h-32c-4.42 0-8-3.58-8-8v-20c0-4.42 3.58-8 8-8Zm31.25 0v-6.51c0-8.42-6.83-15.25-15.25-15.25h0c-8.42 0-15.25 6.83-15.25 15.25v6.51m15.25 21.7v-7.39' /%3E%3C/svg%3E");
  --icon-user: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='5' d='M32 3.98c9.6 0 17.37 7.78 17.37 17.37S41.59 38.72 32 38.72s-17.37-7.78-17.37-17.37S22.4 3.98 32 3.98Zm22 56.04c-3.64-6.77-12.12-11.51-22-11.51s-18.36 4.74-22 11.51' /%3E%3C/svg%3E");
  --icon-eye: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='5' d='M32 10.75c16 0 28.98 12.07 28.98 21.25S48.01 53.25 32 53.25 3.02 40.69 3.02 32 16 10.75 32 10.75ZM20.25 32c0 6.49 5.26 11.75 11.75 11.75S43.75 38.49 43.75 32 38.49 20.25 32 20.25 20.25 25.51 20.25 32Z' /%3E%3C/svg%3E");
  --icon-eye-off: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='5' d='M10.38 4.6 60.4 54.62M43.01 36.07c.47-1.27.74-2.64.74-4.07 0-6.49-5.26-11.75-11.75-11.75-1.43 0-2.8.27-4.07.74m24.84 24.84c5.08-4.13 8.21-9.33 8.21-13.83 0-9.18-12.97-21.25-28.98-21.25-4.26 0-8.3.9-11.95 2.37m1.13 14.29c-.6 1.41-.93 2.96-.93 4.59 0 6.49 5.26 11.75 11.75 11.75 1.63 0 3.18-.33 4.59-.93M11.72 17.95C6.35 22.2 3.02 27.6 3.02 32c0 8.69 12.97 21.25 28.98 21.25 4.48 0 8.72-.95 12.51-2.51' /%3E%3C/svg%3E");
  --icon-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='5' d='M42.65 12.01c8.46 8.46 8.46 22.18 0 30.64s-22.18 8.46-30.64 0-8.46-22.18 0-30.64 22.18-8.46 30.64 0Zm6.7 37.34 8.99 8.99' /%3E%3C/svg%3E");
  --icon-date-from: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M13 11.25h38c4.42 0 8 3.58 8 8v32c0 4.42-3.58 8-8 8H13c-4.42 0-8-3.58-8-8v-32c0-4.42 3.58-8 8-8Zm4 0V4.28m30 6.97V4.28M5 24.72h54M37.38 47.83l5.92-5.92-5.92-5.92m5.91 5.93H20.71' /%3E%3C/svg%3E");
  --icon-date-to: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M13 11.25h38c4.42 0 8 3.58 8 8v32c0 4.42-3.58 8-8 8H13c-4.42 0-8-3.58-8-8v-32c0-4.42 3.58-8 8-8Zm4 0V4.28m30 6.97V4.28M5 24.72h54M26.62 36l-5.92 5.92 5.92 5.92m-5.91-5.92h22.58' /%3E%3C/svg%3E");
  --icon-kanban: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M12 4h40c4.42 0 8 3.58 8 8v40c0 4.42-3.58 8-8 8H12c-4.42 0-8-3.58-8-8V12c0-4.42 3.58-8 8-8Zm3.5 10.25v31m11-31V32m11-17.75v36m11-36v7.08' /%3E%3C/svg%3E");
  --icon-table: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M12 4h40c4.42 0 8 3.58 8 8v40c0 4.42-3.58 8-8 8H12c-4.42 0-8-3.58-8-8V12c0-4.42 3.58-8 8-8ZM4 19.67h56m-39.67 0V60m9.56-29.44h18m-18 9.63h11.33m-11.33 9.64h18' /%3E%3C/svg%3E");
  --icon-status-active: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='m5 26 16-16m-16 .07L20.93 26M5 54l16-16m-.07 16L5 38.07m26.41-24.51h27.03m-27.03 8.89H41.5M31.44 41.56h20.11m-20.11 8.88h27' /%3E%3C/svg%3E");
  --icon-status-all: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='m5 26 16-16m-.07 16L5 10.07m0 39.3L8.59 54 21 38m10.41-24.44h21.81m-21.81 8.89h27M31.44 41.56h27m-27 8.88h10.61' /%3E%3C/svg%3E");
  --icon-filter: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='m5.85 14.94 21.04 22.91V53.2l9.95 7.55v-22.4l21.33-23.43c4.07-4.48.9-11.66-5.15-11.66H10.98c-6.07 0-9.24 7.21-5.13 11.68Z' /%3E%3C/svg%3E");
  --icon-filter-2: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M60 32h-7.11m-12 0H4m48.89 0c0-3.31-2.69-6-6-6s-6 2.69-6 6m0 0c0 3.31 2.69 6 6 6s6-2.69 6-6M4 10h7.11m12 0H60m-48.89 0c0 3.31 2.69 6 6 6s6-2.69 6-6m0 0c0-3.31-2.69-6-6-6s-6 2.69-6 6M4 54h16.11m12 0H60m-39.89 0c0 3.31 2.69 6 6 6s6-2.69 6-6m0 0c0-3.31-2.69-6-6-6s-6 2.69-6 6' /%3E%3C/svg%3E");
  --icon-trash: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M6.8 14.9h50.3m-14.7 0v-6c0-3-1.9-5.4-4.2-5.4H26c-2.3 0-4.2 2.4-4.2 5.4v6m-8.9 0 2.7 38.7c.3 3.9 3.5 6.9 7.4 6.9h18.1c3.9 0 7.1-3 7.4-6.9l2.7-38.7M25.9 28.7v16.7m12.2-16.7v16.7' /%3E%3C/svg%3E");
  --icon-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M12 4h40c4.42 0 8 3.58 8 8v40c0 4.42-3.58 8-8 8H12c-4.42 0-8-3.58-8-8V12c0-4.42 3.58-8 8-8Zm28.24 13.88c0 3.25 2.63 5.88 5.88 5.88S52 21.13 52 17.88 49.37 12 46.12 12s-5.88 2.63-5.88 5.88Zm19.64 35.47L43.67 37.14a3 3 0 0 0-4.24 0l-5.41 5.41a3 3 0 0 1-4.24 0L17.12 29.89a3 3 0 0 0-4.24 0l-8.55 8.55' /%3E%3C/svg%3E");
  --icon-edit: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M60 26v17c0 3.87-13.13 17-17 17H11c-3.87 0-7-3.13-7-7V11c0-3.87 3.13-7 7-7h27m22 38.22H49.22c-3.87 0-7 3.13-7 7V60M30.41 40.99l28.84-28.84c1.3-1.3 1.3-3.4 0-4.7l-2.7-2.7a3.32 3.32 0 0 0-4.7 0L23.01 33.59c-.49.49-.88 1.07-1.16 1.71l-3.59 8.25c-.6 1.39.81 2.8 2.19 2.19l8.25-3.59c.64-.28 1.22-.67 1.71-1.16Z' /%3E%3C/svg%3E");
  --icon-duplicate: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M29 22h24c3.87 0 7 3.13 7 7v17c0 3.87-10.13 14-14 14H29c-3.87 0-7-3.13-7-7V29c0-3.87 3.13-7 7-7Zm7-11.11v-.67A6.22 6.22 0 0 0 29.78 4H10.22A6.22 6.22 0 0 0 4 10.22v19.56A6.22 6.22 0 0 0 10.22 36h.67M60 45.29h-8.92c-3.2 0-5.79 2.59-5.79 5.79V60' /%3E%3C/svg%3E");
  --icon-complete: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M60 21v22c0 3.87-13.13 17-17 17H11c-3.87 0-7-3.13-7-7V11c0-3.87 3.13-7 7-7h32m17 38.22H49.22c-3.87 0-7 3.13-7 7V60M15.78 30.33C20.92 34.2 27 41.22 27 41.22S38.22 19.78 59.42 4.58' /%3E%3C/svg%3E");
  --icon-settings: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='m38.07 60 1.67-7.14 6.42-3.81 7.14 2.14c3.34-5.73 2.87-4.75 5.95-10.48l-5.48-5.01v-7.4l5.48-5.01c-3.34-5.73-2.87-4.75-5.95-10.48l-7.14 2.14-6.42-3.81L38.07 4H25.92l-1.67 7.14-6.42 3.81-7.14-2.14-5.95 10.48 5.48 5.01v7.4l-5.48 5.01 5.95 10.48 7.14-2.14 6.42 3.81L25.92 60h12.15Zm-5.94-17.85c-5.62 0-10-4.61-10-10s4.61-10 10-10 10 4.61 10 10-4.61 10-10 10Z' /%3E%3C/svg%3E");
  --icon-logout: url("data:image/svg+xml, %3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M32 25V3.67M19 7.2C10.08 11.88 4 21.23 4 32c0 15.46 12.54 28 28 28s28-12.54 28-28c0-10.77-6.08-20.11-15-24.8' /%3E%3C/svg%3E");
  --icon-dashboard: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M53 60H11c-3.87 0-7-3.13-7-7V11c0-3.87 3.13-7 7-7h42c3.87 0 7 3.13 7 7v42c0 3.87-3.13 7-7 7ZM4 32h56M22.5 4v28m18.67 28V32' /%3E%3C/svg%3E");
  --icon-add-user: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='5' d='M27 4c9.59 0 17.36 7.77 17.36 17.36S36.59 38.72 27 38.72 9.64 30.95 9.64 21.36 17.41 4 27 4Zm0 44.5c-9.87 0-18.35 4.74-21.98 11.5M49 38v22M38 49h22' /%3E%3C/svg%3E");
  --icon-users: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-miterlimit='10' stroke-width='5' d='M22 15.23c7.67 0 13.89 6.22 13.89 13.89S29.67 43.01 22 43.01 8.11 36.79 8.11 29.12 14.33 15.23 22 15.23Zm17.58 44.79c-2.91-5.41-9.69-9.2-17.58-9.2s-14.68 3.79-17.58 9.2m38.67-34.37a8.88 8.88 0 1 1 5.66 15.72c-2.66 0-5.05-1.17-6.67-3.02M60 54.27c-1.86-3.46-6.2-5.89-11.25-5.89-2.04 0-3.97.4-5.66 1.1m-8.5-41.3a8.886 8.886 0 0 1 5.48-1.47c4.51.29 8.02 3.89 8.3 8.28M33.35 9.18c.38-.37.8-.7 1.25-1' /%3E%3C/svg%3E");
  --icon-health: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M11 18h42c3.87 0 7 3.13 7 7v26c0 3.87-3.13 7-7 7H11c-3.87 0-7-3.13-7-7V25c0-3.87 3.13-7 7-7Zm31.96 0v-6c0-3.31-3.13-6-7-6h-8c-3.87 0-7 2.69-7 6v6M32 30v16m-8-8h16' /%3E%3C/svg%3E");
  --icon-plus: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M4 32c0 15.46 12.54 28 28 28s28-12.54 28-28S47.46 4 32 4 4 16.54 4 32Zm28-12v24M20 32h24' /%3E%3C/svg%3E");
  --icon-clock: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='5' d='M4 32c0 15.46 12.54 28 28 28s28-12.54 28-28S47.46 4 32 4 4 16.54 4 32Zm36.44 8.44L32 32V15.78' /%3E%3C/svg%3E");
  --icon-chevron-down: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%231d1d1b' stroke-linecap='round' stroke-linejoin='round' stroke-width='10' d='M4 20 32 44 60 20' /%3E%3C/svg%3E");
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}
.form__input-text,
.form-input-wrapper__input,
.form-input-wrapper__textarea,
textarea,
select {
  --form-input-padding-left: 1em;
  font-family: var(--font-basic);
  font-weight: var(--font-weight-medium);
  font-optical-sizing: auto;
  padding: 0.7em 1em 0.7em var(--form-input-padding-left);
  font-size: var(--form-input-font-size, var(--font-size-15));
  background: var(--form-input-background-color, var(--input-bg));
  color: var(--form-input-text-color, var(--color-text-primary));
  display: block;
  width: 100%;
  border-radius: var(--border-radius-smaller);
  border: 1px solid var(--form-input-border-color, var(--input-border));
  transition: var(--transition);
  box-shadow: none;
}
.form__input-text:hover,
.form-input-wrapper__input:hover,
.form-input-wrapper__textarea:hover,
textarea:hover,
select:hover {
  border-color: var(--form-input-border-color-active, var(--color-text-primary));
}
.form__input-text:focus,
.form-input-wrapper__input:focus,
.form-input-wrapper__textarea:focus,
textarea:focus,
select:focus {
  border-color: var(--form-input-border-color-active, var(--color-text-primary));
  background-color: var(--form-input-background-color-active, var(--input-bg-focus));
  box-shadow: 0 0 3px rgba(var(--color-primary-rgb), 0.5);
}

input[type=password]::-ms-reveal,
input[type=password]::-ms-clear {
  display: none;
}

::placeholder {
  color: var(--color-text-primary);
  opacity: 0.5;
  font-weight: var(--font-weight-regular);
}

.form-input-wrapper {
  position: relative;
  line-height: 1;
}
.form-input-wrapper--inline {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
}
.form-input-wrapper__input--has-icon {
  --form-input-padding-left: 2.5em;
}
.form-input-wrapper__input--file {
  display: none;
}
.form-input-wrapper__icon {
  position: absolute;
  left: 0.5em;
  top: 50%;
  transform: translateY(-50%);
  width: 1em;
  height: 1em;
  pointer-events: none;
  mask: var(--form-input-icon) center/contain no-repeat;
  background-color: var(--color-text-primary);
  z-index: 2;
  opacity: 0.5;
}
.form-input-wrapper__icon--user {
  --form-input-icon: var(--icon-user);
}
.form-input-wrapper__icon--lock {
  --form-input-icon: var(--icon-lock);
}
.form-input-wrapper__icon--search {
  --form-input-icon: var(--icon-search);
}
.form-input-wrapper__icon--date-from {
  --form-input-icon: var(--icon-date-from);
}
.form-input-wrapper__icon--date-to {
  --form-input-icon: var(--icon-date-to);
}
.form-input-wrapper__label {
  font-size: var(--font-size-12);
  margin-bottom: 0.5em;
  display: inline-block;
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
  line-height: 1.25em;
}
.form-input-wrapper__password-toggle {
  position: absolute;
  right: 0.5em;
  top: 50%;
  transform: translateY(-50%);
  width: 1em;
  height: 1em;
  cursor: pointer;
  mask: var(--icon-eye);
  background-color: var(--color-text-primary);
  z-index: 2;
  transition: var(--transition);
  opacity: 0;
}
.form-input-wrapper__password-toggle:hover.active {
  background-color: var(--color-primary);
  opacity: 1;
}
.form-input-wrapper__password-toggle.active {
  opacity: 0.5;
}
.form-input-wrapper__password-toggle.password-visible {
  mask: var(--icon-eye-off);
}
.form-input-wrapper__input--checkbox, .form-input-wrapper__input--radio {
  display: none;
}
.form-input-wrapper__input--checkbox:checked + .form-input-wrapper__checkbox-label:after {
  opacity: 1;
}
.form-input-wrapper__input--checkbox:checked + .form-input-wrapper__checkbox-label::before {
  border-color: var(--form-input-border-color-active, var(--color-text-primary));
  box-shadow: 0 0 3px rgba(var(--color-primary-rgb), 0.5);
}
.form-input-wrapper__checkbox-wrapper {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.form-input-wrapper__checkbox-label {
  font-size: var(--font-size-16);
  padding-left: 2em;
}
.form-input-wrapper__checkbox-label:hover::before {
  border-color: var(--form-input-border-color-active, var(--color-border-default));
}
.form-input-wrapper__checkbox-label::before {
  content: "";
  width: 1.2em;
  height: 1.2em;
  border-radius: var(--border-radius-smaller);
  border: 1px solid var(--form-input-border-color, var(--input-border));
  transition: var(--transition);
  position: absolute;
  left: 0;
  top: 0.05em;
  transition: var(--transition);
  background-color: var(--form-input-background-color, var(--input-bg));
}
.form-input-wrapper__checkbox-label::after {
  content: "";
  width: 0.6em;
  height: 0.3em;
  border-left: 2px solid var(--color-primary);
  border-bottom: 2px solid var(--color-primary);
  transform: rotate(-45deg);
  position: absolute;
  left: 0.3em;
  top: 0.35em;
  opacity: 0;
  transition: var(--transition);
  z-index: 2;
}
.form-input-wrapper__radio-group {
  display: flex;
  gap: 0.5em;
  flex-wrap: wrap;
  font-size: var(--font-size-15);
}
.form-input-wrapper__radio-option--icon {
  --radio-color: var(--color-text-primary);
  --form-input-background-color: var(--color-surface);
  --form-input-text-color: var(--color-text-primary);
  display: flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.4em 0.7em;
  border: 1px solid var(--form-input-border-color, var(--input-border));
  border-radius: var(--border-radius-smaller);
  background-color: var(--form-input-background-color, var(--input-bg));
  cursor: pointer;
  color: var(--form-input-text-color);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  transition: var(--transition);
}
.form-input-wrapper__radio-option--icon input {
  display: none;
}
.form-input-wrapper__radio-option--icon:has(input:checked) {
  --form-input-border-color: var(--color-primary);
  --form-input-background-color: var(--color-primary);
  --form-input-text-color: var(--palette-white);
}
.form-input-wrapper__radio-option--icon:has(input:checked)::before {
  --radio-color: var(--palette-white);
  opacity: 1;
}
.form-input-wrapper__radio-option--icon::before {
  content: "";
  width: 1em;
  aspect-ratio: 1/1;
  mask: var(--radio-icon) center/contain no-repeat;
  background-color: var(--radio-color);
  opacity: 0.5;
  transition: var(--transition);
  display: inline-block;
}
.form-input-wrapper__radio-option--icon:hover {
  --form-input-border-color: var(--color-primary);
  --form-input-background-color: rgba(var(--color-primary-rgb), 0.15);
  --form-input-border-color: rgba(var(--color-primary-rgb), 0.3);
  --form-input-text-color: var(--color-primary);
  --radio-color: var(--color-primary);
}
.form-input-wrapper__radio-option--icon:hover::before {
  opacity: 1;
}
.form-input-wrapper__radio-option--icon label {
  cursor: pointer;
  user-select: none;
  color: var(--form-input-text-color, var(--color-text-primary));
  transition: var(--transition);
  top: 0.05em;
  position: relative;
  display: inline-block;
}
.form-input-wrapper__radio-option--icon-table {
  --radio-icon: var(--icon-table);
}
.form-input-wrapper__radio-option--icon-kanban {
  --radio-icon: var(--icon-kanban);
}
.form-input-wrapper__radio-option--icon-all {
  --radio-icon: var(--icon-status-all);
}
.form-input-wrapper__radio-option--icon-active {
  --radio-icon: var(--icon-status-active);
}
.form-input-wrapper__radio-option--default {
  padding: 0.4em 0.7em;
  border: 1px solid var(--form-input-border-color, var(--input-border));
  border-radius: var(--border-radius-smaller);
  background-color: var(--color-surface);
  cursor: pointer;
  user-select: none;
  transition: var(--transition);
}
.form-input-wrapper__radio-option--default input {
  display: none;
}
.form-input-wrapper__radio-option--default:has(input:checked) {
  --form-input-text-color: var(--palette-white);
  --form-input-border-color: var(--color-primary);
  background-color: var(--color-primary);
}
.form-input-wrapper__radio-option--default:hover {
  --form-input-text-color: var(--color-primary);
  border-color: rgba(var(--color-primary-rgb), 0.3);
  background-color: rgba(var(--color-primary-rgb), 0.15);
}
.form-input-wrapper__radio-option--default label {
  cursor: pointer;
  user-select: none;
  color: var(--form-input-text-color, var(--color-text-primary));
  transition: var(--transition);
  top: 0.05em;
  position: relative;
  display: inline-block;
}
.form-input-wrapper__description {
  font-size: var(--font-size-14);
  color: var(--color-text-secondary);
  margin-top: 0.75em;
}

.required {
  color: var(--color-error);
  font-weight: var(--font-weight-semibold);
}

.form {
  --form-gap: 1em 1.75em;
  --form-input-border-color-active: var(--color-primary);
  --form-input-background-color: var(--input-bg);
  --form-input-border-color: var(--color-border-default);
  --form-input-background-color-active: var(--input-bg-focus);
  display: grid;
  gap: var(--form-gap);
}
.form__rows {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.form__row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--form-gap);
}
.form__row--flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.form__columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: calc(var(--form-gap) * 1.5);
}
.form__column {
  display: flex;
  flex-direction: column;
  gap: var(--form-gap);
}
.form__separator {
  height: 1px;
  background-color: var(--color-border-default);
  margin: 0.5em 0;
  width: 100%;
}
.form__submit-wrapper {
  display: flex;
  gap: 0.5em;
}
.form__submit-wrapper--right {
  justify-content: flex-end;
}
.form--search, .form--date {
  display: flex;
  gap: 0.5em;
}

.form__new-entry-content {
  display: flex;
  flex-direction: column;
  gap: 1em;
}

* {
  box-sizing: border-box;
  position: relative;
}

h1,
h2,
h3,
h4,
h5,
h6,
ul,
li,
a,
input,
textarea,
p,
body,
span,
menu {
  margin: 0;
  padding: 0;
  line-height: 1.25;
}

img {
  border: none;
}

ul li,
menu li {
  list-style: none;
}

a {
  text-decoration: none;
}

a,
svg,
path {
  transition: var(--transition);
}

div,
article,
section,
img,
main,
input,
textarea {
  display: block;
}

input,
textarea,
img,
a,
option,
select,
button,
div {
  outline: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

html {
  font-size: 10px;
  font-family: var(--font-basic);
  font-weight: var(--font-weight-regular);
  font-optical-sizing: auto;
  height: fill-available;
  height: -webkit-fill-available;
  width: 100%;
  overflow-x: hidden;
}

body {
  font-size: var(--font-size-18);
  color: var(--color-text-secondary, var(--color-text-primary));
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  background-color: var(--color-page-background);
  min-height: 100vh;
  min-height: fill-available;
  min-height: -webkit-fill-available;
  overflow: clip;
  scrollbar-color: var(--color-border-subtle) var(--color-surface-secondary);
  scrollbar-width: thin;
}
body::-webkit-scrollbar {
  width: 0.8rem;
  background: var(--color-border-subtle);
}
body::-webkit-scrollbar-thumb {
  background: var(--color-surface-secondary);
  border-radius: 0.4rem;
}

.z-index-5 {
  z-index: 5;
}

.text-center {
  text-align: center;
}

.margin-top {
  margin-top: var(--gap);
}

.margin-bottom {
  margin-bottom: var(--gap);
}

.no-margin-top {
  margin-top: 0 !important;
}

.no-margin-bottom {
  margin-bottom: 0 !important;
}

.absolute-image {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.content {
  width: 100%;
  padding: 0 var(--padding-on-side);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.content--regular {
  max-width: calc(var(--content-regular) + 2 * var(--padding-on-side));
}
.content--smaller {
  max-width: calc(var(--content-small) + 2 * var(--padding-on-side));
}
.content--bigger {
  max-width: calc(var(--content-big) + 2 * var(--padding-on-side));
}

.section {
  position: relative;
  z-index: 2;
}
.section--smaller {
  padding: calc(var(--gap) * 2) 0;
}
.section--normal {
  padding: calc(var(--gap) * 3) 0;
}
.section--bigger {
  padding: calc(var(--gap) * 4) 0;
}
.section--smaller-top {
  padding-top: calc(var(--gap) * 2);
}
.section--no-top {
  padding-top: 0;
}
.section--no-bottom {
  padding-bottom: 0;
}
.section--background {
  background-color: var(--color-surface);
}

.section__title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-48);
  line-height: 1.25;
  color: var(--color-title, var(--color-primary));
  margin-bottom: 0.5em;
}
.section__title--smaller {
  font-size: var(--font-size-30);
  color: var(--color-primary);
}
.section__title.text-center, .section__title.has-text-align-center {
  justify-content: center;
}

.section__subheading,
.is-style-subheading {
  font-family: var(--font-basic);
  font-weight: var(--font-weight-regular);
  font-optical-sizing: auto;
  font-size: var(--font-size-18);
  line-height: 1.2;
  color: var(--color-text-secondary, var(--color-secondary));
  margin-top: 0 !important;
  margin-bottom: 0.25em !important;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  display: block;
}
.section__subheading + .wp-block-heading,
.is-style-subheading + .wp-block-heading {
  margin-top: 0 !important;
}

.section__text {
  font-size: var(--font-size-16);
  line-height: var(--line-height);
  color: var(--color-text-primary);
}
.section__text.text-center {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.section:not([class*=is-style]):not([class*=has-background]):has(+ .section:not([class*=is-style]):not([class*=has-background])) {
  padding-bottom: 0;
}

.button {
  --button-text-color: var(--palette-white);
  --button-text-color-hover: var(--palette-white);
  --button-background-color: var(--color-primary);
  --button-background-color-hover: var(--color-primary-hover);
  --button-font-size: var(--font-size-16);
  --button-border-radius: var(--border-radius);
  --button-border-color: transparent;
  --button-border: 1px solid var(--button-border-color);
  --button-border-color-hover: transparent;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  display: inline-block;
  padding: 0.7em 1.6em;
  line-height: 1;
  font-size: var(--button-font-size, var(--font-size-18));
  border: var(--button-border, none);
  transition: var(--transition);
  cursor: pointer;
  border-radius: var(--button-border-radius, var(--border-radius));
  text-align: center;
  color: var(--button-text-color, var(--palette-white));
  background-color: var(--button-background-color, var(--color-text-primary));
  box-shadow: var(--button-shadow, none);
}
.button:hover {
  color: var(--button-text-color-hover, var(--palette-white));
  background-color: var(--button-background-color-hover, var(--color-secondary-light));
  box-shadow: var(--button-shadow-hover, none);
  border-color: var(--button-border-color-hover, var(--color-tertiary));
}
.button--secondary {
  --button-background: var(--color-secondary);
  --button-background-hover: var(--color-primary);
}
.button--outline {
  --button-text-color: var(--color-primary);
  --button-text-color-hover: var(--color-white);
  --button-background-color: rgba(var(--color-primary-rgb), 0.05);
  --button-background-color-hover: var(--color-primary-hover);
  --button-border-color: rgba(var(--color-primary-rgb), 0.2);
  --button-border-color-hover: var(--color-primary-hover);
  --button-shadow: none;
}
.button--neutral {
  --button-text-color: var(--color-info);
  --button-text-color-hover: var(--palette-white);
  --button-background-color: var(--color-info-bg);
  --button-background-color-hover: var(--color-info);
  --button-border-color: var(--color-info-border);
  --button-border-color-hover: var(--color-info);
  --button-shadow: none;
  --button-shadow-hover: none;
}
.button--smaller {
  --button-font-size: var(--font-size-14);
}
.button--tiny {
  --button-font-size: var(--font-size-13);
  padding: 0.7em 1.4em;
}
.button--icon {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
}
.button--icon::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  position: relative;
  width: 1em;
  height: 1em;
  z-index: 5;
  mask: var(--button-icon) center/contain no-repeat;
  background-color: var(--button-text-color);
  transition: var(--transition, all 0.2s ease-in-out);
}
.button--icon:hover::before {
  background-color: var(--button-text-color-hover, var(--palette-white));
}
.button--icon-delete {
  --button-icon: var(--icon-trash);
}
.button--icon-logout {
  --button-icon: var(--icon-logout);
}
.button--icon-add-user {
  --button-icon: var(--icon-add-user);
}
.button--icon-add {
  --button-icon: var(--icon-plus);
}
.button--icon-edit {
  --button-icon: var(--icon-edit);
}
.button--icon-clock {
  --button-icon: var(--icon-clock);
}
.button--loading {
  display: inline-flex;
  align-items: center;
}
.button--loading::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  position: relative;
  width: 0;
  height: 1em;
  z-index: 5;
  mask: var(--icon-loading) center/contain no-repeat;
  background-color: var(--palette-white);
  animation: spin 1s linear infinite;
  transition: var(--transition, all 0.2s ease-in-out);
}
.button.loading::before {
  animation: spin 1s linear infinite;
  width: 1em;
  margin-right: 1em;
}
.button:disabled {
  cursor: not-allowed;
  opacity: 0.75;
}

.buttons-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em 1em;
}
.buttons-wrapper.text-center {
  justify-content: center;
}

/* ----- Globální styly ----- */
.global-style > *:first-child {
  margin-top: 0;
}
.global-style > *:last-child {
  margin-bottom: 0;
}
.global-style p,
.global-style li {
  line-height: var(--line-height);
}
.global-style a:not([class]) {
  color: var(--color-secondary);
  position: relative;
}
.global-style a:not([class]):hover {
  color: var(--color-secondary-light);
}
.global-style a:not([class]):hover:after {
  left: 100%;
}
.global-style a:not([class])::after {
  content: "";
  position: absolute;
  height: 0.15em;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 1em;
  background: linear-gradient(90deg, var(--color-secondary-light), var(--color-tertiary-light));
  z-index: -1;
  transition: var(--transition);
}
.global-style p {
  margin-top: 1em;
  margin-bottom: 1em;
}
.global-style hr {
  border: 0;
  height: 2px;
  background: var(--color-surface);
  clear: both;
  margin: var(--gap) 0;
}

/* ----- Fonty ----- */
.has-small-font-size {
  font-size: 0.9em;
}

.has-medium-font-size {
  font-size: 1.1em;
}

.has-large-font-size {
  font-size: 1.25em;
}

.has-huge-font-size {
  font-size: 1.4em;
}

.has-text-align-center,
.aligncenter {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  max-width: 44em !important;
}

.wp-block-heading {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  line-height: 1.1;
  color: var(--color-title, var(--color-primary));
  margin-top: 1em;
  margin-bottom: 0.5em;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size);
}
.wp-block-heading strong {
  color: var(--color-secondary);
}
.wp-block-heading.text-center, .wp-block-heading.has-text-align-center {
  justify-content: center;
  text-align: center;
}

h1.wp-block-heading {
  --font-size: var(--font-size-60);
}

h2.wp-block-heading {
  --font-size: var(--font-size-36);
}

h3.wp-block-heading {
  --font-size: var(--font-size-30);
}

h4.wp-block-heading {
  --font-size: var(--font-size-30);
  --color: var(--color-primary-hover);
}

h5.wp-block-heading {
  --font-size: var(--font-size-24);
  --color: var(--color-secondary);
  text-transform: uppercase;
}

/* ----- Tabulky ----- */
.wp-block-table {
  margin: var(--margins) 0;
  overflow: inherit;
}
.wp-block-table table {
  border-spacing: 0;
  border-collapse: collapse;
  width: 100%;
}
.wp-block-table th {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-18);
  color: var(--palette-white);
  background-color: var(--color-text-primary);
  text-align: left;
  border: none;
  padding: 0.6em 1em;
}
.wp-block-table td {
  font-size: var(--font-size-18);
  text-align: left;
  border: none !important;
  padding: 0.6em 1em;
}
.wp-block-table tr:nth-of-type(even) td {
  background-color: var(--color-surface);
}
@media screen and (max-width: 768px) {
  .wp-block-table.responsive-table thead {
    display: none;
  }
  .wp-block-table.responsive-table td {
    display: flex;
    justify-content: space-between;
    gap: 0 1em;
  }
  .wp-block-table.responsive-table td div {
    text-align: right;
  }
  .wp-block-table.responsive-table td::before {
    content: attr(data-label);
    font-weight: bold;
  }
  .wp-block-table.responsive-table tbody {
    display: grid;
    gap: 1em;
  }
  .wp-block-table.responsive-table tr {
    border: 1px solid var(--bs-border-color);
  }
}

/* ----- Seznamy ----- */
.wp-block-list {
  counter-reset: item;
  list-style: none;
  margin: 1em 0;
  display: flex;
  flex-direction: column;
  gap: 0.6em;
  padding: 0;
}
.wp-block-list li {
  line-height: 1.25;
  padding: 0 0 0 1.4em;
}

ul.wp-block-list li::before {
  content: "";
  position: absolute;
  left: 0;
  width: 0.4em;
  height: 0.4em;
  top: 0.4em;
  border-radius: 50%;
  background-color: var(--color-secondary);
}

ol.wp-block-list li::before {
  position: absolute;
  left: 0;
  counter-increment: item;
  content: counter(item) ". ";
  font-weight: var(--font-weight-medium);
  color: var(--color-secondary);
  min-width: 1em;
}

/* ----- Citace ----- */
.wp-block-quote {
  padding: clamp(1em, 5cqw, var(--gap) * 1);
  margin: 2em auto;
}
.wp-block-quote::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 10em;
  height: 10em;
  mask: var(--icon-quote) center/contain no-repeat;
  background-color: var(--color-primary);
  opacity: 0.075;
}
.wp-block-quote p {
  margin: 0;
  font-size: var(--font-size-30);
  color: var(--color-primary);
  z-index: 2;
}
.wp-block-quote cite {
  margin-top: 1em;
  font-size: var(--font-size-16);
  display: block;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  color: var(--color-title);
  font-style: normal;
}
.wp-block-quote cite a {
  font-style: normal;
  color: var(--color-secondary);
}
.wp-block-quote cite a:hover {
  text-decoration: underline;
}
.wp-block-quote cite em {
  font-style: normal;
  line-break: loose;
}

.wp-block-columns {
  gap: calc(var(--gap) * 1.5);
}

.wp-block-column > *:first-child {
  margin-top: 0;
}
.wp-block-column > *:last-child {
  margin-bottom: 0;
}

/* ----- Obrázek ----- */
.wp-block-image {
  margin: calc(var(--margins) * 2) auto;
}
.wp-block-image .wp-element-caption {
  text-align: center;
  font-size: var(--font-size-16);
  color: var(--color-primary);
  padding: 1em;
  background-color: var(--color-white);
  display: block;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-bold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
}

/* ----- Tlačítka ----- */
.wp-block-buttons {
  margin-top: var(--gap);
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
}

.wp-block-buttons.is-content-justification-center {
  justify-content: center;
}

/* ----- Globální ----- */
.has-text-align-right {
  text-align: right;
}

/* ------------------------- */
/* ----- CUSTOM STYLES ----- */
/* ------------------------- */
.image-text {
  display: grid;
  gap: calc(var(--gap) * 2);
  margin: var(--gap) 0;
}
.image-text--image-left {
  grid-template-columns: var(--media-width, 50%) 1fr;
  --media-order: 1;
  --text-order: 2;
}
.image-text--image-right {
  grid-template-columns: 1fr var(--media-width, 50%);
  --media-order: 2;
  --text-order: 1;
}
.image-text--vertical-align-center {
  align-items: center;
}
.image-text--vertical-align-top {
  align-items: flex-start;
}
.image-text--vertical-align-bottom {
  align-items: flex-end;
}
.image-text + .image-text {
  margin-top: calc(var(--gap) * 2);
}
.image-text__text {
  padding: 0;
  order: var(--text-order);
}
.image-text__text > *:first-child {
  margin-top: 0;
}
.image-text__text > *:last-child {
  margin-bottom: 0;
}
.image-text__image {
  order: var(--media-order);
  padding: 10px;
  border: 2px solid black;
}
.image-text__image::after {
  content: "";
  position: absolute;
  width: 0.5em;
  height: 0.5em;
  background-color: black;
  border-radius: 50%;
  top: 5em;
  right: calc(0% - 0.25em - 1px);
}
.image-text__image img {
  width: auto !important;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .image-text {
    grid-template-columns: 1fr;
  }
  .image-text__image {
    grid-column: auto;
    order: 1;
    grid-row: auto;
  }
  .image-text__text {
    grid-column: auto;
    order: 2;
    grid-row: auto;
  }
}

.has-secondary-color {
  --color-title: var(--color-secondary);
}

.has-black-color {
  --color-title: var(--color-black);
}

.has-primary-color {
  --color-title: var(--color-primary);
  --color-text: var(--color-primary);
  color: var(--color-primary);
}

.has-background-color-background {
  background-color: var(--color-background);
}

.has-background-color-pink-background {
  background-color: var(--color-pink-background);
}
.has-background-color-pink-background .article {
  --article-background-color: var(--color-white);
  --article-title-color: var(--color-secondary);
  --article-image-filter-color: var(--color-secondary);
}

.is-style-frame {
  padding: clamp(1em, 5cqw, 2em);
  border: 2px solid var(--color-black);
}
.is-style-frame > *:first-child {
  margin-top: 0;
}
.is-style-frame > *:last-child {
  margin-bottom: 0;
}
.is-style-frame::after {
  content: "";
  position: absolute;
  width: 0.5em;
  height: 0.5em;
  background-color: var(--color-black);
  border-radius: 50%;
  top: calc(0% - 0.25em - 1px);
  left: 5em;
}
.is-style-frame .has-text-align-center {
  max-width: none !important;
}

.excles-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--gap);
  margin-top: 2em;
}
.excles-logos .wp-block-image {
  margin: 0;
}
.excles-logos img {
  height: 3em !important;
}

.is-style-artwork-1::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background: url(../assets/images/neurin-artwork-pink.svg) right bottom/100% no-repeat;
  opacity: 0.25;
}

.badge {
  --badge-background-color: var(--color-surface-secondary);
  --badge-border-color: var(--color-border-default);
  --badge-text-color: var(--color-text-main);
  --badge-font-size: var(--font-size-12);
  display: inline-block;
  background-color: var(--badge-background-color);
  border: 1px solid var(--badge-border-color);
  border-radius: var(--border-radius-smaller);
  padding: 0.2em 0.6em;
  font-size: var(--badge-font-size);
  font-weight: var(--font-weight-medium);
  color: var(--badge-text-color);
}
.badge--error, .badge--sick-leave {
  --badge-background-color: rgba(var(--color-error-rgb), 0.1);
  --badge-border-color: rgba(var(--color-error-rgb), 0.25);
  --badge-text-color: var(--color-error);
}
.badge--warning, .badge--unpaid {
  --badge-background-color: rgba(var(--color-warning-rgb), 0.1);
  --badge-border-color: rgba(var(--color-warning-rgb), 0.25);
  --badge-text-color: var(--color-warning);
}
.badge--success, .badge--vacation {
  --badge-background-color: rgba(var(--color-success-rgb), 0.1);
  --badge-border-color: rgba(var(--color-success-rgb), 0.25);
  --badge-text-color: var(--color-success);
}
.badge--info, .badge--other {
  --badge-background-color: rgba(var(--color-info-rgb), 0.1);
  --badge-border-color: rgba(var(--color-info-rgb), 0.25);
  --badge-text-color: var(--color-info);
}
.badge--neutral {
  --badge-background-color: var(--color-surface-secondary);
  --badge-border-color: var(--color-border-default);
  --badge-text-color: var(--color-text-main);
}
.badge--tiny {
  --badge-font-size: var(--font-size-10);
}
.badge--medium {
  --badge-font-size: var(--font-size-14);
}
.badge--big {
  --badge-font-size: var(--font-size-16);
}
.badge--sup {
  top: -0.5em;
}

.modal {
  --modal-backdrop-padding: clamp(10px, 5vw, 20px);
  --modal-padding: clamp(20px, 3cqw, 30px);
  --modal-padding-smaller: clamp(20px, 3cqw, 11px);
  --modal-state-color: var(--color-error);
  --modal-state-background-color: var(--color-error-bg);
  --modal-icon-size: 2.4em;
  --modal-width: 60em;
  border: none;
  padding: 0;
  max-width: none;
  max-height: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-16);
  color: var(--color-text-primary);
  z-index: 49;
  background-color: transparent;
  padding: var(--modal-backdrop-padding);
  opacity: 0;
  transition: var(--transition);
  pointer-events: none;
  transform: scale(0.98);
  visibility: hidden;
  transition-behavior: allow-discrete;
}
.modal::backdrop {
  transition: var(--transition);
  backdrop-filter: blur(0px);
}
.modal:open {
  opacity: 1;
  pointer-events: auto;
  transform: scale(1);
  visibility: visible;
  background-color: var(--modal-overlay);
}
.modal:open::backdrop {
  backdrop-filter: blur(1px);
}
.modal:open .modal__inner {
  transform: none;
}
.modal__inner {
  background-color: var(--modal-bg);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  width: 100%;
  max-width: var(--modal-width);
  max-height: 100%;
  overflow-y: auto;
  transform: scale(0.9) translateY(-20px);
  transition: var(--transition);
  position: relative;
}
.modal__inner--small {
  --modal-width: 32em;
}
.modal__inner--new-entry {
  --modal-width: 44em;
}
.modal__content {
  padding: var(--modal-padding) var(--modal-padding);
}
.modal__content--body {
  padding-bottom: var(--modal-padding-smaller);
}
.modal__content--footer {
  padding: var(--modal-padding-smaller) var(--modal-padding);
  display: flex;
  gap: 1em;
  justify-content: flex-end;
}
.modal__content--footer-buttons-center {
  justify-content: center;
}
.modal__content--footer-button-start {
  justify-content: flex-start;
}
.modal__close {
  width: 2.2em;
  aspect-ratio: 1/1;
  border: none;
  background: transparent;
  border-radius: var(--border-radius-smaller);
  cursor: pointer;
  transition: var(--transition);
  position: absolute;
  top: calc(var(--modal-padding) - 0.4em);
  right: calc(var(--modal-padding) - 0.4em);
  z-index: 2;
}
.modal__close::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  mask: var(--icon-close) center/40% no-repeat;
  background-color: var(--color-text-primary);
  transition: var(--transition);
  opacity: 0.5;
  transition: var(--transition);
}
.modal__close:hover {
  background-color: var(--color-surface-hover);
}
.modal__close:hover::after {
  opacity: 1;
}
.modal__with-icon {
  display: flex;
  gap: 1em;
}
.modal__with-icon::before {
  content: "";
  width: var(--modal-icon-size);
  height: var(--modal-icon-size);
  aspect-ratio: 1/1;
  background-color: var(--modal-state-background-color);
  border-radius: 50%;
  flex-shrink: 0;
}
.modal__with-icon::after {
  content: "";
  width: var(--modal-icon-size);
  height: var(--modal-icon-size);
  background-color: var(--modal-state-color);
  mask: var(--icon-error) center/54% auto no-repeat;
  position: absolute;
  left: 0;
  top: 0;
}
.modal__header {
  border-bottom: 1px solid var(--modal-border);
}
.modal__title {
  font-size: var(--font-size-18);
  font-weight: var(--font-weight-semibold);
  margin: 0;
}
.modal__title--margin-bottom {
  margin-bottom: 1em;
}
.modal__message {
  font-size: var(--font-size-15);
  margin-top: 0.5em;
  line-height: var(--line-height);
  color: var(--color-text-secondary);
}
.modal__message--timelog {
  padding: 0.5em 1em;
  background-color: var(--color-surface-secondary);
  border-radius: var(--border-radius);
  text-align: center;
  margin-top: 1em;
}
.modal__footer {
  background-color: var(--color-surface-secondary);
  position: sticky;
  bottom: 0;
}

.server-responses {
  position: fixed;
  bottom: var(--gap);
  left: 50%;
  transform: translate(-50%, 0);
  z-index: 999;
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
.server-responses__item {
  padding: 1em 1.5em;
  font-size: var(--font-size-16);
  border-radius: var(--border-radius);
  font-weight: var(--bold);
  display: flex;
  align-items: center;
  background-color: var(--box-color);
  color: var(--palette-white);
  gap: 1em;
  filter: blur(0.2em);
  transition: var(--transition);
  top: 1em;
  opacity: 0;
  visibility: hidden;
}
.server-responses__item.visible {
  top: 0;
  opacity: 1;
  visibility: visible;
  filter: blur(0) drop-shadow(0 0.2em 0.5em rgba(var(--color-secondary-rgb), 0.15));
}
.server-responses__item.success {
  --box-color: var(--color-success);
}
.server-responses__item.error {
  --box-color: var(--color-error);
}
.server-responses__text {
  flex-grow: 1;
}
.server-responses__close {
  width: 0.8em;
  height: 0.8em;
  -webkit-mask: var(--icon-close) center/contain no-repeat;
  mask: var(--icon-close) center/contain no-repeat;
  cursor: pointer;
  background-color: var(--palette-white);
}
.server-responses__link {
  color: var(--palette-white);
  text-decoration: underline;
  cursor: pointer;
}
.server-responses__link:hover {
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .server-responses {
    left: var(--padding-on-side);
    right: var(--padding-on-side);
    transform: none;
  }
}

.message {
  background-color: var(--message-background-color);
  border: 1px solid var(--message-border-color);
  color: var(--message-text-color);
  padding: 1em;
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  gap: 1em;
  font-size: var(--font-size-15);
}
.message--success {
  --message-background-color: var(--color-surface);
  --message-border-color: var(--color-border-default);
  --message-text-color: var(--color-text-primary);
  --message-icon: var(--icon-success);
  --message-icon-color: var(--color-success);
}
.message--error {
  --message-background-color: var(--color-surface);
  --message-border-color: var(--color-border-default);
  --message-text-color: var(--color-text-primary);
  --message-icon: var(--icon-error);
  --message-icon-color: var(--color-error);
}
.message--warning {
  --message-background-color: var(--color-surface);
  --message-border-color: var(--color-border-default);
  --message-text-color: var(--color-text-primary);
  --message-icon: var(--icon-warning);
  --message-icon-color: var(--color-warning);
}
.message::before {
  content: "";
  display: block;
  width: 1.2em;
  aspect-ratio: 1/1;
  mask: var(--message-icon) center/contain no-repeat;
  background-color: var(--message-icon-color);
  flex-shrink: 0;
}

.table-scroll-wrapper {
  position: relative;
  width: 100%;
}
.table-scroll-wrapper.is-scrollable .js-table {
  will-change: transform;
}

.custom-scrollbar {
  position: sticky;
  bottom: 1em;
  left: 0;
  width: 100%;
  height: 20px;
  padding: 4px;
  background-color: var(--color-text-secondary);
  border-radius: 2em;
  margin-top: 0.5em;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease;
  z-index: 50;
  cursor: pointer;
  box-shadow: var(--shadow);
}
.custom-scrollbar.is-visible {
  opacity: 1;
  visibility: visible;
}
.custom-scrollbar__thumb {
  position: absolute;
  top: 4px;
  left: 4px;
  height: calc(100% - 8px);
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-active));
  border-radius: calc(var(--border-radius) - 2px);
  cursor: grab;
  transition: background-color 0.2s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  will-change: transform;
}
.custom-scrollbar__thumb.is-dragging {
  cursor: grabbing;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
.custom-scrollbar__thumb::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 30px;
  height: 3px;
  background-color: rgba(255, 255, 255, 0.5);
  border-radius: 2px;
}
@media (hover: none) and (pointer: coarse) {
  .custom-scrollbar {
    height: 20px;
  }
  .custom-scrollbar__thumb {
    height: calc(100% - 6px);
    top: 3px;
  }
  .custom-scrollbar__thumb::before {
    width: 40px;
    height: 4px;
  }
}

.table {
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius);
  background-color: var(--table-bg);
  font-size: var(--font-size-14);
  position: relative;
  box-shadow: var(--shadow);
  max-width: 1720px;
}
.table--app {
  --table-columns: 1.2fr 1fr 1fr 0.65fr 1.05fr 1fr 1fr 1fr 1fr 1.5fr 3.4em;
  min-width: 1280px;
}
.table--timelog-admin {
  --table-columns: 1fr 1fr 1fr 1fr 4fr;
  min-width: 960px;
}
@media screen and (max-width: 1400px) {
  .table--timelog-admin {
    --table-columns: 1fr 1fr 1fr 1fr 2.5fr;
    min-width: 768px;
  }
}
.table--timelog {
  --table-columns: 1fr 1fr 1fr 4fr;
  min-width: 768px;
}
@media screen and (max-width: 1400px) {
  .table--timelog {
    --table-columns: 1fr 1fr 1fr 2.5fr;
    min-width: 660px;
  }
}
.table__header {
  display: grid;
  grid-template-columns: var(--table-columns);
  border-bottom: 1px solid var(--color-border-default);
  background-color: var(--table-header-bg);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  align-items: center;
  color: var(--color-text-primary);
  position: sticky;
  top: 0;
  left: 0;
  z-index: 10;
  border-top-left-radius: var(--border-radius);
  border-top-right-radius: var(--border-radius);
}
.table__header-item {
  padding: 1em 1em;
}
.table__header-item--file {
  padding: 0.5em;
}
.table__header-item--file::before {
  content: "";
  display: block;
  mask: var(--icon-image) center/contain no-repeat;
  background-color: var(--color-text-primary);
  width: 1.2em;
  aspect-ratio: 1/1;
  z-index: 2;
}
.table__row {
  --row-text-color: var(--color-text-secondary);
  --row-text-color-hover: var(--color-text-primary);
  --row-background-color: var(--table-bg);
  --row-background-color-hover: var(--color-surface-hover);
  --row-border-color: var(--color-border-default);
  --row-controls-opacity: 0;
  --row-controls-transform: translateY(calc(-100% + 0.5em));
  display: grid;
  grid-template-columns: var(--table-columns);
  align-items: center;
  transition: var(--transition);
  color: var(--row-text-color);
  background-color: var(--row-background-color);
}
.table__row.closed {
  --row-text-color: var(--color-success);
  --row-text-color-hover: var(--color-success);
  --row-background-color: var(--color-success-bg);
  --row-background-color-hover: var(--color-success-bg-hover);
  --row-border-color: var(--color-success-border);
}
.table__row:not(:last-child) {
  border-bottom: 1px solid var(--row-border-color);
}
.table__row:hover {
  --row-controls-opacity: 1;
  --row-controls-transform: translateY(-100%);
  --row-text-color: var(--row-text-color-hover);
  background-color: var(--row-background-color-hover);
  z-index: 20;
}
.table__row-item {
  padding: 0.8em 1em;
  word-wrap: break-word;
}
.table__row-item--actions {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
}
.table__nothing-found {
  padding: 2em;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1em;
  max-width: 44em;
  border: 2px dashed var(--color-border);
  border-radius: var(--border-radius);
  margin: var(--gap) auto;
  background-color: var(--color-gray-0);
}
.table__nothing-found-text {
  font-size: var(--font-size-16);
  color: var(--color-main);
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
}
.table__nothing-found-text::before {
  content: "";
  width: 2em;
  height: 2em;
  aspect-ratio: 1/1;
  background-color: var(--color-error);
  mask: var(--icon-error) center/contain no-repeat;
  display: block;
  margin: 0 auto 1em auto;
  opacity: 0.5;
}
.table__image-badge {
  width: 1.2em;
  aspect-ratio: 1/1;
}
.table__image-badge::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  mask: var(--icon-image) center/contain no-repeat;
  background-color: var(--color-text-primary);
}
.table__image-badge-count {
  position: absolute;
  top: -0.6em;
  right: -0.6em;
  background-color: var(--color-primary);
  color: var(--palette-white);
  font-size: var(--font-size-10);
  font-weight: var(--font-weight-semibold);
  padding: 0.1em 0.4em;
  border-radius: var(--border-radius-smaller);
  z-index: 2;
}
.table__image-badge-link {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
}
@media screen and (max-width: 1400px) {
  .table__header {
    font-size: var(--font-size-11);
  }
}

.entry-controls__menu {
  border-radius: var(--border-radius-smaller);
  transition: var(--transition);
  opacity: var(--row-controls-opacity);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  z-index: 99;
  background-color: var(--color-surface);
  transform: var(--row-controls-transform);
  padding: 0.6em;
  box-shadow: var(--shadow);
}
.entry-controls__item {
  --controller-color: var(--color-info);
  --controller-background-color: var(--color-info-rgb);
  padding: 0.6em 0.8em;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 0.4em;
  background-color: rgba(var(--controller-background-color), 0.05);
  border-radius: var(--border-radius-smaller);
  transition: var(--transition);
  border: 1px solid rgba(var(--controller-background-color), 0.15);
}
.entry-controls__item::before {
  content: "";
  display: block;
  width: 1.2em;
  aspect-ratio: 1/1;
  mask: var(--icon-controller) center/contain no-repeat;
  background-color: var(--controller-color);
  margin: 0 auto;
  transition: var(--transition);
}
.entry-controls__item:hover {
  background-color: rgba(var(--controller-background-color), 0.1);
}
.entry-controls__item--edit {
  --icon-controller: var(--icon-edit);
}
.entry-controls__item--duplicate {
  --icon-controller: var(--icon-duplicate);
}
.entry-controls__item--close {
  --icon-controller: var(--icon-complete);
  --controller-color: var(--color-success);
  --controller-background-color: var(--color-success-rgb);
}
.entry-controls__item--delete {
  --icon-controller: var(--icon-trash);
  --controller-color: var(--color-error);
  --controller-background-color: var(--color-error-rgb);
}
.entry-controls__text {
  color: var(--controller-color);
  transition: var(--transition);
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-12);
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1em;
  gap: 1em;
  background-color: var(--table-header-bg);
  border-bottom-left-radius: var(--border-radius);
  border-bottom-right-radius: var(--border-radius);
}
.pagination__items {
  display: flex;
  align-items: center;
  gap: 0.3em;
  flex-wrap: wrap;
  justify-content: center;
}
.pagination__item {
  display: flex;
  min-width: 2.4em;
  border-radius: var(--border-radius-smaller);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border-default);
  color: var(--color-text-primary);
  font-weight: var(--font-weight-semibold);
  transition: var(--transition);
  overflow: hidden;
  text-align: center;
}
.pagination__item a {
  color: var(--color-text-primary);
  padding: 0.4em 0.8em;
  width: 100%;
}
.pagination__item.active a, .pagination__item:hover a {
  background-color: var(--color-primary);
  color: var(--palette-white);
  border-color: var(--color-primary);
}
.pagination__item--dots {
  padding: 0.4em 0.8em;
}
.pagination__info {
  color: var(--color-text-primary);
  font-weight: var(--font-weight-medium);
}

.kanban {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 1em;
}
.kanban__nothing-found {
  padding: 2em;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1em;
  max-width: 44em;
  border: 2px dashed var(--color-border);
  border-radius: var(--border-radius);
  margin: var(--gap) auto;
  background-color: var(--color-gray-0);
}
.kanban__nothing-found-text {
  font-size: var(--font-size-16);
  color: var(--color-main);
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
}
.kanban__nothing-found-text::before {
  content: "";
  width: 2em;
  height: 2em;
  aspect-ratio: 1/1;
  background-color: var(--color-error);
  mask: var(--icon-error) center/contain no-repeat;
  display: block;
  margin: 0 auto 1em auto;
  opacity: 0.5;
}
.kanban__cards {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.kanban__card {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  padding: 1em;
  display: flex;
  flex-direction: column;
  gap: 0.25em;
  overflow: hidden;
  font-size: var(--font-size-14);
}
.kanban__card-actions {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1em;
  background-color: var(--color-surface);
  border-top: 1px solid var(--color-border-default);
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
  pointer-events: none;
  z-index: 5;
  border-bottom-left-radius: var(--border-radius-smaller);
  border-bottom-right-radius: var(--border-radius-smaller);
}
.kanban__card-actions .entry-controls {
  background: none;
}
.kanban__card-actions .entry-controls__menu {
  box-shadow: none;
  border: none;
  padding: 0;
}
.kanban__card:hover .kanban__card-actions {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.kanban__column {
  max-width: 600px;
}
.kanban__column--error {
  --column-title-background-color: rgba(var(--color-error-rgb), 0.1);
  --column-title-color: var(--color-error);
}
.kanban__column--warning {
  --column-title-background-color: rgba(var(--color-warning-rgb), 0.1);
  --column-title-color: var(--color-warning);
}
.kanban__column-title {
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  margin-bottom: 0.5em;
  color: var(--color-text-primary);
  font-size: var(--font-size-18);
  text-align: center;
  padding: 0.5em 1em;
  background-color: var(--column-title-background-color);
  color: var(--column-title-color);
  border-radius: var(--border-radius);
}
@media screen and (max-width: 960px) {
  .kanban {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  }
}

.context-menu {
  position: relative;
  --context-menu-background: var(--color-surface);
  --context-menu-border: var(--color-border-default);
  --form-input-font-size: var(--font-size-14);
}
.context-menu.active .context-menu__content {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.context-menu.active .context-menu__button, .context-menu:hover .context-menu__button {
  --button-background-color: var(--color-surface-hover);
  --button-color: var(--color-primary);
  --button-opacity: 1;
}
.context-menu__badge {
  position: absolute;
  top: -0.4em;
  right: -0.4em;
  background-color: var(--color-primary);
  font-size: var(--font-size-11);
  padding: 0.35em 0.5em 0.2em;
  border-radius: var(--border-radius-smaller);
  color: var(--palette-white);
  line-height: 1;
  z-index: 1;
}
.context-menu__button {
  --button-border-color: var(--color-border-default);
  --button-background-color: var(--color-surface);
  --button-color: var(--color-text-primary);
  --button-opacity: 0.5;
  background-color: var(--button-background-color);
  border: 1px solid var(--button-border-color);
  color: var(--button-color);
  padding: 0.6em 1em;
  border-radius: var(--border-radius);
  cursor: pointer;
  transition: var(--transition);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
}
.context-menu__button[data-is-running=true] {
  --button-color: var(--color-warning);
  --button-opacity: 1;
  --button-background-color: rgba(var(--color-warning-rgb), 0.1);
  --button-border-color: rgba(var(--color-warning-rgb), 0.2);
}
.context-menu__button::after {
  content: "";
  display: block;
  width: 0.6em;
  aspect-ratio: 1/1;
  mask: var(--icon-chevron-down) center/contain no-repeat;
  background-color: var(--button-color);
  opacity: var(--button-opacity);
  transition: var(--transition);
}
.context-menu__button-text {
  top: 0.075em;
  position: relative;
}
.context-menu__button--icon::before {
  content: "";
  width: 1.1em;
  aspect-ratio: 1/1;
  flex-shrink: 0;
  mask: var(--icon-context-menu) center/contain no-repeat;
  background-color: var(--button-color);
  opacity: var(--button-opacity);
  transition: var(--transition);
}
.context-menu__button--icon-filter {
  --icon-context-menu: var(--icon-filter-2);
}
.context-menu__button--icon-clock {
  --icon-context-menu: var(--icon-clock);
}
.context-menu__button--icon-user {
  --icon-context-menu: var(--icon-user);
}
.context-menu__timer-display {
  min-width: 4.3em;
}
.context-menu__content {
  position: absolute;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
  pointer-events: none;
  padding: 1em;
  border-radius: var(--border-radius);
  background-color: var(--context-menu-background);
  border: 1px solid var(--context-menu-border);
  box-shadow: var(--shadow);
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  min-width: 260px;
}
.context-menu__content--right {
  right: 0;
}
.context-menu__content--filter {
  min-width: 284px;
}
.context-menu__form {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
.context-menu__separator {
  height: 1px;
  background-color: var(--color-border-subtle);
  margin: 0.25em 0;
}
.context-menu__actions {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}

.color-switcher {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5em;
  --icon-size: 1.4em;
}
.color-switcher__label {
  font-size: var(--font-size-12);
  display: inline-block;
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
  line-height: 1.25em;
}
.color-switcher__items {
  background-color: var(--color-surface-secondary);
  padding: 0.2em;
  border-radius: var(--border-radius);
  display: flex;
  gap: 0.25em;
}
.color-switcher__item {
  width: var(--icon-size);
  aspect-ratio: 1/1;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  --icon-color: var(--color-text-primary);
}
.color-switcher__item::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  transition: var(--transition);
  mask: var(--switcher-icon) center/60% auto no-repeat;
  background-color: var(--icon-color);
}
.color-switcher__item--dark {
  --switcher-icon: var(--icon-theme-dark);
}
.color-switcher__item--light {
  --switcher-icon: var(--icon-theme-light);
}
.color-switcher__item:hover {
  --icon-color: var(--color-primary-hover);
}
.color-switcher__item.active {
  --icon-color: var(--color-primary);
  cursor: not-allowed;
}
.color-switcher__bar {
  position: absolute;
  width: var(--icon-size);
  aspect-ratio: 1/1;
  z-index: 1;
  top: 0.2em;
  left: 0.2em;
  border-radius: var(--border-radius-smaller);
  background-color: var(--color-surface);
  transition: var(--transition);
}

html {
  font-feature-settings: "cv02", "cv03", "cv04", "cv11";
}

body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.dark .login-form__logo {
  background-color: var(--palette-white);
}

.page-wrapper {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-wrapper__app {
  align-self: flex-start;
  width: 100%;
}
.page-wrapper__login {
  width: 100%;
}

.body-content {
  flex-grow: 1;
}

.footer {
  padding: 1em 0;
  text-align: center;
  font-size: var(--font-size-14);
}
.footer a {
  color: var(--color-primary);
}
.footer a:hover {
  text-decoration: underline;
  text-decoration-color: var(--color-text-primary);
}

.box {
  padding: calc(var(--gap) * 1.25);
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border-default);
  box-shadow: var(--shadow);
}

.login-form {
  max-width: 26em;
  margin: 0 auto;
  z-index: 5;
  width: 100%;
}
.login-form__logo {
  padding: 1em;
  border-radius: var(--border-radius);
  margin: 0 auto var(--gap) auto;
  width: clamp(160px, 10cqw, 240px);
}
.login-form__title {
  text-align: center;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-semibold);
  font-optical-sizing: auto;
  letter-spacing: var(--letter-spacing);
  font-size: var(--font-size-24);
  margin-bottom: 1em;
  color: var(--color-text-primary);
}

.user-menu {
  position: relative;
}
.user-menu:hover .user-menu__dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.user-menu__user {
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border-default);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  padding: 0.5em 0.6em;
  font-size: var(--font-size-14);
}
.user-menu__user-avatar {
  width: 2em;
  height: 2em;
  border-radius: 50%;
  mask: var(--icon-user) center/contain no-repeat;
  background-color: var(--color-text-secondary);
  opacity: 0.5;
}
.user-menu__user-name {
  font-weight: var(--font-weight-semibold);
  line-height: 1.1;
  color: var(--color-text-primary);
}
.user-menu__user-username {
  opacity: 0.75;
  font-size: var(--font-size-12);
  line-height: 1;
}
.user-menu__dropdown {
  position: absolute;
  top: calc(100% - 1px);
  right: 0;
  background-color: var(--color-surface);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  min-width: 12em;
  z-index: 10;
  transition: var(--transition);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  padding: 1em;
  gap: 0.5em;
}

.switcher {
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border-default);
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  padding: 0.5em 0.6em;
  font-size: var(--font-size-14);
}
.switcher__title {
  font-weight: var(--font-weight-semibold);
  margin-bottom: 0.2em;
}
.switcher__values {
  display: flex;
  align-items: center;
  gap: 0.5em;
}

.top-bar {
  z-index: 99;
}
.top-bar__info {
  padding: 0.75em 1em;
  background-color: var(--color-surface);
  border: 1px solid var(--color-border-default);
  text-align: center;
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-14);
  margin: 0 auto;
  background-color: var(--color-primary);
  color: var(--palette-white);
}
.top-bar__info a {
  color: var(--palette-white);
  text-decoration: underline;
}
.top-bar__info a:hover {
  text-decoration: none;
}
.top-bar__content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1em;
  padding-top: 1em;
  padding-bottom: 1em;
}
.top-bar__content-left {
  display: flex;
  align-items: center;
  gap: clamp(0.5em, 2cqw, 1.5em);
}
.top-bar__content-right {
  justify-content: flex-end;
  display: flex;
  align-items: center;
  gap: clamp(0.5em, 2cqw, 1em);
}
@media screen and (max-width: 540px) {
  .top-bar__content {
    flex-direction: column;
    align-items: center;
    gap: 0.75em;
  }
}

.drag-drop-area {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1em;
  border: 1px dashed var(--color-border-default);
  border-radius: var(--border-radius);
  cursor: pointer;
  transition: var(--transition);
  color: var(--color-text-primary);
  text-align: center;
  background-color: var(--color-surface);
}
.drag-drop-area.dragging, .drag-drop-area:hover {
  background-color: var(--color-surface-hover);
  color: var(--color-text-primary);
}
.drag-drop-area__text {
  display: flex;
  align-items: center;
  gap: 1em;
  font-size: var(--font-size-16);
}
.drag-drop-area__text::before {
  content: "";
  width: 1.2em;
  aspect-ratio: 1/1;
  mask: var(--icon-image) center/contain no-repeat;
  background-color: var(--color-text-primary);
  opacity: 0.5;
  flex-shrink: 0;
}

.timer-controls {
  min-width: 280px;
  max-width: 320px;
}
.timer-controls__status {
  display: block;
  text-align: center;
  margin-bottom: 0.75em;
}
.timer-controls__actions {
  margin-top: 0.5em;
}
.timer-controls__actions .button {
  width: 100%;
}

.note__read-more {
  color: var(--color-primary);
  text-decoration: underline;
  cursor: pointer;
}
.note__read-more:hover {
  text-decoration: none;
}

.menu {
  display: flex;
  flex-direction: column;
  gap: 0.1em;
}
.menu__item-link {
  --menu-item-text-color: var(--color-text-primary);
  --menu-item-text-color-hover: var(--color-primary);
  --menu-item-background-color: transparent;
  --menu-item-background-color-hover: var(--table-header-bg);
  --menu-item-icon-color: var(--color-text-secondary);
  --menu-item-icon-color-hover: var(--color-primary);
  display: block;
  padding: 0.6em 1em;
  border-radius: var(--border-radius);
  color: var(--menu-item-text-color);
  background-color: var(--menu-item-background-color);
  transition: var(--transition);
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-medium);
}
.menu__item-link:hover {
  background-color: var(--menu-item-background-color-hover);
  color: var(--menu-item-text-color-hover);
}
.menu__item-link:hover::before {
  background-color: var(--menu-item-icon-color-hover);
}
.menu__item-link--active {
  --menu-item-text-color: var(--palette-white);
  --menu-item-text-color-hover: var(--palette-white);
  --menu-item-background-color: var(--color-primary);
  --menu-item-background-color-hover: var(--color-primary-hover);
  --menu-item-icon-color: var(--palette-white);
  --menu-item-icon-color-hover: var(--palette-white);
}
.menu__item-link--icon {
  display: flex;
  align-items: center;
  gap: 0.75em;
}
.menu__item-link--icon::before {
  content: "";
  width: 1.2em;
  aspect-ratio: 1/1;
  background-color: var(--menu-item-icon-color);
  mask: var(--icon-menu) center/contain no-repeat;
  flex-shrink: 0;
  transition: var(--transition);
}
.menu__item-link--icon-dashboard {
  --icon-menu: var(--icon-dashboard);
}
.menu__item-link--icon-users {
  --icon-menu: var(--icon-users);
}
.menu__item-link--icon-settings {
  --icon-menu: var(--icon-settings);
}
.menu__item-link--icon-profile {
  --icon-menu: var(--icon-user);
}
.menu__item-link--icon-app {
  --icon-menu: var(--icon-table);
}
.menu__item-link--icon-absences {
  --icon-menu: var(--icon-health);
}
.menu__item-link--icon-timelog {
  --icon-menu: var(--icon-clock);
}