﻿/* general settings */
html, body {
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
html {
    font-size: 14px;
    min-height: auto;
    min-width: auto;
}
@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}
form {
    display: flex;
    gap: 0;
}

/* messages */
#message {
    position: fixed;
    font-size: 12px;
    bottom: 15px;
    right: 15px;
    max-width: 500px;
    max-height: 100px;
    padding: 10px;
    color: magenta;
    z-index: 1;
    background-color: transparent;
    overflow: auto;
    list-style: none;
    display: flex;
    flex-direction: column;
}
.message-item {
    opacity: 0.5;
}
.message-item-be {
    opacity: 0.5;
    color: red;
}

/* gantt chart */
#gantt_here {
    position: absolute;
    left: 0;
    min-width: auto;
    background-color: white;
}

/* task dragging styles */
.overlapped-task {
    box-shadow: 0 0 3px 3px red !important;
}
.edited-task {
    box-shadow: 0 0 3px 3px yellow !important;
}
.gantt_dragging_task {
    position: fixed;
    border: 2px solid black;
    opacity: 0.9;
    pointer-events: none;
    z-index: auto;
}
.gantt_dragging_task_text {
    font-size: 12px;
    overflow: visible;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: flex;
    justify-content: center;
    align-items: center;
}
.dragging_task,
.dragging_task.gantt_task_line.gantt_milestone .gantt_link_control .gantt_link_point,
.dragging_task.gantt_task_line.gantt_milestone .gantt_task_content,
.dragging_task.gantt_task_line.gantt_milestone .gantt_side_content {
    opacity: 0.1;
}
.gantt_task_progress {
    text-align: left !important;
    box-sizing: border-box;
    color: white;
    font-weight: bold;
    font-size: 12px;
}
.gantt_task_drag.task_left {
    background: url();
    width: 20px;
    left: 0px;
}
.gantt_task_drag.task_right {
    background: url();
    width: 20px;
    right: 0px;
}

/* grid versus timeline panel resize */
#resize-btn {
    background: url();
    position: absolute;
    width: 5px;
    height: 100%;
    padding: 0;
    cursor: col-resize;
    border-radius: 2.5px;
    opacity: 0.4;
    transition: border 0.3s, opacity 0.3s;
}
#resize-btn:hover {
    width: 5px;
    background-color: red;
    border: 2.5px solid #1CCCFF;
    opacity: 0.7;
}

/* scrolling over the gantt */
.scroll-indicator {
    position: absolute;
    z-index: auto;
    display: none;
    overflow: visible;
    pointer-events: none;
    margin: 0;
    background-color: transparent;
    color: red;
    font-size: 24px;
    opacity: 0.7;
    height: 1px;
    transform-origin: 100% 50%;
}
.scroll-indicator::before {
    content: "";
    width: 100%;
    height: 1px;
    position: absolute;
    top: 50%;
    left: 0;
    color: red;
    background-color: red;
}
.arrow {
    position: absolute;
    top: -2px;
    left: 0;    
    transform: translate(-50%, -50%);
    transition: transform .3s ease-in-out;
}
.custom-cursor {
    position: fixed;
    display: none;
    width: 32px;
    height: 32px;
    background-image: url(/images/icons8-navigation-32.png);
    background-repeat: no-repeat;
    pointer-events: none;
}

/* timeline cell styles */
.gantt_task_scale .gantt_scale_cell {
    cursor: default;
}
.weekend {
    background: #fff3a1;
    z-index: 1;
    opacity: 0.3;
    pointer-events: none;
}
.User_holiday {
    background: plum;
    z-index: 1;
    opacity: 0.3;
    pointer-events: none;
}
.highlighted-column {
    background-color: lightgray;
    opacity: 0.3;
}

/* task tooltip button */
#Q {
    opacity: 0.5;
    padding-left: 5px;
    font-size: 15px;
    color: white;
    cursor: help;
    border: none;
    background-color: transparent;
}

/* lightbox help button */
.button_help {
    background-image: url(/images/icons8-help-16.png);
    background-repeat: no-repeat;
    width: 20px;
    margin-right: 5px;
}

/* additional column buttons */
/*.custom_add1 {
    filter: hue-rotate(190deg);
    width: 24px;
    height: 100%;
    background-image: url();
    background-position: 50%;
    background-repeat: no-repeat;
    cursor: pointer;
    position: relative;
}
.custom_add2 {
    filter: hue-rotate(270deg);
    width: 24px;
    height: 100%;
    background-image: url();
    background-position: 50%;
    background-repeat: no-repeat;
    cursor: pointer;
    position: relative;
}*/

/* marker styles */
.marker_text {
    background-color: #ff0000 !important;
}
.gantt_marker {
    min-height: 1000px;
    height: 100%;
    opacity: 0.8;
}

/* buttons global style */
button[type='button'] {
    border: 2px solid #ddd;
    border-radius: 4px;
    color: gray;
    height: 30px;
    font-size: 14px;
    cursor: pointer;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .5), 0 1px 2px rgba(0, 0, 0, .1);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .5), 0 1px 2px rgba(0, 0, 0, .1);
}
button[type='button']:hover {
    background-color: #fafafa;
    border-color: #1CCCFF;
    color: red;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}
button[type='button']:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* mouse right click context menu */
.context-menu {
    position: absolute;
    z-index: 1;
    background: #fff;
    border: 1px solid #ccc;
    padding: 8px;
    display: none;
}
.context-menu ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}
.context-menu ul li {
    margin-bottom: 8px;
}
.context-menu ul li label {
    margin-left: 8px;
}
.context-menu li:hover {
    background-color: #ddd;
    color: red;
}

/* main menu */
#mainMenu {
    position: absolute;
    left: 0;
    width: 100%;
    text-align: left;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: gray;
}

/* main menu container */
:root {
    --menu-width: 250px;
}
.mainMenu-container {
    position: absolute;
    left: 0;
    width: var(--menu-width);
    height: 100%;
    text-align: left;
    display: flex;
    align-items: center;
    cursor: default;
    overflow: hidden;
    white-space: nowrap;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
}
.mainMenu-container:hover {
    overflow-x: auto;
}
.mainMenu-container::-webkit-scrollbar {
    height: 8px;
    width: 8px;
    border-radius: 4px;
}
.mainMenu-container::-webkit-scrollbar-thumb {
    background-color: gray;
    border-radius: 4px;
}
.mainMenu-container::-webkit-scrollbar-thumb:hover {
    background-color: dimgray;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}
.menu-list {
    display: flex;
    align-items: center;
    height: 100%;
    margin: 0;
    padding: 0;
    list-style-type: none;
}

/* main menu items */
.menu-item {
    user-select: none;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    display: inline-block;
    padding: 10px;
    cursor: pointer;
}
.menu-item:hover {
    background-color: #ddd;
    color: red;
}
.main-menu ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

/* main menu sub items */
.sub-menu {
    position: fixed;
    display: none;
    margin-left: -10px;
    min-width: 150px;
    text-align: left;
    background: #fff;
    border: 2px solid #ccc;
    color: gray;
    z-index: 1;
}
.sub-menu .sub-menu-item {
    padding: 10px;
    cursor: pointer;
}
.sub-menu .sub-menu-item:hover {
    background-color: #ddd;
    color: red;
}
.separator {
    border: none;
    border-top: 2px solid gray;
    margin: 0;
    pointer-events: none;
}
.vertical_separator {
    border-left: 1px solid lightgray;
    margin: 0;
    height: 100%;
    width: 0;
    pointer-events: none;
    margin-inline: 5px;
}
select {
    color: gray;
    width: 120px;
    height: 24px;
    border-radius: 4px;
    margin-inline: 5px;
    display: inline-flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
    background-color: transparent;
    background: url(/images/combo.ico) 85% / 15px no-repeat transparent;
}
select:hover,
#selectedConnection:hover {
    color: gray;
    background-color: #fafafa;
    border-color: #1CCCFF;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}

/* export tool */
#export {
    border: none;
    font-size: inherit;
    color: inherit;
    padding-left: 20%;
    cursor: pointer;
    background: url(/images/icons8-export-excel-48.png) 30% / 30% no-repeat transparent;
    background-position: left;
}
#export[disabled]:hover {
    cursor: not-allowed;
    border-color: initial;
    color: initial;
    -webkit-box-shadow: initial;
    box-shadow: initial;
}

/* checkbox container */
.checkbox-container {
    position: absolute;
    left: var(--menu-width);
    width: calc(100% - var(--menu-width));
    height: 100%;
    text-align: left;
    display: flex;
    align-items: center;
    cursor: default;
    overflow: hidden;
    white-space: nowrap;
    border: 1px solid gray;
    border-color: lightgray;
    align-items: center;
}
.checkbox-container:hover {
    overflow-x: auto;
}
.checkbox-container::-webkit-scrollbar {
    height: 8px;
    width: 8px;
    border-radius: 4px;
}
.checkbox-container::-webkit-scrollbar-thumb {
    background-color: gray;
    border-radius: 4px; 
}
.checkbox-container::-webkit-scrollbar-thumb:hover {
    background-color: dimgray;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}

/* filter tasks and users */
.filterboxes {
    display: flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
    height: 100%;
}
#filter_task,
#filter_user {
    width: 120px;
    height: 30px;
    margin: 1.25px;
    border-radius: 4px;
    border-color: lightgray;
    color: gray;
    background-color: transparent;
}
#filter_task:hover,
#filter_user:hover {
    background-color: #fafafa;
    border-color: #1CCCFF;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}

/* date pickers, slider and tooltip at hover */
.datepickers {
    display: flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
    height: 100%;
}
#start_date,
#end_date {
    width: 130px;
    height: 30px;
    flex-shrink: 0;
    margin: 1.25px;
    border-radius: 4px;
    border-color: lightgray;
    color: gray;
    background-color: transparent;
}
#slider {
    width: 250px;
    height: 6px;
    margin: 15px;
    flex-shrink: 0;
    display: flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
}
.current-date-marker {
    transition: color 0.3s;
}
.current-date-marker:hover {
    width: 3px;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}
#start_date:hover,
#end_date:hover,
#slider:hover {
    background-color: #fafafa;
    border-color: #1CCCFF;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}
#slider:hover .noUi-handle .noUi-tooltip {
    display: block;
}

/* Empty or split task checkboxes */
.checkboxes {
    display: flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
    height: 100%;
}
.checkbox-label {
    margin: 5px;
    opacity: 0.2;
    transition: opacity 0.3s;
    pointer-events: auto;
}
.checkbox-label:hover {
    color: red;
    opacity: 1;
}
.checkbox-input {
    margin-left: 10px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 25px;
    height: 25px;
    border: 2px solid #ccc;
    border-radius: 3px;
    outline: none;
    cursor: pointer;
    transition: border-color 0.3s;
}
#Split-Tasks {
    margin-right: 10px;
}
.checkbox-input:checked {
    border-color: #007bff;
    background-color: #007bff;
}
.checkbox-input::before {
    display: inline-block;
    width: 20px;
    height: 20px;
    background-color: #fff;
    border-radius: 2px;
    transform: translate(3px, 3px);
    transition: background-color 0.3s;
}
.checkbox-input:checked::before {
    background-color: #007bff;
}
.checkbox-input:hover {
    border-color: #1CCCFF;
    background-color: #fafafa;
    cursor: pointer;
    color: red;
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7), 0 1px 2px rgba(0, 0, 0, .3);
}
input[type="checkbox"] {
    position: relative;
    display: inline-block;
    width: 25px;
    height: 25px;
    background-color: #ddd;
    border-radius: 4px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
}
input[type="checkbox"]:checked:before {
    content: "\2713";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 16px;
    color: #fff;
}

/* zoom, home and fullscreen buttons */
.zoom-buttons {
    display: flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
    height: 100%;
}
.zoom-buttons[aria-hidden="true"] {
    user-select: none;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
}
.zoom-button {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    margin-left: 10px;
    border: none;
    background-color: transparent;
    cursor: pointer;
    transition: transform 0.3s;
}
.zoom-icon {
    font-size: 10px;
    transition: color 0.3s;
    font-weight: bold;
}
.home-button .zoom-icon {
    font-size: 16px;
    font-weight: normal;
}
.zoom-button:hover:not(.home-button) .zoom-icon {
    color: red;
    font-size: 12px;
    font-weight: normal;
}
.home-button:hover .zoom-icon {
    color: red;
    font-size: 20px;
    font-weight: normal;
}
.gantt-fullscreen {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: transparent;
    height: 100vh;
    z-index: auto;
}
.gantt-fullscreen:hover {
    background: rgba(150, 150, 150, 0.5);
    opacity: 1;
}
.fullscreen-button {
    width: 30px;
    height: 30px;
    border-radius: 4px;
    margin-inline: 10px;
    font-size: 20px;
    border: none;
    cursor: pointer;
    color: gray;
    text-align: center;
    -webkit-transition: background-color 0.5s, opacity 0.5s;
    transition: background-color 0.5s, opacity 0.5s;
}
.fullscreen-button:hover {
    background: rgba(150, 150, 150, 0.5);
    color: red;
    border: 2px solid #1CCCFF;
}
.fullscreen-button::before {
    content: "\21F2";
    display: inline-block;
}
.gantt-fullscreen .fullscreen-button::before {
    content: "\21F1";
    display: inline-block;
}

/* button container, undo - redo */
.button-container_1 {
    display: flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
    height: 100%;
}
.button-container_1 button::before {
    content: "\21BA";
    margin-right: 0px;
    font-size: 20px;    
    padding: 0;
}
.button-container_1 button:nth-child(2)::before {
    content: "\21BB";
    margin-right: 0px;
}
#undo {
    width: 30px;
    margin-left: 10px;
    padding: 0;
}
#redo {
    width: 30px;
    margin-inline: 10px;
    padding: 0;
}

/* button container, remaining tech buttons */
.button-container_2 {
    display: flex;
    border: 2px solid gray;
    border-color: lightgray;
    align-items: center;
    height: 100%;
    flex-grow: 1;
}
#ReadOnly,
#Editable,
#ClearSort,
#synch {
    margin-block: auto;
    margin-left: 5px;
}
#test {
    margin-block: auto;
    margin-left: 5px;
    margin-right: 10px;
}
#useIdOrder {
    position: relative;
    left: 5px;
    margin: 0;
    height: 30px;
    width: 10px;
    background-color: transparent;
}
#useIdOrder:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
#selectedConnection {
    width: 140px;
    height: 30px;
    margin: 1.25px;
}