diff --git a/.vscode/ftp-kr.sync.cache.json b/.vscode/ftp-kr.sync.cache.json index 90a3af1..08755bc 100644 --- a/.vscode/ftp-kr.sync.cache.json +++ b/.vscode/ftp-kr.sync.cache.json @@ -311,6 +311,16 @@ "lmtime": 0, "modified": true }, + "docs": { + "migrations": { + "2026-03-01-tasks-recursive-parent-id.sql": { + "type": "-", + "size": 542, + "lmtime": 1772360740310, + "modified": false + } + } + }, ".htaccess": { "type": "-", "size": 1055, @@ -319,8 +329,8 @@ }, "index.php": { "type": "-", - "size": 6268, - "lmtime": 1772276742587, + "size": 6563, + "lmtime": 1772386724937, "modified": false }, "layout": { @@ -634,8 +644,8 @@ }, "task_popup.php": { "type": "-", - "size": 32627, - "lmtime": 1772282729802, + "size": 36954, + "lmtime": 1772395947362, "modified": false }, "task_single.php": { @@ -786,16 +796,6 @@ "size": 230708, "lmtime": 1771920013460, "modified": false - }, - "docs": { - "migrations": { - "2026-03-01-tasks-recursive-parent-id.sql": { - "type": "-", - "size": 542, - "lmtime": 1772360740310, - "modified": false - } - } } } }, diff --git a/AGENTS.md b/AGENTS.md new file mode 100644 index 0000000..b6bf8dd --- /dev/null +++ b/AGENTS.md @@ -0,0 +1,10 @@ +# AGENTS.md + +## Sposób pracy +- Pisz do mnie po polsku, zwięźle i krótko, ale merytorycznie + +## Wprowadzanie zmian +- Przeanalizuj wprowadzone zadanie +- Jeżeli masz jakieś wątpliwości pytaj +- Przedstaw plan +- Po akceptacji wdróź plan \ No newline at end of file diff --git a/autoload/controls/class.Tasks.php b/autoload/controls/class.Tasks.php index 3c85b5e..2645971 100644 --- a/autoload/controls/class.Tasks.php +++ b/autoload/controls/class.Tasks.php @@ -458,10 +458,15 @@ class Tasks $task['id'] = isset( $task['id'] ) ? (int)$task['id'] : $task_id; $task_id_for_attachments = (int)$task['id']; + $wiki_categories = \factory\Wiki::get_categories_for_user( (int)$user['id'] ); + if ( !is_array( $wiki_categories ) or !count( $wiki_categories ) ) + $wiki_categories = \factory\Wiki::get_all_categories(); + return \Tpl::view( 'tasks/task_edit', [ 'projects' => \factory\Projects::user_projects( $user['id'] ), 'priorities' => \factory\Tasks::$priorities, 'task' => $task, + 'wiki_categories' => $wiki_categories, 'task_attachments' => $task_id_for_attachments ? $attachments_repository -> listByTaskId( $task_id_for_attachments ) : [], 'parent_tasks' => \factory\Tasks::parent_tasks( $user['id'] ), 'users' => \factory\Users::users_list(), @@ -493,6 +498,12 @@ class Tasks $values['parent_id'] = null; $values['priority'] = isset( $values['priority'] ) && $values['priority'] !== '' ? $values['priority'] : ( empty( $values['id'] ) ? 1 : 0 ); $values['recursive_last_date'] = isset( $values['recursive_last_date'] ) ? $values['recursive_last_date'] : null; + if ( isset( $values['wiki_ids'] ) ) + $values['wiki_ids'] = $values['wiki_ids']; + else if ( isset( $values['wiki_ids[]'] ) ) + $values['wiki_ids'] = $values['wiki_ids[]']; + else + $values['wiki_ids'] = []; $status = \Controllers\TasksController::resolveTaskStatusForSave( $values ); $recursive_parent_id = null; @@ -504,7 +515,7 @@ class Tasks } if ( $id = \factory\Tasks::task_save( - $values['id'], $values['parent_id'], $recursive_parent_id, $user['id'], $values['name'], $values['text'], $values['date_start'], $values['date_end'], $values['project_id'], $values['client_id'], $values['pay_rate'], $values['reminders_interval'], $values['recursively'], $values['frequency'], $values['period'], $values['users'], null, null, $values['send_email_notification'], $values['status_change_mail'], false, $status, $values['show_in_calendar'], $values['priority'], $values['recursive_last_date'] + $values['id'], $values['parent_id'], $recursive_parent_id, $user['id'], $values['name'], $values['text'], $values['date_start'], $values['date_end'], $values['project_id'], $values['client_id'], $values['pay_rate'], $values['reminders_interval'], $values['recursively'], $values['frequency'], $values['period'], $values['users'], null, null, $values['send_email_notification'], $values['status_change_mail'], false, $status, $values['show_in_calendar'], $values['priority'], $values['recursive_last_date'], $values['wiki_ids'] ) ) { \factory\Tasks::clear_task_opened( $id ); @@ -527,11 +538,16 @@ class Tasks $attachments_repository = new \Domain\Tasks\TaskAttachmentRepository(); \factory\Tasks::set_task_opened_by_user( \S::get( 'task_id' ), $user['id'] ); + $wiki_data = \factory\Tasks::task_wiki_entries_for_user( (int)\S::get( 'task_id' ), (int)$user['id'] ); echo \Tpl::view( 'tasks/task_popup', [ 'task' => \factory\Tasks::task_details( \S::get( 'task_id' ), $user['id'] ), 'task_works' => \factory\Tasks::task_works( \S::get( 'task_id' ) ), 'task_attachments' => $attachments_repository -> listByTaskId( \S::get( 'task_id' ) ), + 'task_wiki_entries' => $wiki_data['entries'], + 'task_wiki_all_count' => $wiki_data['all_count'], + 'task_wiki_visible_count' => $wiki_data['visible_count'], + 'task_wiki_hidden_count' => $wiki_data['hidden_count'], 'clients' => \factory\Crm::get_client_list(), 'user' => $user, 'statuses' => \factory\Tasks::get_statuses(), diff --git a/autoload/controls/class.Wiki.php b/autoload/controls/class.Wiki.php index 164cf77..3f11a1a 100644 --- a/autoload/controls/class.Wiki.php +++ b/autoload/controls/class.Wiki.php @@ -9,6 +9,8 @@ class Wiki if ( !$user or!\controls\Users::permissions( $user[ 'id' ], 'wiki' ) ) return false; + if ( (int)$user['id'] !== 1 and (int)$user['id'] !== 3 ) + return false; if ( \factory\Wiki::category_delete( \S::get( 'id' ) ) ) \S::alert( 'Kategoria została usunięta.' ); @@ -17,6 +19,30 @@ class Wiki exit; } + public static function categories_delete_bulk() + { + global $user; + + if ( !$user or!\controls\Users::permissions( $user[ 'id' ], 'wiki' ) ) + return false; + if ( (int)$user['id'] !== 1 and (int)$user['id'] !== 3 ) + return false; + + $ids = \S::get( 'ids' ); + if ( !is_array( $ids ) ) + $ids = []; + + $deleted_count = \factory\Wiki::categories_delete_bulk( $ids ); + + if ( $deleted_count > 0 ) + \S::alert( 'UsuniÄ™to wpisy: ' . $deleted_count . '.' ); + else + \S::alert( 'Nie wybrano poprawnych wpisĂłw do usuniÄ™cia.' ); + + header( 'Location: /wiki/main_view/' ); + exit; + } + public static function category_save() { global $user; @@ -69,4 +95,4 @@ class Wiki ] ); } -} \ No newline at end of file +} diff --git a/autoload/factory/class.Tasks.php b/autoload/factory/class.Tasks.php index dabfbff..684ae12 100644 --- a/autoload/factory/class.Tasks.php +++ b/autoload/factory/class.Tasks.php @@ -589,10 +589,123 @@ class Tasks if ( $user_id ) $task['is_open'] = self::is_task_open( $task_id, $user_id ); $task['comments'] = $mdb -> select( 'tasks_comments', '*', [ 'task_id' => $task_id, 'ORDER' => [ 'date_add' => 'DESC' ] ] ); + $task['wiki_ids'] = self::task_wiki_ids( $task_id ); return $task; } + private static function normalize_wiki_ids( $wiki_ids ) + { + if ( $wiki_ids === null or $wiki_ids === '' ) + return []; + + if ( is_string( $wiki_ids ) and strpos( $wiki_ids, ',' ) !== false ) + $wiki_ids = explode( ',', $wiki_ids ); + + if ( !is_array( $wiki_ids ) ) + $wiki_ids = [ $wiki_ids ]; + + $result = []; + foreach ( $wiki_ids as $wiki_id ) + { + $wiki_id = (int)$wiki_id; + if ( $wiki_id > 0 ) + $result[] = $wiki_id; + } + + return array_values( array_unique( $result ) ); + } + + static public function task_wiki_ids( $task_id ) + { + global $mdb; + + $task_id = (int)$task_id; + if ( !$task_id ) + return []; + + $ids = $mdb -> select( 'task_wiki', 'wiki_id', [ 'task_id' => $task_id ] ); + if ( !is_array( $ids ) ) + return []; + + return array_values( array_unique( array_map( 'intval', $ids ) ) ); + } + + static public function set_task_wiki_links( $task_id, $wiki_ids, $user_id ) + { + global $mdb; + + $task_id = (int)$task_id; + $user_id = (int)$user_id; + + if ( !$task_id or !$user_id ) + return false; + + $wiki_ids = self::normalize_wiki_ids( $wiki_ids ); + $visible_wiki_ids = []; + foreach ( $wiki_ids as $wiki_id ) + { + if ( \factory\Wiki::is_category_visible_for_user( (int)$wiki_id, $user_id ) ) + $visible_wiki_ids[] = (int)$wiki_id; + } + + $existing_ids = self::task_wiki_ids( $task_id ); + $hidden_existing_ids = []; + foreach ( $existing_ids as $existing_id ) + { + if ( !\factory\Wiki::is_category_visible_for_user( (int)$existing_id, $user_id ) ) + $hidden_existing_ids[] = (int)$existing_id; + } + + $final_ids = array_values( array_unique( array_merge( $visible_wiki_ids, $hidden_existing_ids ) ) ); + + $mdb -> delete( 'task_wiki', [ 'task_id' => $task_id ] ); + + foreach ( $final_ids as $wiki_id ) + $mdb -> insert( 'task_wiki', [ 'task_id' => $task_id, 'wiki_id' => $wiki_id ] ); + + return true; + } + + static public function task_wiki_entries_for_user( $task_id, $user_id ) + { + global $mdb; + + $task_id = (int)$task_id; + $user_id = (int)$user_id; + + $response = [ + 'all_count' => 0, + 'visible_count' => 0, + 'hidden_count' => 0, + 'entries' => [] + ]; + + if ( !$task_id or !$user_id ) + return $response; + + $response['all_count'] = (int)$mdb -> count( 'task_wiki', [ 'task_id' => $task_id ] ); + + if ( $user_id == 1 or $user_id == 3 ) + $sql = 'SELECT w.* FROM task_wiki tw INNER JOIN wiki w ON w.id = tw.wiki_id WHERE tw.task_id = ' . $task_id . ' ORDER BY w.name ASC'; + else + $sql = 'SELECT DISTINCT w.* FROM task_wiki tw ' + . 'INNER JOIN wiki w ON w.id = tw.wiki_id ' + . 'LEFT JOIN wiki_users wu ON wu.wiki_id = w.id ' + . 'WHERE tw.task_id = ' . $task_id . ' AND (wu.user_id = ' . $user_id . ' OR NOT EXISTS (SELECT 1 FROM wiki_users wu2 WHERE wu2.wiki_id = w.id)) ' + . 'ORDER BY w.name ASC'; + + $entries = $mdb -> query( $sql ) -> fetchAll( \PDO::FETCH_ASSOC ); + if ( !is_array( $entries ) ) + $entries = []; + + $response['entries'] = $entries; + $response['visible_count'] = count( $entries ); + $response['hidden_count'] = max( 0, $response['all_count'] - $response['visible_count'] ); + + return $response; + } + static public function task_total_time( $task_id, $month = '' ) { global $mdb; @@ -633,7 +746,7 @@ class Tasks } // przy zmianach pamiętać o zadaniach z CRON - static public function task_save( $task_id, $parent_id = null, $recursive_parent_id = null, $user_id, $name, $text, $date_start, $date_end, $project_id, $client_id, $pay_rate, $reminders_interval, $recursively, $frequency, $period, $users, $date_end_month_day = null, $date_start_month_day = null, $send_email_notification = false, $status_change_mail, $rescursive = false, $status = 0, $show_in_calendar, $priority = 0, $recursive_last_date = null ) + static public function task_save( $task_id, $parent_id = null, $recursive_parent_id = null, $user_id, $name, $text, $date_start, $date_end, $project_id, $client_id, $pay_rate, $reminders_interval, $recursively, $frequency, $period, $users, $date_end_month_day = null, $date_start_month_day = null, $send_email_notification = false, $status_change_mail, $rescursive = false, $status = 0, $show_in_calendar, $priority = 0, $recursive_last_date = null, $wiki_ids = [] ) { global $mdb; @@ -685,6 +798,7 @@ class Tasks \factory\Projects::send_email_notification( $id, $users ); } + self::set_task_wiki_links( $id, $wiki_ids, $user_id ); return $id; } else @@ -730,6 +844,7 @@ class Tasks } $mdb -> delete( 'tasks_reminders', [ 'task_id' => $task_id ] ); + self::set_task_wiki_links( (int)$task_id, $wiki_ids, $user_id ); return $task_id; } @@ -779,6 +894,7 @@ class Tasks $attachments_repository = new \Domain\Tasks\TaskAttachmentRepository( $mdb ); $attachments_repository -> purgeByTaskId( $task_id ); + $mdb -> delete( 'task_wiki', [ 'task_id' => (int)$task_id ] ); $mdb -> delete( 'tasks', [ 'id' => $task_id ] ); $mdb -> update( 'tasks', [ 'recursive_parent_id' => null ], [ 'recursive_parent_id' => $task_id ] ); diff --git a/autoload/factory/class.Wiki.php b/autoload/factory/class.Wiki.php index da01e20..54a680e 100644 --- a/autoload/factory/class.Wiki.php +++ b/autoload/factory/class.Wiki.php @@ -3,11 +3,47 @@ namespace factory; class Wiki { + static public function get_all_categories() + { + global $mdb; + return $mdb -> select( 'wiki', '*', [ 'ORDER' => [ 'name' => 'ASC' ] ] ); + } + static public function category_delete( int $category_id ) { global $mdb; + + $category_id = (int)$category_id; + if ( !$category_id ) + return false; + + $mdb -> delete( 'wiki_users', [ 'wiki_id' => $category_id ] ); + $mdb -> delete( 'task_wiki', [ 'wiki_id' => $category_id ] ); return $mdb -> delete( 'wiki', [ 'id' => $category_id ] ); } + static public function categories_delete_bulk( array $category_ids ) + { + global $mdb; + + $ids = []; + foreach ( $category_ids as $category_id ) + { + $category_id = (int)$category_id; + if ( $category_id > 0 ) + $ids[] = $category_id; + } + + $ids = array_values( array_unique( $ids ) ); + if ( !count( $ids ) ) + return 0; + + $mdb -> delete( 'wiki_users', [ 'wiki_id' => $ids ] ); + $mdb -> delete( 'task_wiki', [ 'wiki_id' => $ids ] ); + $mdb -> delete( 'wiki', [ 'id' => $ids ] ); + + return count( $ids ); + } + public static function category_save( $category_id, $name, $text, $text_admin = '', $users ) { global $mdb; @@ -59,9 +95,38 @@ class Wiki { global $mdb, $user; - if ( $user['id'] == 1 or $user['id'] == 3 ) + return self::get_categories_for_user( (int)$user['id'] ); + } + + static public function get_categories_for_user( int $user_id ) + { + global $mdb; + + if ( $user_id == 1 or $user_id == 3 ) return $mdb -> select( 'wiki', '*', [ 'ORDER' => [ 'name' => 'ASC' ] ] ); - else - return $mdb -> query( 'SELECT w.* FROM wiki AS w INNER JOIN wiki_users AS wu ON wu.wiki_id = w.id WHERE user_id = ' . $user['id'] ) -> fetchAll( \PDO::FETCH_ASSOC ); + + return $mdb -> query( + 'SELECT DISTINCT w.* FROM wiki AS w ' + . 'LEFT JOIN wiki_users AS wu ON wu.wiki_id = w.id ' + . 'WHERE wu.user_id = ' . $user_id . ' OR NOT EXISTS (SELECT 1 FROM wiki_users wu2 WHERE wu2.wiki_id = w.id) ' + . 'ORDER BY w.name ASC' + ) -> fetchAll( \PDO::FETCH_ASSOC ); + } + + static public function is_category_visible_for_user( int $category_id, int $user_id ): bool + { + global $mdb; + + if ( !$category_id or !$user_id ) + return false; + + if ( $user_id == 1 or $user_id == 3 ) + return (bool)$mdb -> count( 'wiki', [ 'id' => $category_id ] ); + + $visibility_rows = (int)$mdb -> count( 'wiki_users', [ 'wiki_id' => $category_id ] ); + if ( $visibility_rows === 0 ) + return (bool)$mdb -> count( 'wiki', [ 'id' => $category_id ] ); + + return (bool)$mdb -> count( 'wiki_users', [ 'AND' => [ 'wiki_id' => $category_id, 'user_id' => $user_id ] ] ); } } diff --git a/docs/migrations/2026-03-03-task-wiki-relations.sql b/docs/migrations/2026-03-03-task-wiki-relations.sql new file mode 100644 index 0000000..af9f060 --- /dev/null +++ b/docs/migrations/2026-03-03-task-wiki-relations.sql @@ -0,0 +1,10 @@ +-- 2026-03-03: relacja wiele-do-wielu zadania <-> wpisy wiki + +CREATE TABLE IF NOT EXISTS `task_wiki` ( + `task_id` INT NOT NULL, + `wiki_id` INT NOT NULL, + `date_add` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, + PRIMARY KEY (`task_id`, `wiki_id`), + KEY `idx_task_wiki_wiki` (`wiki_id`) +); + diff --git a/layout/style.css b/layout/style.css index 835b15e..2244b99 100644 --- a/layout/style.css +++ b/layout/style.css @@ -1 +1 @@ -.default-btn,.task_popup .task_details .content .right .time a:not(.time_worked_toggle),.task_popup .task_details .content .right .time a.time_worked_toggle{display:flex;align-items:center;justify-content:center;height:40px;border-radius:6px;padding:0 15px;transition:all .3s ease}.default-btn:hover,.task_popup .task_details .content .right .time a:hover:not(.time_worked_toggle),.task_popup .task_details .content .right .time a.time_worked_toggle:hover{text-decoration:none}.animate{animation:mymove 3s infinite}.text-right{text-align:right}.nowrap{white-space:nowrap}table{border-collapse:collapse;font-size:13px}small{font-size:.75em}@keyframes mymove{50%{opacity:.33}}@keyframes gradient-animation{0%{background-position:15% 0%}50%{background-position:85% 100%}100%{background-position:15% 0%}}@keyframes frame-enter{0%{clip-path:polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), 3px calc(100% - 3px), 3px 100%, 100% 100%, 100% 0%, 0% 0%)}25%{clip-path:polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) 100%, 100% 100%, 100% 0%, 0% 0%)}50%{clip-path:polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, 100% 0%, 0% 0%)}75%{-webkit-clip-path:polygon(0% 100%, 3px 100%, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 0%, 0% 0%)}100%{-webkit-clip-path:polygon(0% 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 0% 100%)}}*{box-sizing:border-box}body{font-family:"Open Sans",sans-serif;margin:0;padding:0;font-size:15px;color:#4e5e6a}.btn{padding:9px 25px;transition:all .3s ease;color:#fff;border:0;border-radius:6px;cursor:pointer;display:inline-flex;text-decoration:none;gap:5px;justify-content:center;align-items:center}.btn.btn_small,.btn.btn-xs,.btn.btn-sm{padding:5px 7px;font-size:13px}.btn.btn_small i,.btn.btn-xs i,.btn.btn-sm i{font-size:12px}.btn.btn-success{background:#099885}.btn.btn-success:hover{background:#4a9c3b}.btn.btn-primary{background:#6690f4}.btn.btn-primary:hover{background:#3164db}.btn.btn-danger{background:#cc563d}.btn.btn-danger:hover{background:#b30000}.hide{display:none}.form-error{color:#cc563d;font-size:13px}.input-group{margin-bottom:10px}.form-field{margin-bottom:15px}.form-field label{display:block;font-size:13px;font-weight:600;margin-bottom:4px;color:#4e5e6a}.password-wrap{position:relative}.password-wrap .form-control{padding-right:40px}.password-wrap .password-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#999;text-decoration:none;z-index:2}.password-wrap .password-eye:hover{color:#333}input[type=checkbox]{border:1px solid #cdcdcd}.form-control{border:1px solid #cdcdcd;border-radius:6px;height:35px;width:100%;padding:5px;font-family:"Open Sans",sans-serif}.form-control option{padding:5px}.form-control:focus{border:1px solid #6690f4;outline:none}.unlogged{background:#eef1f9;display:flex;align-items:center;justify-content:center;height:100vh}.unlogged .box-login{background:#fff;padding:25px;border-radius:6px;width:400px}.unlogged .box-login .title{text-align:center;padding:10px 10px 25px;border-bottom:1px solid #cdcdcd;font-size:20px;margin-bottom:25px}.sidebar{position:fixed;top:0;left:0;width:220px;height:100vh;background:#1e2a3a;display:flex;flex-direction:column;z-index:1000;transition:width .3s ease;overflow:hidden}.sidebar.collapsed{width:60px}.sidebar.collapsed .sidebar-header .sidebar-logo span,.sidebar.collapsed .sidebar-nav ul li a span,.sidebar.collapsed .sidebar-footer span,.sidebar.collapsed .sidebar-footer .sidebar-user span{display:none}.sidebar.collapsed .sidebar-header .sidebar-logo{font-size:0}.sidebar.collapsed .sidebar-header .sidebar-logo::first-letter{font-size:16px}.sidebar.collapsed .sidebar-nav ul li a{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-nav ul li a i{margin-right:0}.sidebar.collapsed .sidebar-nav ul li.has-submenu .submenu-arrow{display:none}.sidebar.collapsed .sidebar-nav ul li.has-submenu .sidebar-submenu{display:none}.sidebar.collapsed .sidebar-footer .sidebar-footer-link,.sidebar.collapsed .sidebar-footer .sidebar-user{justify-content:center;padding:8px 10px}.sidebar.collapsed .sidebar-footer .sidebar-footer-link i,.sidebar.collapsed .sidebar-footer .sidebar-user i{margin-right:0}.sidebar .sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:15px;border-bottom:1px solid hsla(0,0%,100%,.1)}.sidebar .sidebar-header .sidebar-logo{color:#6690f4;text-decoration:none;font-size:16px;white-space:nowrap}.sidebar .sidebar-header .sidebar-logo span{font-weight:700}.sidebar .sidebar-header .sidebar-toggle{cursor:pointer;color:#c2c7d0;font-size:16px;transition:color .2s ease}.sidebar .sidebar-header .sidebar-toggle:hover{color:#fff}.sidebar .sidebar-nav{flex:1;overflow-y:auto;padding:10px 0}.sidebar .sidebar-nav ul{list-style:none;margin:0;padding:0}.sidebar .sidebar-nav ul li a{display:flex;align-items:center;padding:10px 15px;color:#c2c7d0;text-decoration:none;font-size:14px;transition:all .2s ease;white-space:nowrap}.sidebar .sidebar-nav ul li a i{width:20px;text-align:center;margin-right:10px;font-size:15px}.sidebar .sidebar-nav ul li a:hover{background:hsla(0,0%,100%,.08);color:#fff}.sidebar .sidebar-nav ul li.active a{background:hsla(0,0%,100%,.08);color:#fff;font-weight:600}.sidebar .sidebar-nav ul li.has-submenu>a .submenu-arrow{margin-left:auto;font-size:12px;transition:transform .2s ease;width:auto}.sidebar .sidebar-nav ul li.has-submenu.open>a .submenu-arrow{transform:rotate(180deg)}.sidebar .sidebar-nav ul li.has-submenu .sidebar-submenu{max-height:0;overflow:hidden;transition:max-height .25s ease;background:rgba(0,0,0,.15)}.sidebar .sidebar-nav ul li.has-submenu .sidebar-submenu li a{padding:8px 15px 8px 45px;font-size:13px}.sidebar .sidebar-nav ul li.has-submenu .sidebar-submenu li a i{font-size:13px;width:16px}.sidebar .sidebar-nav ul li.has-submenu.open .sidebar-submenu{max-height:200px}.sidebar .sidebar-footer{border-top:1px solid hsla(0,0%,100%,.1);padding:10px 0}.sidebar .sidebar-footer .sidebar-user{display:flex;align-items:center;padding:8px 15px;color:#c2c7d0;font-size:13px;white-space:nowrap;overflow:hidden}.sidebar .sidebar-footer .sidebar-user i{margin-right:10px;color:#6690f4}.sidebar .sidebar-footer .sidebar-footer-link{display:flex;align-items:center;padding:8px 15px;color:#c2c7d0;text-decoration:none;font-size:13px;transition:all .2s ease;white-space:nowrap}.sidebar .sidebar-footer .sidebar-footer-link i{width:20px;text-align:center;margin-right:10px}.sidebar .sidebar-footer .sidebar-footer-link:hover{background:hsla(0,0%,100%,.08);color:#fff}.sidebar .sidebar-footer .sidebar-footer-link.logout{color:#cc563d}.sidebar .sidebar-footer .sidebar-footer-link.logout:hover{color:#e07a66}.content-wrapper{margin-left:220px;min-height:100vh;transition:margin-left .3s ease}.content-wrapper.expanded{margin-left:60px}.top-bar{background:#fff;border-bottom:1px solid #e8e8e8;padding:10px 20px;display:flex;align-items:center}.top-bar .top-bar-left{display:flex;align-items:center;gap:15px}.top-bar .top-bar-left i{cursor:pointer;font-size:18px;color:#4e5e6a}.top-bar .top-bar-left i:hover{color:#000}.main{padding:25px;background:#d9dee2;min-height:calc(100vh - 45px)}.tasks_container{display:grid;grid-template-columns:repeat(5, 1fr);gap:20px}.tasks_container .column{width:100%}.tasks_container .column h2{display:flex;padding:10px;background:#fff;margin-bottom:10px;font-size:15px;font-weight:300;border-radius:3px 3px 0 0;justify-content:space-between;align-items:center}.tasks_container .column h2 i{cursor:pointer}.tasks_container .column.tasks_suspended h2{border-bottom:5px solid #cc563d}.tasks_container .column.tasks_fvat h2{border-bottom:5px solid #a900fc}.tasks_container .column.tasks_new h2{border-bottom:5px solid #ccc}.tasks_container .column.tasks_bulk h2{border-bottom:5px solid #ff8c00}.tasks_container .column.tasks_to_do h2{border-bottom:5px solid #2aaf47}.tasks_container .column.tasks_to_review h2{border-bottom:5px solid #2535c9}.tasks_container .column.tasks_closed h2{border-bottom:5px solid #000}.tasks_container .column ul{list-style-type:none;margin:0;padding:0}.tasks_container .column ul .task{margin-bottom:5px;background:#fff;padding:10px;border-radius:0;display:flex;position:relative;border-radius:6px;flex-wrap:wrap}.tasks_container .column ul .task.notopened{border:2px solid #cc563d}.tasks_container .column ul .task .top{display:flex;justify-content:space-between;margin-bottom:5px;width:100%}.tasks_container .column ul .task .top ._users{display:flex;gap:5px;flex-wrap:wrap}.tasks_container .column ul .task .top ._users .user{display:flex;width:25px;height:25px;border-radius:6px;justify-content:center;align-items:center;color:#fff;font-size:12px}.tasks_container .column ul .task .top ._timer{display:flex;gap:5px}.tasks_container .column ul .task .top ._timer .recursively{color:#fff;background:#405189;border-radius:3px;cursor:pointer;margin-bottom:5px;width:25px;height:25px;text-align:center;display:block}.tasks_container .column ul .task .top ._timer .recursively i{font-size:12px}.tasks_container .column ul .task .top ._timer .task_start{display:block;background:#099885;color:#fff;border-radius:6px;cursor:pointer;margin-bottom:5px;width:25px;height:25px;text-align:center}.tasks_container .column ul .task .top ._timer .task_start.hidden{display:none}.tasks_container .column ul .task .top ._timer .task_start i{font-size:12px}.tasks_container .column ul .task .top ._timer .task_end{background:#cc563d;display:block;color:#fff;border-radius:6px;cursor:pointer;margin-bottom:5px;width:25px;height:25px;text-align:center}.tasks_container .column ul .task .top ._timer .task_end.hidden{display:none}.tasks_container .column ul .task .top ._timer .task_end i{font-size:12px}.tasks_container .column ul .task .middle{width:100%}.tasks_container .column ul .task .name{font-size:14px;color:#333;text-decoration:none;display:block;margin-bottom:5px}.tasks_container .column ul .task .bottom{display:flex;justify-content:space-between}.tasks_container .column ul .task .client_info,.tasks_container .column ul .task .current_status{font-size:12px;font-weight:400}.tasks_container .column ul .task .client_info strong,.tasks_container .column ul .task .current_status strong{font-weight:600}.tasks_container .column ul .task .current_status{position:relative;cursor:pointer}.tasks_container .column ul .task .current_status .status_change{position:absolute;left:0;top:20px;background:#fff;padding:15px;border:1px solid #dfdfdf;border-radius:3px;cursor:pointer;box-shadow:0 0 15px rgba(0,0,0,.1);z-index:99;display:none}.tasks_container .column ul .task .current_status .status_change select{width:250px;padding:10px;border:1px solid #cdcdcd;border-radius:3px}.tasks_container .column ul .task .current_status .status_change select option{font-size:15px;padding:3px}.tasks_container .column ul .task .dates{margin-bottom:5px;display:flex;justify-content:space-between;font-size:12px}.tasks_container .column ul .task .dates .danger{color:#cc563d;font-weight:600}.tasks_container .column ul .task .dates .warning{color:#ff8c00}.tasks_container .column ul .task .dates i{font-size:12px;color:#c9ced4;margin-right:5px}.block-header{margin-bottom:20px}.block-header h2{font-size:20px;font-weight:400;color:#4e5e6a;margin:0;padding-bottom:12px;border-bottom:2px solid #e2e6ec}.block-header h2 strong{font-weight:700}.filters-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:24px;padding:12px 16px;background:#f5f7fa;border-radius:8px;border:1px solid #e2e6ec}.filters-bar select,.filters-bar input[type=text],.filters-bar input[type=date],.filters-bar input[type=number]{height:36px;min-width:170px;padding:0 10px;border:1px solid #d0d5dd;border-radius:6px;background:#fff;font-size:13px;color:#4e5e6a;font-family:"Open Sans",sans-serif;transition:border-color .2s}.filters-bar select:focus,.filters-bar input[type=text]:focus,.filters-bar input[type=date]:focus,.filters-bar input[type=number]:focus{border-color:#6690f4;outline:none}.filters-bar .btn{height:36px;display:inline-flex;align-items:center;gap:5px;padding:0 14px;border-radius:6px;font-size:13px;font-weight:500;border:none;cursor:pointer;transition:background .2s,box-shadow .2s;text-decoration:none;color:#fff}.filters-bar .btn.btn-primary{background:#6690f4}.filters-bar .btn.btn-primary:hover{background:#4a74d4}.filters-bar .btn.btn-success{background:#099885}.filters-bar .btn.btn-success:hover{background:#077a6b}.section-title{font-size:14px;font-weight:600;color:#4e5e6a;margin:28px 0 12px;padding-bottom:8px;border-bottom:1px solid #e2e6ec}.action_menu{display:flex;margin-bottom:25px;gap:20px}.action_menu .btn{display:inline-flex;padding:7px 15px;color:#fff;text-decoration:none;align-items:center;justify-content:center;gap:5px}.action_menu .btn.btn_add{background:#099885}.action_menu .btn.btn_add:hover{background:#4a9c3b}.action_menu .btn.btn_cancel{background:#cc563d}.action_menu .btn.btn_cancel:hover{background:#b30000}.action_menu .btn.disabled{opacity:.5}.form_container{background:#fff;padding:25px;max-width:1300px}.form_container.full{max-width:100%}.form_container .form_group{margin-bottom:10px;display:flex}.form_container .form_group>.label{width:300px;display:inline-flex;align-items:flex-start;justify-content:right;padding-right:10px}.form_container .form_group .input{width:calc(100% - 300px)}.fullscreen_description{position:fixed !important;top:25px;left:25px;right:25px;bottom:25px;z-index:9999;background:#fff;padding:20px;overflow:auto;border-radius:.25rem;box-shadow:0 0 20px rgba(0,0,0,.3)}.fullscreen{position:absolute;top:10px;right:10px;cursor:pointer;color:#fff;background:#cc563d;display:inline-flex;height:40px;width:40px;border-radius:6px;align-items:center;justify-content:center;transition:all .3s ease}.fullscreen:hover{transform:scale(1.05);text-decoration:none}.task_popup{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:none;z-index:9999}.task_popup .task_details{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);background:#fff;padding:25px;border-radius:6px;max-width:1140px;width:100%;transition:all .3s ease;height:90vh}.task_popup .task_details .content{height:calc(100% - 50px)}.task_popup .task_details.open_works_time{max-width:1540px}.task_popup .task_details.open_works_time .content{grid-template-columns:1fr 300px 350px}.task_popup .task_details.open_works_time .content .task_work_details{display:block}.task_popup .task_details .title{font-size:20px;margin-bottom:25px;display:flex;align-items:center;gap:10px}.task_popup .task_details .title a{border:1px solid #099885;display:inline-flex;height:30px;width:30px;border-radius:6px;align-items:center;justify-content:center}.task_popup .task_details .title a:hover{text-decoration:none}.task_popup .task_details .title a i{color:#099885}.task_popup .task_details .title a.task-delete{border:1px solid #cc563d}.task_popup .task_details .title a.task-delete i{color:#cc563d}.task_popup .task_details .title a i{font-size:14px}.task_popup .task_details .close{position:absolute;top:10px;right:10px;cursor:pointer}.task_popup .task_details .content{display:grid;font-size:14px;grid-template-columns:1fr 300px;gap:30px;transition:all .3s ease}.task_popup .task_details .content h3{width:100%;margin-top:0;margin-bottom:5px;font-weight:500;color:#000;font-size:17px}.task_popup .task_details .content .left{height:100%;overflow:hidden}.task_popup .task_details .content .left .users{display:flex;gap:20px}.task_popup .task_details .content .left .users .user{display:flex;gap:10px;align-items:center;margin-bottom:10px}.task_popup .task_details .content .left .users .user .avatar{height:30px;width:30px;border-radius:6px;background:#ccc;display:flex;justify-content:center;align-items:center;color:#fff;font-size:12px}.task_popup .task_details .content .left .comments{border-radius:3px;max-height:406px;overflow-y:auto}.task_popup .task_details .content .left .comments .new_comment{margin-bottom:10px}.task_popup .task_details .content .left .comments .new_comment textarea{height:75px;margin-bottom:10px;border-radius:6px}.task_popup .task_details .content .left .comments .new_comment .add_comment{background:#099885;color:#fff;padding:10px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:200px;text-decoration:none}.task_popup .task_details .content .left .comments .new_comment .add_comment:hover{background:#4a9c3b}.task_popup .task_details .content .left .comments ul{margin:0;padding:0;list-style-type:none}.task_popup .task_details .content .left .comments ul li{background:#ced4da;margin-bottom:5px;padding:15px;border-radius:6px;position:relative}.task_popup .task_details .content .left .comments ul li .delete_comment{position:absolute;top:10px;right:10px;cursor:pointer;color:#cc563d}.task_popup .task_details .content .left .comments ul li .author{font-weight:600;margin-bottom:5px;display:inline-flex;margin-right:10px}.task_popup .task_details .content .left .comments ul li .date{font-size:12px;margin-bottom:5px;display:inline-flex}.task_popup .task_details .content .left .comments ul li .text{margin-bottom:15px;font-size:13px}.task_popup .task_details .content .left .checklist{border-radius:3px;margin-bottom:10px}.task_popup .task_details .content .left .checklist .new_element{display:flex;margin-bottom:10px}.task_popup .task_details .content .left .checklist .new_element input{border-radius:6px 0 0 6px}.task_popup .task_details .content .left .checklist .new_element a{display:flex;align-items:center;justify-content:center;padding:10px;border-radius:0 6px 6px 0;text-decoration:none;width:35px;background:#099885;color:#fff}.task_popup .task_details .content .left .checklist ul{margin:0;padding:0;list-style-type:none;overflow-y:auto;max-height:calc(90vh - 400px)}.task_popup .task_details .content .left .checklist ul li{display:flex;gap:10px;margin-bottom:5px;background:#fff;border-radius:3px;padding:10px;border:1px solid #cdcdcd;font-size:13px;align-items:flex-start}.task_popup .task_details .content .left .checklist ul li a{margin-left:auto;margin-right:0;cursor:pointer;background:#cc563d;display:flex;height:25px;width:25px;min-width:25px;justify-content:center;align-items:center;border:0;border-radius:3px;transition:all .3s ease}.task_popup .task_details .content .left .checklist ul li a:hover{text-decoration:none;background:#b30000}.task_popup .task_details .content .left .checklist ul li a i{color:#fff;font-size:12px}.task_popup .task_details .content .left .attachments{margin-top:10px;border:1px solid #e6e9ed;border-radius:8px;padding:12px;background:#f9fbfd}.task_popup .task_details .content .left .attachments h3{margin-bottom:10px;font-size:16px;font-weight:600}.task_popup .task_details .content .left .attachments .attachments_upload{display:flex;gap:10px;align-items:center;margin-bottom:10px}.task_popup .task_details .content .left .attachments .attachments_upload .attachment_file_input{flex:1;margin-bottom:0;border-radius:6px;background:#fff}.task_popup .task_details .content .left .attachments .attachments_upload .attachment-upload-btn{white-space:nowrap;border-radius:6px;min-width:150px}.task_popup .task_details .content .left .attachments .attachments_upload .attachment-upload-btn.is-loading{pointer-events:none;opacity:.85}.task_popup .task_details .content .left .attachments .attachments_upload .attachment-upload-btn.is-loading i{margin-right:6px}.task_popup .task_details .content .left .attachments .attachments_list{margin:0;padding:0;list-style:none;display:grid;gap:8px;max-height:180px;overflow-y:auto}.task_popup .task_details .content .left .attachments .attachments_list li{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e4e8ee;border-radius:6px;padding:8px 10px}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-link{color:#1f3d72;text-decoration:none;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 140px)}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-link:hover{text-decoration:underline}.task_popup .task_details .content .left .attachments .attachments_list li small{color:#6b7280;margin-right:auto}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-rename,.task_popup .task_details .content .left .attachments .attachments_list li .attachment-delete{display:inline-flex;align-items:center;justify-content:center;height:28px;width:28px;border-radius:4px;text-decoration:none;transition:all .2s ease}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-rename{border:1px solid #d8e2f6;color:#6690f4;background:#f4f8ff}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-rename:hover{background:#e7f0ff}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-delete{border:1px solid #f1d3d1;color:#cc563d;background:#fff6f6}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-delete:hover{background:#ffeaea}.task_popup .task_details .content .left .attachments .attachments_list .attachments-empty{color:#6b7280;border-style:dashed;justify-content:center;font-size:13px}.task_popup .task_details .content .left .description{padding:15px;border-radius:.25rem;border:1px solid #cdcdcd;margin-bottom:15px;max-height:202px;overflow-x:hidden;position:relative}.task_popup .task_details .content .right .box{margin-bottom:15px}.task_popup .task_details .content .right .time a.time_worked_toggle{color:#299cdb;display:inline-flex;border:1px solid #299cdb}.task_popup .task_details .content .right .time a.time_worked_toggle:hover{background:#dff0fa;text-decoration:none}.task_popup .task_details .content .right .time a.time_worked_toggle:active,.task_popup .task_details .content .right .time a.time_worked_toggle:focus{text-decoration:none}.task_popup .task_details .content .right .time a:not(.time_worked_toggle){margin-top:10px;text-decoration:none;gap:10px}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).task_start{background:#0ab39c;color:#fff}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).task_start:hover{background:#099885}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).task_end{background:#cc563d;color:#fff}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).hidden{display:none}.task_popup .task_details .content .right .dates{display:flex;justify-content:space-between;flex-wrap:wrap}.task_popup .task_details .content .right .dates .danger{color:#cc563d;font-weight:600}.task_popup .task_details .content .right .dates .warning{color:#ff8c00}.task_popup .task_details .content .right .dates i{color:#c9ced4;margin-right:5px}.task_popup .task_details .content .task_work_details{display:none;overflow-y:auto;max-height:508px;width:100%;padding-right:10px;padding-top:4px}.task_popup .task_details .content .task_work_details ._line{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:5px}.task_popup .task_details .content .task_work_details ._line ._user{width:100%;font-size:13px}.task_popup .task_details .content .task_work_details ._line input{width:calc(50% - 25px);text-align:center;margin-left:2px;margin-right:2px}.task_popup .task_details .content .task_work_details ._work_delete{display:inline-flex;height:35px;width:35px;border-radius:6px;align-items:center;justify-content:center;cursor:pointer;border:1px solid #cc563d;margin-left:2px;transition:all .3s ease}.task_popup .task_details .content .task_work_details ._work_delete:hover{background:#cc563d}.task_popup .task_details .content .task_work_details ._work_delete:hover i{color:#fff}.task_popup .task_details .content .task_work_details ._work_delete i{transition:all .3s ease;color:#cc563d}.table{width:100%;border:none;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06);background:#fff}.table th,.table td{padding:10px 14px;border:none;border-bottom:1px solid #eef0f3;text-align:left;vertical-align:middle}.table thead th{background:#f5f7fa;color:#4e5e6a;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border-bottom:2px solid #e2e6ec}.table tbody tr{transition:background .15s ease}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#f8fafd}.table td.center,.table th.center{text-align:center}.table td.left,.table th.left{text-align:left}.table td.right,.table th.right{text-align:right}.table td[colspan]{text-align:center;color:#8896a4;padding:24px 14px;font-style:italic}.projects_container{background:#fff;padding:15px;border-radius:6px;display:flex;gap:20px}.projects_container .left{width:calc(100% - 250px)}.projects_container .left ._projects,.projects_container .left ._users{display:flex;gap:20px;flex-wrap:wrap}.projects_container .right{width:250px;display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:center;gap:20px;border-left:1px solid #cdcdcd;padding-left:15px}.projects_container .right select{width:200px}.default_popup{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:none}.default_popup .popup_content{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);background:#fff;padding:25px;border-radius:0;max-width:1140px;width:100%}.default_popup .popup_content .close{position:absolute;top:10px;right:10px;cursor:pointer}#fg-cron{margin:10px 0}#fg-cron .countdown{background:#099885;color:#fff;padding:10px}#fg-cron #cron-container{max-height:300px;overflow-x:hidden;overflow-y:auto}#fg-cron #cron-container .msg{font-size:13px;padding:5px;border-bottom:1px solid #e8e8e8}.card{background:#fff;padding:25px;border-radius:6px;color:#000;font-size:15px;max-width:1280px}.card.mb25{margin-bottom:25px}.card .card-header{font-weight:600}.card .card-body{padding-top:10px}.card .card-body table{border-collapse:collapse}.card .card-body table th,.card .card-body table td{font-size:14px}.card .card-body table th.bold,.card .card-body table td.bold{font-weight:600}.card .card-body table th.text-right,.card .card-body table td.text-right{text-align:right}.card .card-body table th.text-center,.card .card-body table td.text-center{text-align:center}.card .card-body table th .close-task,.card .card-body table td .close-task{text-decoration:none;color:#6690f4}.card .card-body table th .close-task:hover,.card .card-body table td .close-task:hover{color:#cc563d}.finance-summary{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px}.finance-summary .panel{background:#fff;border-radius:6px;padding:15px}.finance-summary .panel h1{font-size:20px;margin:0}.finance-summary .panel span{font-size:.85em}.finance-manager{display:grid;gap:10px;grid-template-columns:200px 1fr 500px;padding-top:25px}.finance-manager .manage-menu{display:inline-block;margin-right:10px}.finance-manager .manage-menu a{color:#333;text-decoration:none;font-weight:300;display:block}.finance-manager .actions{width:100px;text-align:center}.finance-manager .actions a{display:inline-flex;margin:0 2px;height:25px;width:25px;align-items:center;justify-content:center;text-decoration:none;color:#000;border:1px solid #e7e7e7;font-size:11px;border-radius:3px;transition:all .3s ease}.finance-manager .actions a:hover{border:1px solid #6690f4}.bootstrap-tagsinput .tag{background:#6690f4;font-size:13px;padding:5px 10px;border-radius:12px}.bootstrap-tagsinput .tag [data-role=remove]{color:#fff !important}.bootstrap-tagsinput .tag [data-role=remove]:hover{box-shadow:none !important;color:#000 !important}.finance-tags{display:flex;flex-wrap:wrap;gap:5px}.finance-tags a:not(.btn){display:flex;width:100%;text-decoration:none;color:#4e5e6a}.finance-tags a:not(.btn).zoom-100{font-size:1.2em}.finance-tags a:not(.btn).zoom-90{font-size:1.15em}.finance-tags a:not(.btn).zoom-80{font-size:1.1em}.finance-tags a:not(.btn).zoom-70{font-size:1.05em}.finance-tags a:not(.btn).zoom-60{font-size:1em}.finance-tags a:not(.btn).zoom-50{font-size:.95em}.finance-tags a:not(.btn).zoom-40{font-size:.9em}.finance-tags a:not(.btn).zoom-30{font-size:.85em}.finance-tags a:not(.btn).zoom-20{font-size:.8em}.finance-tags a:not(.btn).zoom-10{font-size:.75em}.finance-tags a:not(.btn).zoom-0{font-size:.7em}.manage-menu{position:relative}.manage-menu .context-menu{border-left:4px dotted #000;width:1px;height:100%}.manage-menu .context-menu-container{position:absolute;display:none;background:#fff;box-shadow:5px 5px 15px rgba(0,0,0,.1);top:2px;left:2px}.manage-menu .context-menu-container ul{list-style-type:none;margin:0;padding:0}.manage-menu .context-menu-container ul li a{display:block;padding:7px 15px;white-space:nowrap}.manage-menu .context-menu-container ul li a:hover{background:#f8f8f8}.manage-menu:hover .context-menu-container{display:block}.wiki-categories{display:grid;gap:10px;margin-top:25px;grid-template-columns:1fr 1fr 1fr 1fr}.wiki-categories .category{background:#fff;padding:10px}.wiki-categories .category .users{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:5px}.wiki-categories .category .users .user{display:flex;height:25px;width:25px;border-radius:50%;background:#ccc;justify-content:center;align-items:center;color:#fff;font-size:12px}.wiki-categories .category .actions{display:grid;grid-template-columns:1fr 1fr}.wiki-categories .category .actions a{display:block;color:#4e5e6a;font-size:13px;text-align:center}.wiki-categories .category .title{margin-bottom:5px}.wiki-categories .category .title a{display:block;color:#4e5e6a;font-size:13px;font-weight:600}.bootstrap-datetimepicker-widget .picker-switch a{display:block;color:#000}.gantt_users{display:flex;gap:20px}#g-results{background:#fff;padding:25px}.g-menu-container{margin-bottom:15px}.g-menu-container .right-menu{display:none}.g-center{text-align:center}.alert{background:#099885;border:0;color:#fff}.tasks_main_view{display:flex;gap:20px}.tasks_main_view ._left_column{padding:25px;background:#fcfcfc;border-right:1px solid #e8e8e8;width:350px}.tasks_main_view ._left_column label{font-weight:400;font-size:14px}.tasks_main_view ._left_column select[name=filtr]{margin-bottom:10px}.tasks_main_view ._left_column ._buttons{display:flex;gap:10px;justify-content:space-between}.tasks_main_view ._left_column ._buttons .btn{flex:1}.tasks_main_view ._right_column{flex:1;max-width:calc(100% - 350px)}#billing-summary .card-header{padding:10px}#billing-summary .billing-kpi{border:1px solid #dee2e6;border-radius:6px;padding:10px 12px;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.04)}#billing-summary .billing-kpi-label{font-size:12px;color:#6c757d;margin-bottom:3px}#billing-summary .billing-kpi-value{font-size:21px;font-weight:700;line-height:1.1}#billing-summary .billing-details-row{display:none}#billing-summary .billing-client-name{font-weight:600}#billing-summary .billing-table>thead>tr>th{background:#f8f9fa}#billing-summary .billing-details-wrap{background:#f8fbff}.vacation-type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500;background:#e3f0ff;color:#2563eb}.vacation-type-badge.type-chorobowe{background:#fff3e0;color:#e65100}.vacation-type-badge.type-inna_nieobecnosc{background:#f3e5f5;color:#7b1fa2}/*# sourceMappingURL=style.css.map */ \ No newline at end of file +.default-btn,.task_popup .task_details .content .right .time a:not(.time_worked_toggle),.task_popup .task_details .content .right .time a.time_worked_toggle{display:flex;align-items:center;justify-content:center;height:40px;border-radius:6px;padding:0 15px;transition:all .3s ease}.default-btn:hover,.task_popup .task_details .content .right .time a:hover:not(.time_worked_toggle),.task_popup .task_details .content .right .time a.time_worked_toggle:hover{text-decoration:none}.animate{animation:mymove 3s infinite}.text-right{text-align:right}.nowrap{white-space:nowrap}table{border-collapse:collapse;font-size:13px}small{font-size:.75em}@keyframes mymove{50%{opacity:.33}}@keyframes gradient-animation{0%{background-position:15% 0%}50%{background-position:85% 100%}100%{background-position:15% 0%}}@keyframes frame-enter{0%{clip-path:polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), 3px calc(100% - 3px), 3px 100%, 100% 100%, 100% 0%, 0% 0%)}25%{clip-path:polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) 100%, 100% 100%, 100% 0%, 0% 0%)}50%{clip-path:polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, 100% 0%, 0% 0%)}75%{-webkit-clip-path:polygon(0% 100%, 3px 100%, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 0%, 0% 0%)}100%{-webkit-clip-path:polygon(0% 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 0% 100%)}}*{box-sizing:border-box}body{font-family:"Open Sans",sans-serif;margin:0;padding:0;font-size:15px;color:#4e5e6a}.btn{padding:9px 25px;transition:all .3s ease;color:#fff;border:0;border-radius:6px;cursor:pointer;display:inline-flex;text-decoration:none;gap:5px;justify-content:center;align-items:center}.btn.btn_small,.btn.btn-xs,.btn.btn-sm{padding:5px 7px;font-size:13px}.btn.btn_small i,.btn.btn-xs i,.btn.btn-sm i{font-size:12px}.btn.btn-success{background:#099885}.btn.btn-success:hover{background:#4a9c3b}.btn.btn-primary{background:#6690f4}.btn.btn-primary:hover{background:#3164db}.btn.btn-danger{background:#cc563d}.btn.btn-danger:hover{background:#b30000}.hide{display:none}.form-error{color:#cc563d;font-size:13px}.input-group{margin-bottom:10px}.form-field{margin-bottom:15px}.form-field label{display:block;font-size:13px;font-weight:600;margin-bottom:4px;color:#4e5e6a}.password-wrap{position:relative}.password-wrap .form-control{padding-right:40px}.password-wrap .password-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#999;text-decoration:none;z-index:2}.password-wrap .password-eye:hover{color:#333}input[type=checkbox]{border:1px solid #cdcdcd}.form-control{border:1px solid #cdcdcd;border-radius:6px;height:35px;width:100%;padding:5px;font-family:"Open Sans",sans-serif}.form-control option{padding:5px}.form-control:focus{border:1px solid #6690f4;outline:none}.unlogged{background:#eef1f9;display:flex;align-items:center;justify-content:center;height:100vh}.unlogged .box-login{background:#fff;padding:25px;border-radius:6px;width:400px}.unlogged .box-login .title{text-align:center;padding:10px 10px 25px;border-bottom:1px solid #cdcdcd;font-size:20px;margin-bottom:25px}.sidebar{position:fixed;top:0;left:0;width:220px;height:100vh;background:#1e2a3a;display:flex;flex-direction:column;z-index:1000;transition:width .3s ease;overflow:hidden}.sidebar.collapsed{width:60px}.sidebar.collapsed .sidebar-header .sidebar-logo span,.sidebar.collapsed .sidebar-nav ul li a span,.sidebar.collapsed .sidebar-footer span,.sidebar.collapsed .sidebar-footer .sidebar-user span{display:none}.sidebar.collapsed .sidebar-header .sidebar-logo{font-size:0}.sidebar.collapsed .sidebar-header .sidebar-logo::first-letter{font-size:16px}.sidebar.collapsed .sidebar-nav ul li a{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-nav ul li a i{margin-right:0}.sidebar.collapsed .sidebar-nav ul li.has-submenu .submenu-arrow{display:none}.sidebar.collapsed .sidebar-nav ul li.has-submenu .sidebar-submenu{display:none}.sidebar.collapsed .sidebar-footer .sidebar-footer-link,.sidebar.collapsed .sidebar-footer .sidebar-user{justify-content:center;padding:8px 10px}.sidebar.collapsed .sidebar-footer .sidebar-footer-link i,.sidebar.collapsed .sidebar-footer .sidebar-user i{margin-right:0}.sidebar .sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:15px;border-bottom:1px solid hsla(0,0%,100%,.1)}.sidebar .sidebar-header .sidebar-logo{color:#6690f4;text-decoration:none;font-size:16px;white-space:nowrap}.sidebar .sidebar-header .sidebar-logo span{font-weight:700}.sidebar .sidebar-header .sidebar-toggle{cursor:pointer;color:#c2c7d0;font-size:16px;transition:color .2s ease}.sidebar .sidebar-header .sidebar-toggle:hover{color:#fff}.sidebar .sidebar-nav{flex:1;overflow-y:auto;padding:10px 0}.sidebar .sidebar-nav ul{list-style:none;margin:0;padding:0}.sidebar .sidebar-nav ul li a{display:flex;align-items:center;padding:10px 15px;color:#c2c7d0;text-decoration:none;font-size:14px;transition:all .2s ease;white-space:nowrap}.sidebar .sidebar-nav ul li a i{width:20px;text-align:center;margin-right:10px;font-size:15px}.sidebar .sidebar-nav ul li a:hover{background:hsla(0,0%,100%,.08);color:#fff}.sidebar .sidebar-nav ul li.active a{background:hsla(0,0%,100%,.08);color:#fff;font-weight:600}.sidebar .sidebar-nav ul li.has-submenu>a .submenu-arrow{margin-left:auto;font-size:12px;transition:transform .2s ease;width:auto}.sidebar .sidebar-nav ul li.has-submenu.open>a .submenu-arrow{transform:rotate(180deg)}.sidebar .sidebar-nav ul li.has-submenu .sidebar-submenu{max-height:0;overflow:hidden;transition:max-height .25s ease;background:rgba(0,0,0,.15)}.sidebar .sidebar-nav ul li.has-submenu .sidebar-submenu li a{padding:8px 15px 8px 45px;font-size:13px}.sidebar .sidebar-nav ul li.has-submenu .sidebar-submenu li a i{font-size:13px;width:16px}.sidebar .sidebar-nav ul li.has-submenu.open .sidebar-submenu{max-height:200px}.sidebar .sidebar-footer{border-top:1px solid hsla(0,0%,100%,.1);padding:10px 0}.sidebar .sidebar-footer .sidebar-user{display:flex;align-items:center;padding:8px 15px;color:#c2c7d0;font-size:13px;white-space:nowrap;overflow:hidden}.sidebar .sidebar-footer .sidebar-user i{margin-right:10px;color:#6690f4}.sidebar .sidebar-footer .sidebar-footer-link{display:flex;align-items:center;padding:8px 15px;color:#c2c7d0;text-decoration:none;font-size:13px;transition:all .2s ease;white-space:nowrap}.sidebar .sidebar-footer .sidebar-footer-link i{width:20px;text-align:center;margin-right:10px}.sidebar .sidebar-footer .sidebar-footer-link:hover{background:hsla(0,0%,100%,.08);color:#fff}.sidebar .sidebar-footer .sidebar-footer-link.logout{color:#cc563d}.sidebar .sidebar-footer .sidebar-footer-link.logout:hover{color:#e07a66}.content-wrapper{margin-left:220px;min-height:100vh;transition:margin-left .3s ease}.content-wrapper.expanded{margin-left:60px}.top-bar{background:#fff;border-bottom:1px solid #e8e8e8;padding:10px 20px;display:flex;align-items:center}.top-bar .top-bar-left{display:flex;align-items:center;gap:15px}.top-bar .top-bar-left i{cursor:pointer;font-size:18px;color:#4e5e6a}.top-bar .top-bar-left i:hover{color:#000}.main{padding:25px;background:#d9dee2;min-height:calc(100vh - 45px)}.tasks_container{display:grid;grid-template-columns:repeat(5, 1fr);gap:20px}.tasks_container .column{width:100%}.tasks_container .column h2{display:flex;padding:10px;background:#fff;margin-bottom:10px;font-size:15px;font-weight:300;border-radius:3px 3px 0 0;justify-content:space-between;align-items:center}.tasks_container .column h2 i{cursor:pointer}.tasks_container .column.tasks_suspended h2{border-bottom:5px solid #cc563d}.tasks_container .column.tasks_fvat h2{border-bottom:5px solid #a900fc}.tasks_container .column.tasks_new h2{border-bottom:5px solid #ccc}.tasks_container .column.tasks_bulk h2{border-bottom:5px solid #ff8c00}.tasks_container .column.tasks_to_do h2{border-bottom:5px solid #2aaf47}.tasks_container .column.tasks_to_review h2{border-bottom:5px solid #2535c9}.tasks_container .column.tasks_closed h2{border-bottom:5px solid #000}.tasks_container .column ul{list-style-type:none;margin:0;padding:0}.tasks_container .column ul .task{margin-bottom:5px;background:#fff;padding:10px;border-radius:0;display:flex;position:relative;border-radius:6px;flex-wrap:wrap}.tasks_container .column ul .task.notopened{border:2px solid #cc563d}.tasks_container .column ul .task .top{display:flex;justify-content:space-between;margin-bottom:5px;width:100%}.tasks_container .column ul .task .top ._users{display:flex;gap:5px;flex-wrap:wrap}.tasks_container .column ul .task .top ._users .user{display:flex;width:25px;height:25px;border-radius:6px;justify-content:center;align-items:center;color:#fff;font-size:12px}.tasks_container .column ul .task .top ._timer{display:flex;gap:5px}.tasks_container .column ul .task .top ._timer .recursively{color:#fff;background:#405189;border-radius:3px;cursor:pointer;margin-bottom:5px;width:25px;height:25px;text-align:center;display:block}.tasks_container .column ul .task .top ._timer .recursively i{font-size:12px}.tasks_container .column ul .task .top ._timer .task_start{display:block;background:#099885;color:#fff;border-radius:6px;cursor:pointer;margin-bottom:5px;width:25px;height:25px;text-align:center}.tasks_container .column ul .task .top ._timer .task_start.hidden{display:none}.tasks_container .column ul .task .top ._timer .task_start i{font-size:12px}.tasks_container .column ul .task .top ._timer .task_end{background:#cc563d;display:block;color:#fff;border-radius:6px;cursor:pointer;margin-bottom:5px;width:25px;height:25px;text-align:center}.tasks_container .column ul .task .top ._timer .task_end.hidden{display:none}.tasks_container .column ul .task .top ._timer .task_end i{font-size:12px}.tasks_container .column ul .task .middle{width:100%}.tasks_container .column ul .task .name{font-size:14px;color:#333;text-decoration:none;display:block;margin-bottom:5px}.tasks_container .column ul .task .bottom{display:flex;justify-content:space-between}.tasks_container .column ul .task .client_info,.tasks_container .column ul .task .current_status{font-size:12px;font-weight:400}.tasks_container .column ul .task .client_info strong,.tasks_container .column ul .task .current_status strong{font-weight:600}.tasks_container .column ul .task .current_status{position:relative;cursor:pointer}.tasks_container .column ul .task .current_status .status_change{position:absolute;left:0;top:20px;background:#fff;padding:15px;border:1px solid #dfdfdf;border-radius:3px;cursor:pointer;box-shadow:0 0 15px rgba(0,0,0,.1);z-index:99;display:none}.tasks_container .column ul .task .current_status .status_change select{width:250px;padding:10px;border:1px solid #cdcdcd;border-radius:3px}.tasks_container .column ul .task .current_status .status_change select option{font-size:15px;padding:3px}.tasks_container .column ul .task .dates{margin-bottom:5px;display:flex;justify-content:space-between;font-size:12px}.tasks_container .column ul .task .dates .danger{color:#cc563d;font-weight:600}.tasks_container .column ul .task .dates .warning{color:#ff8c00}.tasks_container .column ul .task .dates i{font-size:12px;color:#c9ced4;margin-right:5px}.block-header{margin-bottom:20px}.block-header h2{font-size:20px;font-weight:400;color:#4e5e6a;margin:0;padding-bottom:12px;border-bottom:2px solid #e2e6ec}.block-header h2 strong{font-weight:700}.filters-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:24px;padding:12px 16px;background:#f5f7fa;border-radius:8px;border:1px solid #e2e6ec}.filters-bar select,.filters-bar input[type=text],.filters-bar input[type=date],.filters-bar input[type=number]{height:36px;min-width:170px;padding:0 10px;border:1px solid #d0d5dd;border-radius:6px;background:#fff;font-size:13px;color:#4e5e6a;font-family:"Open Sans",sans-serif;transition:border-color .2s}.filters-bar select:focus,.filters-bar input[type=text]:focus,.filters-bar input[type=date]:focus,.filters-bar input[type=number]:focus{border-color:#6690f4;outline:none}.filters-bar .btn{height:36px;display:inline-flex;align-items:center;gap:5px;padding:0 14px;border-radius:6px;font-size:13px;font-weight:500;border:none;cursor:pointer;transition:background .2s,box-shadow .2s;text-decoration:none;color:#fff}.filters-bar .btn.btn-primary{background:#6690f4}.filters-bar .btn.btn-primary:hover{background:#4a74d4}.filters-bar .btn.btn-success{background:#099885}.filters-bar .btn.btn-success:hover{background:#077a6b}.section-title{font-size:14px;font-weight:600;color:#4e5e6a;margin:28px 0 12px;padding-bottom:8px;border-bottom:1px solid #e2e6ec}.action_menu{display:flex;margin-bottom:25px;gap:20px}.action_menu .btn{display:inline-flex;padding:7px 15px;color:#fff;text-decoration:none;align-items:center;justify-content:center;gap:5px}.action_menu .btn.btn_add{background:#099885}.action_menu .btn.btn_add:hover{background:#4a9c3b}.action_menu .btn.btn_cancel{background:#cc563d}.action_menu .btn.btn_cancel:hover{background:#b30000}.action_menu .btn.disabled{opacity:.5}.form_container{background:#fff;padding:25px;max-width:1300px}.form_container.full{max-width:100%}.form_container .form_group{margin-bottom:10px;display:flex}.form_container .form_group>.label{width:300px;display:inline-flex;align-items:flex-start;justify-content:right;padding-right:10px}.form_container .form_group .input{width:calc(100% - 300px)}.fullscreen_description{position:fixed !important;top:25px;left:25px;right:25px;bottom:25px;z-index:9999;background:#fff;padding:20px;overflow:auto;border-radius:.25rem;box-shadow:0 0 20px rgba(0,0,0,.3)}.fullscreen{position:absolute;top:10px;right:10px;cursor:pointer;color:#fff;background:#cc563d;display:inline-flex;height:40px;width:40px;border-radius:6px;align-items:center;justify-content:center;transition:all .3s ease}.fullscreen:hover{transform:scale(1.05);text-decoration:none}.task_popup{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:none;z-index:9999}.task_popup .task_details{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);background:#fff;padding:25px;border-radius:6px;max-width:1140px;width:100%;transition:all .3s ease;height:90vh}.task_popup .task_details .content{height:calc(100% - 50px)}.task_popup .task_details.open_works_time{max-width:1540px}.task_popup .task_details.open_works_time .content{grid-template-columns:1fr 300px 350px}.task_popup .task_details.open_works_time .content .task_work_details{display:block}.task_popup .task_details .title{font-size:20px;margin-bottom:25px;display:flex;align-items:center;gap:10px}.task_popup .task_details .title a{border:1px solid #099885;display:inline-flex;height:30px;width:30px;border-radius:6px;align-items:center;justify-content:center}.task_popup .task_details .title a:hover{text-decoration:none}.task_popup .task_details .title a i{color:#099885}.task_popup .task_details .title a.task-delete{border:1px solid #cc563d}.task_popup .task_details .title a.task-delete i{color:#cc563d}.task_popup .task_details .title a i{font-size:14px}.task_popup .task_details .title .task-title-edit-box{align-items:center;gap:6px}.task_popup .task_details .title .task-title-edit-box .task-title-input{height:30px;font-size:14px;padding:2px 8px;width:300px;border:1px solid #ccc;border-radius:4px}.task_popup .task_details .title .task-title-edit-box a.task-title-save,.task_popup .task_details .title .task-title-edit-box a.task-title-cancel{height:30px;width:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px}.task_popup .task_details .title .task-title-edit-box a.task-title-save i,.task_popup .task_details .title .task-title-edit-box a.task-title-cancel i{font-size:13px}.task_popup .task_details .title .task-title-edit-box a.task-title-save{background:#099885;border-color:#099885}.task_popup .task_details .title .task-title-edit-box a.task-title-save i{color:#fff}.task_popup .task_details .title .task-title-edit-box a.task-title-cancel{background:#cc563d;border-color:#cc563d}.task_popup .task_details .title .task-title-edit-box a.task-title-cancel i{color:#fff}.task_popup .task_details .close{position:absolute;top:10px;right:10px;cursor:pointer}.task_popup .task_details .content{display:grid;font-size:14px;grid-template-columns:1fr 300px;gap:30px;transition:all .3s ease}.task_popup .task_details .content h3{width:100%;margin-top:0;margin-bottom:5px;font-weight:500;color:#000;font-size:17px}.task_popup .task_details .content .left{height:100%;overflow:hidden}.task_popup .task_details .content .left .users{display:flex;gap:20px}.task_popup .task_details .content .left .users .user{display:flex;gap:10px;align-items:center;margin-bottom:10px}.task_popup .task_details .content .left .users .user .avatar{height:30px;width:30px;border-radius:6px;background:#ccc;display:flex;justify-content:center;align-items:center;color:#fff;font-size:12px}.task_popup .task_details .content .left .comments{border-radius:3px;max-height:406px;overflow-y:auto}.task_popup .task_details .content .left .comments .new_comment{margin-bottom:10px}.task_popup .task_details .content .left .comments .new_comment textarea{height:75px;margin-bottom:10px;border-radius:6px}.task_popup .task_details .content .left .comments .new_comment .add_comment{background:#099885;color:#fff;padding:10px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:200px;text-decoration:none}.task_popup .task_details .content .left .comments .new_comment .add_comment:hover{background:#4a9c3b}.task_popup .task_details .content .left .comments ul{margin:0;padding:0;list-style-type:none}.task_popup .task_details .content .left .comments ul li{background:#ced4da;margin-bottom:5px;padding:15px;border-radius:6px;position:relative}.task_popup .task_details .content .left .comments ul li .delete_comment{position:absolute;top:10px;right:10px;cursor:pointer;color:#cc563d}.task_popup .task_details .content .left .comments ul li .author{font-weight:600;margin-bottom:5px;display:inline-flex;margin-right:10px}.task_popup .task_details .content .left .comments ul li .date{font-size:12px;margin-bottom:5px;display:inline-flex}.task_popup .task_details .content .left .comments ul li .text{margin-bottom:15px;font-size:13px}.task_popup .task_details .content .left .checklist{border-radius:3px;margin-bottom:10px}.task_popup .task_details .content .left .checklist .new_element{display:flex;margin-bottom:10px}.task_popup .task_details .content .left .checklist .new_element input{border-radius:6px 0 0 6px}.task_popup .task_details .content .left .checklist .new_element a{display:flex;align-items:center;justify-content:center;padding:10px;border-radius:0 6px 6px 0;text-decoration:none;width:35px;background:#099885;color:#fff}.task_popup .task_details .content .left .checklist ul{margin:0;padding:0;list-style-type:none;overflow-y:auto;max-height:calc(90vh - 400px)}.task_popup .task_details .content .left .checklist ul li{display:flex;gap:10px;margin-bottom:5px;background:#fff;border-radius:3px;padding:10px;border:1px solid #cdcdcd;font-size:13px;align-items:flex-start}.task_popup .task_details .content .left .checklist ul li a{margin-left:auto;margin-right:0;cursor:pointer;background:#cc563d;display:flex;height:25px;width:25px;min-width:25px;justify-content:center;align-items:center;border:0;border-radius:3px;transition:all .3s ease}.task_popup .task_details .content .left .checklist ul li a:hover{text-decoration:none;background:#b30000}.task_popup .task_details .content .left .checklist ul li a i{color:#fff;font-size:12px}.task_popup .task_details .content .left .attachments{margin-top:10px;border:1px solid #e6e9ed;border-radius:8px;padding:12px;background:#f9fbfd}.task_popup .task_details .content .left .attachments h3{margin-bottom:10px;font-size:16px;font-weight:600}.task_popup .task_details .content .left .attachments .attachments_upload{display:flex;gap:10px;align-items:center;margin-bottom:10px}.task_popup .task_details .content .left .attachments .attachments_upload .attachment_file_input{flex:1;margin-bottom:0;border-radius:6px;background:#fff}.task_popup .task_details .content .left .attachments .attachments_upload .attachment-upload-btn{white-space:nowrap;border-radius:6px;min-width:150px}.task_popup .task_details .content .left .attachments .attachments_upload .attachment-upload-btn.is-loading{pointer-events:none;opacity:.85}.task_popup .task_details .content .left .attachments .attachments_upload .attachment-upload-btn.is-loading i{margin-right:6px}.task_popup .task_details .content .left .attachments .attachments_list{margin:0;padding:0;list-style:none;display:grid;gap:8px;max-height:180px;overflow-y:auto}.task_popup .task_details .content .left .attachments .attachments_list li{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e4e8ee;border-radius:6px;padding:8px 10px}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-link{color:#1f3d72;text-decoration:none;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 140px)}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-link:hover{text-decoration:underline}.task_popup .task_details .content .left .attachments .attachments_list li small{color:#6b7280;margin-right:auto}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-rename,.task_popup .task_details .content .left .attachments .attachments_list li .attachment-delete{display:inline-flex;align-items:center;justify-content:center;height:28px;width:28px;border-radius:4px;text-decoration:none;transition:all .2s ease}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-rename{border:1px solid #d8e2f6;color:#6690f4;background:#f4f8ff}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-rename:hover{background:#e7f0ff}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-delete{border:1px solid #f1d3d1;color:#cc563d;background:#fff6f6}.task_popup .task_details .content .left .attachments .attachments_list li .attachment-delete:hover{background:#ffeaea}.task_popup .task_details .content .left .attachments .attachments_list .attachments-empty{color:#6b7280;border-style:dashed;justify-content:center;font-size:13px}.task_popup .task_details .content .left .description{padding:15px;border-radius:.25rem;border:1px solid #cdcdcd;margin-bottom:15px;max-height:202px;overflow-x:hidden;position:relative}.task_popup .task_details .content .right .box{margin-bottom:15px}.task_popup .task_details .content .right .time a.time_worked_toggle{color:#299cdb;display:inline-flex;border:1px solid #299cdb}.task_popup .task_details .content .right .time a.time_worked_toggle:hover{background:#dff0fa;text-decoration:none}.task_popup .task_details .content .right .time a.time_worked_toggle:active,.task_popup .task_details .content .right .time a.time_worked_toggle:focus{text-decoration:none}.task_popup .task_details .content .right .time a:not(.time_worked_toggle){margin-top:10px;text-decoration:none;gap:10px}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).task_start{background:#0ab39c;color:#fff}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).task_start:hover{background:#099885}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).task_end{background:#cc563d;color:#fff}.task_popup .task_details .content .right .time a:not(.time_worked_toggle).hidden{display:none}.task_popup .task_details .content .right .dates{display:flex;justify-content:space-between;flex-wrap:wrap}.task_popup .task_details .content .right .dates .danger{color:#cc563d;font-weight:600}.task_popup .task_details .content .right .dates .warning{color:#ff8c00}.task_popup .task_details .content .right .dates i{color:#c9ced4;margin-right:5px}.task_popup .task_details .content .task_work_details{display:none;overflow-y:auto;max-height:508px;width:100%;padding-right:10px;padding-top:4px}.task_popup .task_details .content .task_work_details ._line{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:5px}.task_popup .task_details .content .task_work_details ._line ._user{width:100%;font-size:13px}.task_popup .task_details .content .task_work_details ._line input{width:calc(50% - 25px);text-align:center;margin-left:2px;margin-right:2px}.task_popup .task_details .content .task_work_details ._work_delete{display:inline-flex;height:35px;width:35px;border-radius:6px;align-items:center;justify-content:center;cursor:pointer;border:1px solid #cc563d;margin-left:2px;transition:all .3s ease}.task_popup .task_details .content .task_work_details ._work_delete:hover{background:#cc563d}.task_popup .task_details .content .task_work_details ._work_delete:hover i{color:#fff}.task_popup .task_details .content .task_work_details ._work_delete i{transition:all .3s ease;color:#cc563d}.table{width:100%;border:none;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06);background:#fff}.table th,.table td{padding:10px 14px;border:none;border-bottom:1px solid #eef0f3;text-align:left;vertical-align:middle}.table thead th{background:#f5f7fa;color:#4e5e6a;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border-bottom:2px solid #e2e6ec}.table tbody tr{transition:background .15s ease}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#f8fafd}.table td.center,.table th.center{text-align:center}.table td.left,.table th.left{text-align:left}.table td.right,.table th.right{text-align:right}.table td[colspan]{text-align:center;color:#8896a4;padding:24px 14px;font-style:italic}.projects_container{background:#fff;padding:15px;border-radius:6px;display:flex;gap:20px}.projects_container .left{width:calc(100% - 250px)}.projects_container .left ._projects,.projects_container .left ._users{display:flex;gap:20px;flex-wrap:wrap}.projects_container .right{width:250px;display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:center;gap:20px;border-left:1px solid #cdcdcd;padding-left:15px}.projects_container .right select{width:200px}.default_popup{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:none}.default_popup .popup_content{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);background:#fff;padding:25px;border-radius:0;max-width:1140px;width:100%}.default_popup .popup_content .close{position:absolute;top:10px;right:10px;cursor:pointer}#fg-cron{margin:10px 0}#fg-cron .countdown{background:#099885;color:#fff;padding:10px}#fg-cron #cron-container{max-height:300px;overflow-x:hidden;overflow-y:auto}#fg-cron #cron-container .msg{font-size:13px;padding:5px;border-bottom:1px solid #e8e8e8}.card{background:#fff;padding:25px;border-radius:6px;color:#000;font-size:15px;max-width:1280px}.card.mb25{margin-bottom:25px}.card .card-header{font-weight:600}.card .card-body{padding-top:10px}.card .card-body table{border-collapse:collapse}.card .card-body table th,.card .card-body table td{font-size:14px}.card .card-body table th.bold,.card .card-body table td.bold{font-weight:600}.card .card-body table th.text-right,.card .card-body table td.text-right{text-align:right}.card .card-body table th.text-center,.card .card-body table td.text-center{text-align:center}.card .card-body table th .close-task,.card .card-body table td .close-task{text-decoration:none;color:#6690f4}.card .card-body table th .close-task:hover,.card .card-body table td .close-task:hover{color:#cc563d}.finance-summary{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px}.finance-summary .panel{background:#fff;border-radius:6px;padding:15px}.finance-summary .panel h1{font-size:20px;margin:0}.finance-summary .panel span{font-size:.85em}.finance-manager{display:grid;gap:10px;grid-template-columns:200px 1fr 500px;padding-top:25px}.finance-manager .manage-menu{display:inline-block;margin-right:10px}.finance-manager .manage-menu a{color:#333;text-decoration:none;font-weight:300;display:block}.finance-manager .actions{width:100px;text-align:center}.finance-manager .actions a{display:inline-flex;margin:0 2px;height:25px;width:25px;align-items:center;justify-content:center;text-decoration:none;color:#000;border:1px solid #e7e7e7;font-size:11px;border-radius:3px;transition:all .3s ease}.finance-manager .actions a:hover{border:1px solid #6690f4}.bootstrap-tagsinput .tag{background:#6690f4;font-size:13px;padding:5px 10px;border-radius:12px}.bootstrap-tagsinput .tag [data-role=remove]{color:#fff !important}.bootstrap-tagsinput .tag [data-role=remove]:hover{box-shadow:none !important;color:#000 !important}.finance-tags{display:flex;flex-wrap:wrap;gap:5px}.finance-tags a:not(.btn){display:flex;width:100%;text-decoration:none;color:#4e5e6a}.finance-tags a:not(.btn).zoom-100{font-size:1.2em}.finance-tags a:not(.btn).zoom-90{font-size:1.15em}.finance-tags a:not(.btn).zoom-80{font-size:1.1em}.finance-tags a:not(.btn).zoom-70{font-size:1.05em}.finance-tags a:not(.btn).zoom-60{font-size:1em}.finance-tags a:not(.btn).zoom-50{font-size:.95em}.finance-tags a:not(.btn).zoom-40{font-size:.9em}.finance-tags a:not(.btn).zoom-30{font-size:.85em}.finance-tags a:not(.btn).zoom-20{font-size:.8em}.finance-tags a:not(.btn).zoom-10{font-size:.75em}.finance-tags a:not(.btn).zoom-0{font-size:.7em}.manage-menu{position:relative}.manage-menu .context-menu{border-left:4px dotted #000;width:1px;height:100%}.manage-menu .context-menu-container{position:absolute;display:none;background:#fff;box-shadow:5px 5px 15px rgba(0,0,0,.1);top:2px;left:2px}.manage-menu .context-menu-container ul{list-style-type:none;margin:0;padding:0}.manage-menu .context-menu-container ul li a{display:block;padding:7px 15px;white-space:nowrap}.manage-menu .context-menu-container ul li a:hover{background:#f8f8f8}.manage-menu:hover .context-menu-container{display:block}.wiki-categories{display:grid;gap:10px;margin-top:25px;grid-template-columns:1fr 1fr 1fr 1fr}.wiki-categories .category{background:#fff;padding:10px}.wiki-categories .category .users{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:5px}.wiki-categories .category .users .user{display:flex;height:25px;width:25px;border-radius:50%;background:#ccc;justify-content:center;align-items:center;color:#fff;font-size:12px}.wiki-categories .category .actions{display:grid;grid-template-columns:1fr 1fr}.wiki-categories .category .actions a{display:block;color:#4e5e6a;font-size:13px;text-align:center}.wiki-categories .category .title{margin-bottom:5px}.wiki-categories .category .title a{display:block;color:#4e5e6a;font-size:13px;font-weight:600}.bootstrap-datetimepicker-widget .picker-switch a{display:block;color:#000}.gantt_users{display:flex;gap:20px}#g-results{background:#fff;padding:25px}.g-menu-container{margin-bottom:15px}.g-menu-container .right-menu{display:none}.g-center{text-align:center}.alert{background:#099885;border:0;color:#fff}.tasks_main_view{display:flex;gap:20px}.tasks_main_view ._left_column{padding:25px;background:#fcfcfc;border-right:1px solid #e8e8e8;width:350px}.tasks_main_view ._left_column label{font-weight:400;font-size:14px}.tasks_main_view ._left_column select[name=filtr]{margin-bottom:10px}.tasks_main_view ._left_column ._buttons{display:flex;gap:10px;justify-content:space-between}.tasks_main_view ._left_column ._buttons .btn{flex:1}.tasks_main_view ._right_column{flex:1;max-width:calc(100% - 350px)}#billing-summary .card-header{padding:10px}#billing-summary .billing-kpi{border:1px solid #dee2e6;border-radius:6px;padding:10px 12px;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.04)}#billing-summary .billing-kpi-label{font-size:12px;color:#6c757d;margin-bottom:3px}#billing-summary .billing-kpi-value{font-size:21px;font-weight:700;line-height:1.1}#billing-summary .billing-details-row{display:none}#billing-summary .billing-client-name{font-weight:600}#billing-summary .billing-table>thead>tr>th{background:#f8f9fa}#billing-summary .billing-details-wrap{background:#f8fbff}.vacation-type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500;background:#e3f0ff;color:#2563eb}.vacation-type-badge.type-chorobowe{background:#fff3e0;color:#e65100}.vacation-type-badge.type-inna_nieobecnosc{background:#f3e5f5;color:#7b1fa2}/*# sourceMappingURL=style.css.map */ \ No newline at end of file diff --git a/layout/style.css.map b/layout/style.css.map index 5ea0933..48ce7f3 100644 --- a/layout/style.css.map +++ b/layout/style.css.map @@ -1 +1 @@ -{"version":3,"sources":["style.scss"],"names":[],"mappings":"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","file":"style.css","sourcesContent":["$cBlue: #6690F4;\r\n$cRed: #cc563d;\r\n$cGreen: #099885;\r\n$cBlack: #4e5e6a;\r\n\r\n.default-btn {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 40px;\r\n border-radius: 6px;\r\n padding: 0 15px;\r\n transition: all .3s ease;\r\n\r\n &:hover {\r\n text-decoration: none;\r\n }\r\n}\r\n\r\n.animate {\r\n animation: mymove 3s infinite;\r\n}\r\n\r\n.text-right {\r\n text-align: right;\r\n}\r\n\r\n.nowrap {\r\n white-space: nowrap;\r\n}\r\n\r\ntable {\r\n border-collapse: collapse;\r\n font-size: 13px;\r\n}\r\n\r\nsmall {\r\n font-size: .75em;\r\n}\r\n\r\n@keyframes mymove {\r\n 50% {\r\n opacity: .33;\r\n }\r\n}\r\n\r\n/* motion */\r\n@keyframes gradient-animation {\r\n 0% {\r\n background-position: 15% 0%;\r\n }\r\n\r\n 50% {\r\n background-position: 85% 100%;\r\n }\r\n\r\n 100% {\r\n background-position: 15% 0%;\r\n }\r\n}\r\n\r\n@keyframes frame-enter {\r\n 0% {\r\n clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), 3px calc(100% - 3px), 3px 100%, 100% 100%, 100% 0%, 0% 0%);\r\n }\r\n\r\n 25% {\r\n clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) 100%, 100% 100%, 100% 0%, 0% 0%);\r\n }\r\n\r\n 50% {\r\n clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, 100% 0%, 0% 0%);\r\n }\r\n\r\n 75% {\r\n -webkit-clip-path: polygon(0% 100%, 3px 100%, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 0%, 0% 0%);\r\n }\r\n\r\n 100% {\r\n -webkit-clip-path: polygon(0% 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 0% 100%);\r\n }\r\n}\r\n\r\n* {\r\n box-sizing: border-box;\r\n}\r\n\r\nbody {\r\n font-family: \"Open Sans\", sans-serif;\r\n margin: 0;\r\n padding: 0;\r\n font-size: 15px;\r\n color: #4e5e6a;\r\n}\r\n\r\n.btn {\r\n padding: 9px 25px;\r\n transition: all 0.3s ease;\r\n color: #FFF;\r\n border: 0;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n display: inline-flex;\r\n text-decoration: none;\r\n gap: 5px;\r\n justify-content: center;\r\n align-items: center;\r\n\r\n &.btn_small,\r\n &.btn-xs,\r\n &.btn-sm {\r\n padding: 5px 7px;\r\n font-size: 13px;\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n &.btn-success {\r\n background: $cGreen;\r\n\r\n &:hover {\r\n background: #4a9c3b;\r\n }\r\n }\r\n\r\n &.btn-primary {\r\n background: $cBlue;\r\n\r\n &:hover {\r\n background: #3164db;\r\n }\r\n }\r\n\r\n &.btn-danger {\r\n background: $cRed;\r\n\r\n &:hover {\r\n background: #b30000;\r\n }\r\n }\r\n}\r\n\r\n.hide {\r\n display: none;\r\n}\r\n\r\n.form-error {\r\n color: $cRed;\r\n font-size: 13px;\r\n}\r\n\r\n.input-group {\r\n margin-bottom: 10px;\r\n}\r\n\r\n.form-field {\r\n margin-bottom: 15px;\r\n\r\n label {\r\n display: block;\r\n font-size: 13px;\r\n font-weight: 600;\r\n margin-bottom: 4px;\r\n color: #4e5e6a;\r\n }\r\n}\r\n\r\n.password-wrap {\r\n position: relative;\r\n\r\n .form-control {\r\n padding-right: 40px;\r\n }\r\n\r\n .password-eye {\r\n position: absolute;\r\n right: 10px;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n color: #999;\r\n text-decoration: none;\r\n z-index: 2;\r\n\r\n &:hover {\r\n color: #333;\r\n }\r\n }\r\n}\r\n\r\ninput[type=\"checkbox\"] {\r\n border: 1px solid #cdcdcd;\r\n}\r\n\r\n.form-control {\r\n border: 1px solid #cdcdcd;\r\n border-radius: 6px;\r\n height: 35px;\r\n width: 100%;\r\n padding: 5px;\r\n font-family: \"Open Sans\", sans-serif;\r\n\r\n option {\r\n padding: 5px;\r\n }\r\n\r\n &:focus {\r\n border: 1px solid $cBlue;\r\n outline: none;\r\n }\r\n}\r\n\r\n.unlogged {\r\n background: #EEF1F9;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 100vh;\r\n\r\n .box-login {\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 6px;\r\n width: 400px;\r\n\r\n .title {\r\n text-align: center;\r\n padding: 10px 10px 25px;\r\n border-bottom: 1px solid #cdcdcd;\r\n font-size: 20px;\r\n margin-bottom: 25px;\r\n }\r\n }\r\n}\r\n\r\n$sidebar-width: 220px;\r\n$sidebar-collapsed-width: 60px;\r\n$sidebar-bg: #1e2a3a;\r\n$sidebar-text: #c2c7d0;\r\n$sidebar-active: #fff;\r\n$sidebar-hover-bg: rgba(255, 255, 255, 0.08);\r\n\r\n.sidebar {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: $sidebar-width;\r\n height: 100vh;\r\n background: $sidebar-bg;\r\n display: flex;\r\n flex-direction: column;\r\n z-index: 1000;\r\n transition: width 0.3s ease;\r\n overflow: hidden;\r\n\r\n &.collapsed {\r\n width: $sidebar-collapsed-width;\r\n\r\n .sidebar-header .sidebar-logo span,\r\n .sidebar-nav ul li a span,\r\n .sidebar-footer span,\r\n .sidebar-footer .sidebar-user span {\r\n display: none;\r\n }\r\n\r\n .sidebar-header .sidebar-logo {\r\n font-size: 0;\r\n\r\n &::first-letter {\r\n font-size: 16px;\r\n }\r\n }\r\n\r\n .sidebar-nav ul li a {\r\n justify-content: center;\r\n padding: 10px;\r\n\r\n i {\r\n margin-right: 0;\r\n }\r\n }\r\n\r\n .sidebar-nav ul li.has-submenu {\r\n .submenu-arrow {\r\n display: none;\r\n }\r\n\r\n .sidebar-submenu {\r\n display: none;\r\n }\r\n }\r\n\r\n .sidebar-footer .sidebar-footer-link,\r\n .sidebar-footer .sidebar-user {\r\n justify-content: center;\r\n padding: 8px 10px;\r\n\r\n i {\r\n margin-right: 0;\r\n }\r\n }\r\n }\r\n\r\n .sidebar-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 15px;\r\n border-bottom: 1px solid rgba(255, 255, 255, 0.1);\r\n\r\n .sidebar-logo {\r\n color: $cBlue;\r\n text-decoration: none;\r\n font-size: 16px;\r\n white-space: nowrap;\r\n\r\n span {\r\n font-weight: 700;\r\n }\r\n }\r\n\r\n .sidebar-toggle {\r\n cursor: pointer;\r\n color: $sidebar-text;\r\n font-size: 16px;\r\n transition: color 0.2s ease;\r\n\r\n &:hover {\r\n color: #fff;\r\n }\r\n }\r\n }\r\n\r\n .sidebar-nav {\r\n flex: 1;\r\n overflow-y: auto;\r\n padding: 10px 0;\r\n\r\n ul {\r\n list-style: none;\r\n margin: 0;\r\n padding: 0;\r\n\r\n li {\r\n a {\r\n display: flex;\r\n align-items: center;\r\n padding: 10px 15px;\r\n color: $sidebar-text;\r\n text-decoration: none;\r\n font-size: 14px;\r\n transition: all 0.2s ease;\r\n white-space: nowrap;\r\n\r\n i {\r\n width: 20px;\r\n text-align: center;\r\n margin-right: 10px;\r\n font-size: 15px;\r\n }\r\n\r\n &:hover {\r\n background: $sidebar-hover-bg;\r\n color: $sidebar-active;\r\n }\r\n }\r\n\r\n &.active a {\r\n background: $sidebar-hover-bg;\r\n color: $sidebar-active;\r\n font-weight: 600;\r\n }\r\n\r\n &.has-submenu {\r\n >a .submenu-arrow {\r\n margin-left: auto;\r\n font-size: 12px;\r\n transition: transform 0.2s ease;\r\n width: auto;\r\n }\r\n\r\n &.open>a .submenu-arrow {\r\n transform: rotate(180deg);\r\n }\r\n\r\n .sidebar-submenu {\r\n max-height: 0;\r\n overflow: hidden;\r\n transition: max-height 0.25s ease;\r\n background: rgba(0, 0, 0, 0.15);\r\n\r\n li a {\r\n padding: 8px 15px 8px 45px;\r\n font-size: 13px;\r\n\r\n i {\r\n font-size: 13px;\r\n width: 16px;\r\n }\r\n }\r\n }\r\n\r\n &.open .sidebar-submenu {\r\n max-height: 200px;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n .sidebar-footer {\r\n border-top: 1px solid rgba(255, 255, 255, 0.1);\r\n padding: 10px 0;\r\n\r\n .sidebar-user {\r\n display: flex;\r\n align-items: center;\r\n padding: 8px 15px;\r\n color: $sidebar-text;\r\n font-size: 13px;\r\n white-space: nowrap;\r\n overflow: hidden;\r\n\r\n i {\r\n margin-right: 10px;\r\n color: $cBlue;\r\n }\r\n }\r\n\r\n .sidebar-footer-link {\r\n display: flex;\r\n align-items: center;\r\n padding: 8px 15px;\r\n color: $sidebar-text;\r\n text-decoration: none;\r\n font-size: 13px;\r\n transition: all 0.2s ease;\r\n white-space: nowrap;\r\n\r\n i {\r\n width: 20px;\r\n text-align: center;\r\n margin-right: 10px;\r\n }\r\n\r\n &:hover {\r\n background: $sidebar-hover-bg;\r\n color: $sidebar-active;\r\n }\r\n\r\n &.logout {\r\n color: $cRed;\r\n\r\n &:hover {\r\n color: #e07a66;\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n.content-wrapper {\r\n margin-left: $sidebar-width;\r\n min-height: 100vh;\r\n transition: margin-left 0.3s ease;\r\n\r\n &.expanded {\r\n margin-left: $sidebar-collapsed-width;\r\n }\r\n}\r\n\r\n.top-bar {\r\n background: #fff;\r\n border-bottom: 1px solid #e8e8e8;\r\n padding: 10px 20px;\r\n display: flex;\r\n align-items: center;\r\n\r\n .top-bar-left {\r\n display: flex;\r\n align-items: center;\r\n gap: 15px;\r\n\r\n i {\r\n cursor: pointer;\r\n font-size: 18px;\r\n color: #4e5e6a;\r\n\r\n &:hover {\r\n color: #000;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.main {\r\n padding: 25px;\r\n background: #D9DEE2;\r\n min-height: calc(100vh - 45px);\r\n}\r\n\r\n.tasks_container {\r\n display: grid;\r\n grid-template-columns: repeat(5, 1fr);\r\n gap: 20px;\r\n\r\n .column {\r\n width: 100%;\r\n\r\n h2 {\r\n display: flex;\r\n padding: 10px;\r\n background: #FFF;\r\n margin-bottom: 10px;\r\n font-size: 15px;\r\n font-weight: 300;\r\n border-radius: 3px 3px 0 0;\r\n justify-content: space-between;\r\n align-items: center;\r\n\r\n i {\r\n cursor: pointer;\r\n }\r\n }\r\n\r\n &.tasks_suspended {\r\n h2 {\r\n border-bottom: 5px solid $cRed;\r\n }\r\n }\r\n\r\n &.tasks_fvat {\r\n h2 {\r\n border-bottom: 5px solid #a900fc;\r\n }\r\n }\r\n\r\n &.tasks_new {\r\n h2 {\r\n border-bottom: 5px solid #ccc;\r\n }\r\n }\r\n\r\n &.tasks_bulk {\r\n h2 {\r\n border-bottom: 5px solid #ff8c00;\r\n }\r\n }\r\n\r\n &.tasks_to_do {\r\n h2 {\r\n border-bottom: 5px solid #2aaf47;\r\n }\r\n }\r\n\r\n &.tasks_to_review {\r\n h2 {\r\n border-bottom: 5px solid #2535c9;\r\n }\r\n }\r\n\r\n &.tasks_closed {\r\n h2 {\r\n border-bottom: 5px solid #000;\r\n }\r\n }\r\n\r\n ul {\r\n list-style-type: none;\r\n margin: 0;\r\n padding: 0;\r\n\r\n .task {\r\n margin-bottom: 5px;\r\n background: #FFF;\r\n padding: 10px;\r\n border-radius: 0;\r\n display: flex;\r\n position: relative;\r\n border-radius: 6px;\r\n flex-wrap: wrap;\r\n\r\n &.notopened {\r\n border: 2px solid $cRed;\r\n }\r\n\r\n .top {\r\n display: flex;\r\n justify-content: space-between;\r\n margin-bottom: 5px;\r\n width: 100%;\r\n\r\n ._users {\r\n display: flex;\r\n gap: 5px;\r\n flex-wrap: wrap;\r\n\r\n .user {\r\n display: flex;\r\n width: 25px;\r\n height: 25px;\r\n border-radius: 6px;\r\n justify-content: center;\r\n align-items: center;\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n ._timer {\r\n display: flex;\r\n gap: 5px;\r\n\r\n .recursively {\r\n color: #FFF;\r\n background: #405189;\r\n border-radius: 3px;\r\n cursor: pointer;\r\n margin-bottom: 5px;\r\n width: 25px;\r\n height: 25px;\r\n text-align: center;\r\n display: block;\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n .task_start {\r\n display: block;\r\n background: $cGreen;\r\n color: #FFF;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n margin-bottom: 5px;\r\n width: 25px;\r\n height: 25px;\r\n text-align: center;\r\n\r\n &.hidden {\r\n display: none;\r\n }\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n .task_end {\r\n background: $cRed;\r\n display: block;\r\n color: #FFF;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n margin-bottom: 5px;\r\n width: 25px;\r\n height: 25px;\r\n text-align: center;\r\n\r\n &.hidden {\r\n display: none;\r\n }\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .middle {\r\n width: 100%;\r\n }\r\n\r\n .name {\r\n font-size: 14px;\r\n color: #333;\r\n text-decoration: none;\r\n display: block;\r\n margin-bottom: 5px;\r\n }\r\n\r\n .bottom {\r\n display: flex;\r\n justify-content: space-between;\r\n }\r\n\r\n .client_info,\r\n .current_status {\r\n font-size: 12px;\r\n font-weight: 400;\r\n\r\n strong {\r\n font-weight: 600;\r\n }\r\n }\r\n\r\n .current_status {\r\n position: relative;\r\n cursor: pointer;\r\n\r\n .status_change {\r\n position: absolute;\r\n left: 0;\r\n top: 20px;\r\n background: #fff;\r\n padding: 15px;\r\n border: 1px solid #dfdfdf;\r\n border-radius: 3px;\r\n cursor: pointer;\r\n box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);\r\n z-index: 99;\r\n display: none;\r\n\r\n select {\r\n width: 250px;\r\n padding: 10px;\r\n border: 1px solid #cdcdcd;\r\n border-radius: 3px;\r\n\r\n option {\r\n font-size: 15px;\r\n padding: 3px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .dates {\r\n margin-bottom: 5px;\r\n display: flex;\r\n justify-content: space-between;\r\n font-size: 12px;\r\n\r\n .danger {\r\n color: $cRed;\r\n font-weight: 600;\r\n }\r\n\r\n .warning {\r\n color: #ff8c00;\r\n }\r\n\r\n i {\r\n font-size: 12px;\r\n color: #C9CED4;\r\n margin-right: 5px;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n/* page header */\r\n.block-header {\r\n margin-bottom: 20px;\r\n\r\n h2 {\r\n font-size: 20px;\r\n font-weight: 400;\r\n color: $cBlack;\r\n margin: 0;\r\n padding-bottom: 12px;\r\n border-bottom: 2px solid #e2e6ec;\r\n\r\n strong {\r\n font-weight: 700;\r\n }\r\n }\r\n}\r\n\r\n/* filters bar — reusable across modules */\r\n.filters-bar {\r\n display: flex;\r\n align-items: center;\r\n gap: 10px;\r\n flex-wrap: wrap;\r\n margin-bottom: 24px;\r\n padding: 12px 16px;\r\n background: #f5f7fa;\r\n border-radius: 8px;\r\n border: 1px solid #e2e6ec;\r\n\r\n select,\r\n input[type=\"text\"],\r\n input[type=\"date\"],\r\n input[type=\"number\"] {\r\n height: 36px;\r\n min-width: 170px;\r\n padding: 0 10px;\r\n border: 1px solid #d0d5dd;\r\n border-radius: 6px;\r\n background: #fff;\r\n font-size: 13px;\r\n color: $cBlack;\r\n font-family: \"Open Sans\", sans-serif;\r\n transition: border-color 0.2s;\r\n\r\n &:focus {\r\n border-color: $cBlue;\r\n outline: none;\r\n }\r\n }\r\n\r\n .btn {\r\n height: 36px;\r\n display: inline-flex;\r\n align-items: center;\r\n gap: 5px;\r\n padding: 0 14px;\r\n border-radius: 6px;\r\n font-size: 13px;\r\n font-weight: 500;\r\n border: none;\r\n cursor: pointer;\r\n transition: background 0.2s, box-shadow 0.2s;\r\n text-decoration: none;\r\n color: #fff;\r\n\r\n &.btn-primary {\r\n background: $cBlue;\r\n\r\n &:hover {\r\n background: #4a74d4;\r\n }\r\n }\r\n\r\n &.btn-success {\r\n background: $cGreen;\r\n\r\n &:hover {\r\n background: #077a6b;\r\n }\r\n }\r\n }\r\n}\r\n\r\n/* section title — reusable */\r\n.section-title {\r\n font-size: 14px;\r\n font-weight: 600;\r\n color: $cBlack;\r\n margin: 28px 0 12px;\r\n padding-bottom: 8px;\r\n border-bottom: 1px solid #e2e6ec;\r\n}\r\n\r\n.action_menu {\r\n display: flex;\r\n margin-bottom: 25px;\r\n gap: 20px;\r\n\r\n .btn {\r\n display: inline-flex;\r\n padding: 7px 15px;\r\n color: #FFF;\r\n text-decoration: none;\r\n align-items: center;\r\n justify-content: center;\r\n gap: 5px;\r\n\r\n &.btn_add {\r\n background: $cGreen;\r\n\r\n &:hover {\r\n background: #4a9c3b;\r\n }\r\n }\r\n\r\n &.btn_cancel {\r\n background: $cRed;\r\n\r\n &:hover {\r\n background: #b30000;\r\n }\r\n }\r\n\r\n &.disabled {\r\n opacity: .5;\r\n }\r\n }\r\n}\r\n\r\n.form_container {\r\n background: #FFF;\r\n padding: 25px;\r\n max-width: 1300px;\r\n\r\n &.full {\r\n max-width: 100%;\r\n }\r\n\r\n .form_group {\r\n margin-bottom: 10px;\r\n display: flex;\r\n\r\n >.label {\r\n width: 300px;\r\n display: inline-flex;\r\n align-items: flex-start;\r\n justify-content: right;\r\n padding-right: 10px;\r\n }\r\n\r\n .input {\r\n width: calc(100% - 300px);\r\n }\r\n }\r\n}\r\n\r\n.fullscreen_description {\r\n position: fixed !important;\r\n top: 25px;\r\n left: 25px;\r\n right: 25px;\r\n bottom: 25px;\r\n z-index: 9999;\r\n background: white;\r\n padding: 20px;\r\n overflow: auto;\r\n border-radius: 0.25rem;\r\n box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);\r\n}\r\n\r\n.fullscreen {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n color: #FFF;\r\n background: $cRed;\r\n display: inline-flex;\r\n height: 40px;\r\n width: 40px;\r\n border-radius: 6px;\r\n align-items: center;\r\n justify-content: center;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n transform: scale(1.05);\r\n text-decoration: none;\r\n }\r\n}\r\n\r\n.task_popup {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background: rgba(0, 0, 0, 0.5);\r\n display: none;\r\n z-index: 9999;\r\n\r\n .task_details {\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 6px;\r\n max-width: 1140px;\r\n width: 100%;\r\n transition: all 0.3s ease;\r\n height: 90vh;\r\n\r\n .content {\r\n height: calc(100% - 50px);\r\n }\r\n\r\n &.open_works_time {\r\n max-width: 1540px;\r\n\r\n .content {\r\n grid-template-columns: 1fr 300px 350px;\r\n\r\n .task_work_details {\r\n display: block;\r\n }\r\n }\r\n }\r\n\r\n .title {\r\n font-size: 20px;\r\n margin-bottom: 25px;\r\n display: flex;\r\n align-items: center;\r\n gap: 10px;\r\n\r\n a {\r\n border: 1px solid $cGreen;\r\n display: inline-flex;\r\n height: 30px;\r\n width: 30px;\r\n border-radius: 6px;\r\n align-items: center;\r\n justify-content: center;\r\n\r\n &:hover {\r\n text-decoration: none;\r\n }\r\n\r\n i {\r\n color: $cGreen;\r\n }\r\n\r\n &.task-delete {\r\n border: 1px solid $cRed;\r\n\r\n i {\r\n color: $cRed;\r\n }\r\n }\r\n\r\n i {\r\n font-size: 14px;\r\n }\r\n }\r\n }\r\n\r\n .close {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n }\r\n\r\n .content {\r\n display: grid;\r\n font-size: 14px;\r\n grid-template-columns: 1fr 300px;\r\n gap: 30px;\r\n transition: all 0.3s ease;\r\n\r\n h3 {\r\n width: 100%;\r\n margin-top: 0;\r\n margin-bottom: 5px;\r\n font-weight: 500;\r\n color: #000;\r\n font-size: 17px;\r\n }\r\n\r\n .left {\r\n height: 100%;\r\n overflow: hidden;\r\n\r\n .users {\r\n display: flex;\r\n gap: 20px;\r\n\r\n .user {\r\n display: flex;\r\n gap: 10px;\r\n align-items: center;\r\n margin-bottom: 10px;\r\n\r\n .avatar {\r\n height: 30px;\r\n width: 30px;\r\n border-radius: 6px;\r\n background: #ccc;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n }\r\n\r\n .comments {\r\n border-radius: 3px;\r\n max-height: 406px;\r\n overflow-y: auto;\r\n\r\n .new_comment {\r\n margin-bottom: 10px;\r\n\r\n textarea {\r\n height: 75px;\r\n margin-bottom: 10px;\r\n border-radius: 6px;\r\n }\r\n\r\n .add_comment {\r\n background: $cGreen;\r\n color: #FFF;\r\n padding: 10px;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n width: 200px;\r\n text-decoration: none;\r\n\r\n &:hover {\r\n background: #4a9c3b;\r\n }\r\n }\r\n }\r\n\r\n ul {\r\n margin: 0;\r\n padding: 0;\r\n list-style-type: none;\r\n\r\n li {\r\n background: #ced4da;\r\n margin-bottom: 5px;\r\n padding: 15px;\r\n border-radius: 6px;\r\n position: relative;\r\n\r\n .delete_comment {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n color: $cRed;\r\n }\r\n\r\n .author {\r\n font-weight: 600;\r\n margin-bottom: 5px;\r\n display: inline-flex;\r\n margin-right: 10px;\r\n }\r\n\r\n .date {\r\n font-size: 12px;\r\n margin-bottom: 5px;\r\n display: inline-flex;\r\n }\r\n\r\n .text {\r\n margin-bottom: 15px;\r\n font-size: 13px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .checklist {\r\n border-radius: 3px;\r\n margin-bottom: 10px;\r\n\r\n .new_element {\r\n display: flex;\r\n margin-bottom: 10px;\r\n\r\n input {\r\n border-radius: 6px 0 0 6px;\r\n }\r\n\r\n a {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n padding: 10px;\r\n border-radius: 0 6px 6px 0;\r\n text-decoration: none;\r\n width: 35px;\r\n background: $cGreen;\r\n color: #FFF;\r\n }\r\n }\r\n\r\n ul {\r\n margin: 0;\r\n padding: 0;\r\n list-style-type: none;\r\n overflow-y: auto;\r\n max-height: calc(90vh - 400px);\r\n\r\n li {\r\n display: flex;\r\n gap: 10px;\r\n margin-bottom: 5px;\r\n background: #FFF;\r\n border-radius: 3px;\r\n padding: 10px;\r\n border: 1px solid #cdcdcd;\r\n font-size: 13px;\r\n align-items: flex-start;\r\n\r\n a {\r\n margin-left: auto;\r\n margin-right: 0;\r\n cursor: pointer;\r\n background: $cRed;\r\n display: flex;\r\n height: 25px;\r\n width: 25px;\r\n min-width: 25px;\r\n justify-content: center;\r\n align-items: center;\r\n border: 0;\r\n border-radius: 3px;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n text-decoration: none;\r\n background: #b30000;\r\n }\r\n\r\n i {\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n .attachments {\r\n margin-top: 10px;\r\n border: 1px solid #e6e9ed;\r\n border-radius: 8px;\r\n padding: 12px;\r\n background: #f9fbfd;\r\n\r\n h3 {\r\n margin-bottom: 10px;\r\n font-size: 16px;\r\n font-weight: 600;\r\n }\r\n\r\n .attachments_upload {\r\n display: flex;\r\n gap: 10px;\r\n align-items: center;\r\n margin-bottom: 10px;\r\n\r\n .attachment_file_input {\r\n flex: 1;\r\n margin-bottom: 0;\r\n border-radius: 6px;\r\n background: #fff;\r\n }\r\n\r\n .attachment-upload-btn {\r\n white-space: nowrap;\r\n border-radius: 6px;\r\n min-width: 150px;\r\n\r\n &.is-loading {\r\n pointer-events: none;\r\n opacity: 0.85;\r\n\r\n i {\r\n margin-right: 6px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .attachments_list {\r\n margin: 0;\r\n padding: 0;\r\n list-style: none;\r\n display: grid;\r\n gap: 8px;\r\n max-height: 180px;\r\n overflow-y: auto;\r\n\r\n li {\r\n display: flex;\r\n align-items: center;\r\n gap: 8px;\r\n background: #fff;\r\n border: 1px solid #e4e8ee;\r\n border-radius: 6px;\r\n padding: 8px 10px;\r\n\r\n .attachment-link {\r\n color: #1f3d72;\r\n text-decoration: none;\r\n font-weight: 600;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n max-width: calc(100% - 140px);\r\n\r\n &:hover {\r\n text-decoration: underline;\r\n }\r\n }\r\n\r\n small {\r\n color: #6b7280;\r\n margin-right: auto;\r\n }\r\n\r\n .attachment-rename,\r\n .attachment-delete {\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 28px;\r\n width: 28px;\r\n border-radius: 4px;\r\n text-decoration: none;\r\n transition: all 0.2s ease;\r\n }\r\n\r\n .attachment-rename {\r\n border: 1px solid #d8e2f6;\r\n color: $cBlue;\r\n background: #f4f8ff;\r\n\r\n &:hover {\r\n background: #e7f0ff;\r\n }\r\n }\r\n\r\n .attachment-delete {\r\n border: 1px solid #f1d3d1;\r\n color: $cRed;\r\n background: #fff6f6;\r\n\r\n &:hover {\r\n background: #ffeaea;\r\n }\r\n }\r\n }\r\n\r\n .attachments-empty {\r\n color: #6b7280;\r\n border-style: dashed;\r\n justify-content: center;\r\n font-size: 13px;\r\n }\r\n }\r\n }\r\n\r\n .description {\r\n padding: 15px;\r\n border-radius: 0.25rem;\r\n border: 1px solid #cdcdcd;\r\n margin-bottom: 15px;\r\n max-height: 202px;\r\n overflow-x: hidden;\r\n position: relative;\r\n }\r\n }\r\n\r\n .right {\r\n\r\n .box {\r\n margin-bottom: 15px;\r\n }\r\n\r\n .time {\r\n a.time_worked_toggle {\r\n @extend .default-btn;\r\n color: #299cdb;\r\n display: inline-flex;\r\n border: 1px solid #299cdb;\r\n\r\n &:hover {\r\n background: #dff0fa;\r\n text-decoration: none;\r\n }\r\n\r\n &:active,\r\n &:focus {\r\n text-decoration: none;\r\n }\r\n }\r\n\r\n a:not(.time_worked_toggle) {\r\n @extend .default-btn;\r\n margin-top: 10px;\r\n text-decoration: none;\r\n gap: 10px;\r\n\r\n &.task_start {\r\n background: #0ab39c;\r\n color: #FFF;\r\n\r\n &:hover {\r\n background: #099885;\r\n }\r\n }\r\n\r\n &.task_end {\r\n background: $cRed;\r\n color: #FFF;\r\n }\r\n\r\n &.hidden {\r\n display: none;\r\n }\r\n }\r\n }\r\n\r\n .dates {\r\n display: flex;\r\n justify-content: space-between;\r\n flex-wrap: wrap;\r\n\r\n .danger {\r\n color: $cRed;\r\n font-weight: 600;\r\n }\r\n\r\n .warning {\r\n color: #ff8c00;\r\n }\r\n\r\n i {\r\n color: #C9CED4;\r\n margin-right: 5px;\r\n }\r\n }\r\n }\r\n\r\n .task_work_details {\r\n display: none;\r\n overflow-y: auto;\r\n max-height: 508px;\r\n width: 100%;\r\n padding-right: 10px;\r\n padding-top: 4px;\r\n\r\n ._line {\r\n display: flex;\r\n flex-wrap: wrap;\r\n justify-content: space-between;\r\n align-items: center;\r\n margin-bottom: 5px;\r\n\r\n ._user {\r\n width: 100%;\r\n font-size: 13px;\r\n }\r\n\r\n input {\r\n width: calc(50% - 25px);\r\n text-align: center;\r\n margin-left: 2px;\r\n margin-right: 2px;\r\n }\r\n }\r\n\r\n ._work_delete {\r\n display: inline-flex;\r\n height: 35px;\r\n width: 35px;\r\n border-radius: 6px;\r\n align-items: center;\r\n justify-content: center;\r\n cursor: pointer;\r\n border: 1px solid $cRed;\r\n margin-left: 2px;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n background: $cRed;\r\n\r\n i {\r\n color: #FFF;\r\n }\r\n }\r\n\r\n i {\r\n transition: all 0.3s ease;\r\n color: $cRed;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n.table {\r\n width: 100%;\r\n border: none;\r\n border-radius: 8px;\r\n overflow: hidden;\r\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);\r\n background: #fff;\r\n\r\n th,\r\n td {\r\n padding: 10px 14px;\r\n border: none;\r\n border-bottom: 1px solid #eef0f3;\r\n text-align: left;\r\n vertical-align: middle;\r\n }\r\n\r\n thead th {\r\n background: #f5f7fa;\r\n color: #4e5e6a;\r\n font-weight: 600;\r\n font-size: 12px;\r\n text-transform: uppercase;\r\n letter-spacing: 0.3px;\r\n white-space: nowrap;\r\n border-bottom: 2px solid #e2e6ec;\r\n }\r\n\r\n tbody tr {\r\n transition: background 0.15s ease;\r\n\r\n &:last-child td {\r\n border-bottom: none;\r\n }\r\n\r\n &:hover {\r\n background: #f8fafd;\r\n }\r\n }\r\n\r\n td.center,\r\n th.center {\r\n text-align: center;\r\n }\r\n\r\n td.left,\r\n th.left {\r\n text-align: left;\r\n }\r\n\r\n td.right,\r\n th.right {\r\n text-align: right;\r\n }\r\n\r\n // empty state\r\n td[colspan] {\r\n text-align: center;\r\n color: #8896a4;\r\n padding: 24px 14px;\r\n font-style: italic;\r\n }\r\n}\r\n\r\n.projects_container {\r\n background: #FFF;\r\n padding: 15px;\r\n border-radius: 6px;\r\n display: flex;\r\n gap: 20px;\r\n\r\n .left {\r\n width: calc(100% - 250px);\r\n\r\n ._projects,\r\n ._users {\r\n display: flex;\r\n gap: 20px;\r\n flex-wrap: wrap;\r\n }\r\n }\r\n\r\n .right {\r\n width: 250px;\r\n display: flex;\r\n flex-wrap: wrap;\r\n align-items: flex-start;\r\n justify-content: center;\r\n gap: 20px;\r\n border-left: 1px solid #cdcdcd;\r\n padding-left: 15px;\r\n\r\n select {\r\n width: 200px;\r\n }\r\n }\r\n}\r\n\r\n.default_popup {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background: rgba(0, 0, 0, 0.5);\r\n display: none;\r\n\r\n .popup_content {\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 0;\r\n max-width: 1140px;\r\n width: 100%;\r\n\r\n .close {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n }\r\n }\r\n}\r\n\r\n#fg-cron {\r\n margin: 10px 0;\r\n\r\n .countdown {\r\n background: $cGreen;\r\n color: #FFF;\r\n padding: 10px;\r\n }\r\n\r\n #cron-container {\r\n max-height: 300px;\r\n overflow-x: hidden;\r\n overflow-y: auto;\r\n\r\n .msg {\r\n font-size: 13px;\r\n padding: 5px;\r\n border-bottom: 1px solid #e8e8e8;\r\n }\r\n }\r\n}\r\n\r\n.card {\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 6px;\r\n color: #000;\r\n font-size: 15px;\r\n max-width: 1280px;\r\n\r\n &.mb25 {\r\n margin-bottom: 25px;\r\n }\r\n\r\n .card-header {\r\n font-weight: 600;\r\n }\r\n\r\n .card-body {\r\n padding-top: 10px;\r\n\r\n table {\r\n border-collapse: collapse;\r\n\r\n th,\r\n td {\r\n font-size: 14px;\r\n\r\n &.bold {\r\n font-weight: 600;\r\n }\r\n\r\n &.text-right {\r\n text-align: right;\r\n }\r\n\r\n &.text-center {\r\n text-align: center;\r\n }\r\n\r\n .close-task {\r\n text-decoration: none;\r\n color: $cBlue;\r\n\r\n &:hover {\r\n color: $cRed;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n.finance-summary {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr 1fr 1fr;\r\n gap: 10px;\r\n\r\n .panel {\r\n background: #FFF;\r\n border-radius: 6px;\r\n padding: 15px;\r\n\r\n h1 {\r\n font-size: 20px;\r\n margin: 0;\r\n }\r\n\r\n span {\r\n font-size: 0.85em;\r\n }\r\n }\r\n}\r\n\r\n.finance-manager {\r\n display: grid;\r\n gap: 10px;\r\n grid-template-columns: 200px 1fr 500px;\r\n padding-top: 25px;\r\n\r\n .manage-menu {\r\n display: inline-block;\r\n margin-right: 10px;\r\n\r\n a {\r\n color: #333333;\r\n text-decoration: none;\r\n font-weight: 300;\r\n display: block;\r\n }\r\n }\r\n\r\n .actions {\r\n width: 100px;\r\n text-align: center;\r\n\r\n a {\r\n display: inline-flex;\r\n margin: 0 2px;\r\n height: 25px;\r\n width: 25px;\r\n align-items: center;\r\n justify-content: center;\r\n text-decoration: none;\r\n color: #000;\r\n border: 1px solid #e7e7e7;\r\n font-size: 11px;\r\n border-radius: 3px;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n border: 1px solid $cBlue;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.bootstrap-tagsinput {\r\n .tag {\r\n background: $cBlue;\r\n font-size: 13px;\r\n padding: 5px 10px;\r\n border-radius: 12px;\r\n\r\n [data-role=\"remove\"] {\r\n color: #FFF !important;\r\n\r\n &:hover {\r\n box-shadow: none !important;\r\n color: #000 !important\r\n }\r\n }\r\n }\r\n}\r\n\r\n.finance-tags {\r\n display: flex;\r\n flex-wrap: wrap;\r\n gap: 5px;\r\n\r\n a:not(.btn) {\r\n display: flex;\r\n width: 100%;\r\n text-decoration: none;\r\n color: $cBlack;\r\n\r\n &.zoom-100 {\r\n font-size: 1.2em;\r\n }\r\n\r\n &.zoom-90 {\r\n font-size: 1.15em;\r\n }\r\n\r\n &.zoom-80 {\r\n font-size: 1.1em;\r\n }\r\n\r\n &.zoom-70 {\r\n font-size: 1.05em;\r\n }\r\n\r\n &.zoom-60 {\r\n font-size: 1em;\r\n }\r\n\r\n &.zoom-50 {\r\n font-size: 0.95em;\r\n }\r\n\r\n &.zoom-40 {\r\n font-size: 0.9em;\r\n }\r\n\r\n &.zoom-30 {\r\n font-size: 0.85em;\r\n }\r\n\r\n &.zoom-20 {\r\n font-size: 0.8em;\r\n }\r\n\r\n &.zoom-10 {\r\n font-size: 0.75em;\r\n }\r\n\r\n &.zoom-0 {\r\n font-size: 0.7em;\r\n }\r\n }\r\n}\r\n\r\n.manage-menu {\r\n position: relative;\r\n\r\n .context-menu {\r\n border-left: 4px dotted #000;\r\n width: 1px;\r\n height: 100%;\r\n }\r\n\r\n .context-menu-container {\r\n position: absolute;\r\n display: none;\r\n background: #FFF;\r\n box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.1);\r\n top: 2px;\r\n left: 2px;\r\n\r\n ul {\r\n list-style-type: none;\r\n margin: 0;\r\n padding: 0;\r\n\r\n li {\r\n a {\r\n display: block;\r\n padding: 7px 15px;\r\n white-space: nowrap;\r\n\r\n &:hover {\r\n background: #f8f8f8;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n &:hover {\r\n .context-menu-container {\r\n display: block;\r\n }\r\n }\r\n}\r\n\r\n.wiki-categories {\r\n display: grid;\r\n gap: 10px;\r\n margin-top: 25px;\r\n grid-template-columns: 1fr 1fr 1fr 1fr;\r\n\r\n .category {\r\n background: #FFF;\r\n padding: 10px;\r\n\r\n .users {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr 1fr 1fr;\r\n gap: 5px;\r\n\r\n .user {\r\n display: flex;\r\n height: 25px;\r\n width: 25px;\r\n border-radius: 50%;\r\n background: #ccc;\r\n justify-content: center;\r\n align-items: center;\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n .actions {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr;\r\n\r\n a {\r\n display: block;\r\n color: $cBlack;\r\n font-size: 13px;\r\n text-align: center;\r\n }\r\n }\r\n\r\n .title {\r\n margin-bottom: 5px;\r\n\r\n a {\r\n display: block;\r\n color: $cBlack;\r\n font-size: 13px;\r\n font-weight: 600;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.bootstrap-datetimepicker-widget .picker-switch {\r\n a {\r\n display: block;\r\n color: #000;\r\n }\r\n}\r\n\r\n.gantt_users {\r\n display: flex;\r\n gap: 20px;\r\n}\r\n\r\n#g-results {\r\n background: #FFF;\r\n padding: 25px;\r\n}\r\n\r\n.g-menu-container {\r\n margin-bottom: 15px;\r\n\r\n .right-menu {\r\n display: none;\r\n }\r\n}\r\n\r\n.g-center {\r\n text-align: center;\r\n}\r\n\r\n.alert {\r\n background: $cGreen;\r\n border: 0;\r\n color: #FFF;\r\n}\r\n\r\n.tasks_main_view {\r\n display: flex;\r\n gap: 20px;\r\n\r\n ._left_column {\r\n padding: 25px;\r\n background: #fcfcfc;\r\n border-right: 1px solid #e8e8e8;\r\n width: 350px;\r\n\r\n label {\r\n font-weight: 400;\r\n font-size: 14px;\r\n }\r\n\r\n select[name=\"filtr\"] {\r\n margin-bottom: 10px;\r\n }\r\n\r\n ._buttons {\r\n display: flex;\r\n gap: 10px;\r\n justify-content: space-between;\r\n\r\n .btn {\r\n flex: 1;\r\n }\r\n }\r\n }\r\n\r\n ._right_column {\r\n flex: 1;\r\n max-width: calc(100% - 350px);\r\n }\r\n}\r\n\r\n#billing-summary {\r\n .card-header {\r\n padding: 10px;\r\n }\r\n\r\n .billing-kpi {\r\n border: 1px solid #dee2e6;\r\n border-radius: 6px;\r\n padding: 10px 12px;\r\n background: #ffffff;\r\n box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);\r\n }\r\n\r\n .billing-kpi-label {\r\n font-size: 12px;\r\n color: #6c757d;\r\n margin-bottom: 3px;\r\n }\r\n\r\n .billing-kpi-value {\r\n font-size: 21px;\r\n font-weight: 700;\r\n line-height: 1.1;\r\n }\r\n\r\n .billing-details-row {\r\n display: none;\r\n }\r\n\r\n .billing-client-name {\r\n font-weight: 600;\r\n }\r\n\r\n .billing-table>thead>tr>th {\r\n background: #f8f9fa;\r\n }\r\n\r\n .billing-details-wrap {\r\n background: #f8fbff;\r\n }\r\n}\r\n\r\n/* sidebar submenu */\r\n\r\n/* vacations module */\r\n\r\n.vacation-type-badge {\r\n display: inline-block;\r\n padding: 2px 8px;\r\n border-radius: 4px;\r\n font-size: 12px;\r\n font-weight: 500;\r\n background: #e3f0ff;\r\n color: #2563eb;\r\n\r\n &.type-chorobowe {\r\n background: #fff3e0;\r\n color: #e65100;\r\n }\r\n\r\n &.type-inna_nieobecnosc {\r\n background: #f3e5f5;\r\n color: #7b1fa2;\r\n }\r\n}"]} \ No newline at end of file +{"version":3,"sources":["style.scss"],"names":[],"mappings":"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","file":"style.css","sourcesContent":["$cBlue: #6690F4;\r\n$cRed: #cc563d;\r\n$cGreen: #099885;\r\n$cBlack: #4e5e6a;\r\n\r\n.default-btn {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 40px;\r\n border-radius: 6px;\r\n padding: 0 15px;\r\n transition: all .3s ease;\r\n\r\n &:hover {\r\n text-decoration: none;\r\n }\r\n}\r\n\r\n.animate {\r\n animation: mymove 3s infinite;\r\n}\r\n\r\n.text-right {\r\n text-align: right;\r\n}\r\n\r\n.nowrap {\r\n white-space: nowrap;\r\n}\r\n\r\ntable {\r\n border-collapse: collapse;\r\n font-size: 13px;\r\n}\r\n\r\nsmall {\r\n font-size: .75em;\r\n}\r\n\r\n@keyframes mymove {\r\n 50% {\r\n opacity: .33;\r\n }\r\n}\r\n\r\n/* motion */\r\n@keyframes gradient-animation {\r\n 0% {\r\n background-position: 15% 0%;\r\n }\r\n\r\n 50% {\r\n background-position: 85% 100%;\r\n }\r\n\r\n 100% {\r\n background-position: 15% 0%;\r\n }\r\n}\r\n\r\n@keyframes frame-enter {\r\n 0% {\r\n clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), 3px calc(100% - 3px), 3px 100%, 100% 100%, 100% 0%, 0% 0%);\r\n }\r\n\r\n 25% {\r\n clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) calc(100% - 3px), calc(100% - 3px) 100%, 100% 100%, 100% 0%, 0% 0%);\r\n }\r\n\r\n 50% {\r\n clip-path: polygon(0% 100%, 3px 100%, 3px 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, calc(100% - 3px) 3px, 100% 0%, 0% 0%);\r\n }\r\n\r\n 75% {\r\n -webkit-clip-path: polygon(0% 100%, 3px 100%, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 3px, 3px 0%, 0% 0%);\r\n }\r\n\r\n 100% {\r\n -webkit-clip-path: polygon(0% 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 3px 100%, 0% 100%);\r\n }\r\n}\r\n\r\n* {\r\n box-sizing: border-box;\r\n}\r\n\r\nbody {\r\n font-family: \"Open Sans\", sans-serif;\r\n margin: 0;\r\n padding: 0;\r\n font-size: 15px;\r\n color: #4e5e6a;\r\n}\r\n\r\n.btn {\r\n padding: 9px 25px;\r\n transition: all 0.3s ease;\r\n color: #FFF;\r\n border: 0;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n display: inline-flex;\r\n text-decoration: none;\r\n gap: 5px;\r\n justify-content: center;\r\n align-items: center;\r\n\r\n &.btn_small,\r\n &.btn-xs,\r\n &.btn-sm {\r\n padding: 5px 7px;\r\n font-size: 13px;\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n &.btn-success {\r\n background: $cGreen;\r\n\r\n &:hover {\r\n background: #4a9c3b;\r\n }\r\n }\r\n\r\n &.btn-primary {\r\n background: $cBlue;\r\n\r\n &:hover {\r\n background: #3164db;\r\n }\r\n }\r\n\r\n &.btn-danger {\r\n background: $cRed;\r\n\r\n &:hover {\r\n background: #b30000;\r\n }\r\n }\r\n}\r\n\r\n.hide {\r\n display: none;\r\n}\r\n\r\n.form-error {\r\n color: $cRed;\r\n font-size: 13px;\r\n}\r\n\r\n.input-group {\r\n margin-bottom: 10px;\r\n}\r\n\r\n.form-field {\r\n margin-bottom: 15px;\r\n\r\n label {\r\n display: block;\r\n font-size: 13px;\r\n font-weight: 600;\r\n margin-bottom: 4px;\r\n color: #4e5e6a;\r\n }\r\n}\r\n\r\n.password-wrap {\r\n position: relative;\r\n\r\n .form-control {\r\n padding-right: 40px;\r\n }\r\n\r\n .password-eye {\r\n position: absolute;\r\n right: 10px;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n color: #999;\r\n text-decoration: none;\r\n z-index: 2;\r\n\r\n &:hover {\r\n color: #333;\r\n }\r\n }\r\n}\r\n\r\ninput[type=\"checkbox\"] {\r\n border: 1px solid #cdcdcd;\r\n}\r\n\r\n.form-control {\r\n border: 1px solid #cdcdcd;\r\n border-radius: 6px;\r\n height: 35px;\r\n width: 100%;\r\n padding: 5px;\r\n font-family: \"Open Sans\", sans-serif;\r\n\r\n option {\r\n padding: 5px;\r\n }\r\n\r\n &:focus {\r\n border: 1px solid $cBlue;\r\n outline: none;\r\n }\r\n}\r\n\r\n.unlogged {\r\n background: #EEF1F9;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 100vh;\r\n\r\n .box-login {\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 6px;\r\n width: 400px;\r\n\r\n .title {\r\n text-align: center;\r\n padding: 10px 10px 25px;\r\n border-bottom: 1px solid #cdcdcd;\r\n font-size: 20px;\r\n margin-bottom: 25px;\r\n }\r\n }\r\n}\r\n\r\n$sidebar-width: 220px;\r\n$sidebar-collapsed-width: 60px;\r\n$sidebar-bg: #1e2a3a;\r\n$sidebar-text: #c2c7d0;\r\n$sidebar-active: #fff;\r\n$sidebar-hover-bg: rgba(255, 255, 255, 0.08);\r\n\r\n.sidebar {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: $sidebar-width;\r\n height: 100vh;\r\n background: $sidebar-bg;\r\n display: flex;\r\n flex-direction: column;\r\n z-index: 1000;\r\n transition: width 0.3s ease;\r\n overflow: hidden;\r\n\r\n &.collapsed {\r\n width: $sidebar-collapsed-width;\r\n\r\n .sidebar-header .sidebar-logo span,\r\n .sidebar-nav ul li a span,\r\n .sidebar-footer span,\r\n .sidebar-footer .sidebar-user span {\r\n display: none;\r\n }\r\n\r\n .sidebar-header .sidebar-logo {\r\n font-size: 0;\r\n\r\n &::first-letter {\r\n font-size: 16px;\r\n }\r\n }\r\n\r\n .sidebar-nav ul li a {\r\n justify-content: center;\r\n padding: 10px;\r\n\r\n i {\r\n margin-right: 0;\r\n }\r\n }\r\n\r\n .sidebar-nav ul li.has-submenu {\r\n .submenu-arrow {\r\n display: none;\r\n }\r\n\r\n .sidebar-submenu {\r\n display: none;\r\n }\r\n }\r\n\r\n .sidebar-footer .sidebar-footer-link,\r\n .sidebar-footer .sidebar-user {\r\n justify-content: center;\r\n padding: 8px 10px;\r\n\r\n i {\r\n margin-right: 0;\r\n }\r\n }\r\n }\r\n\r\n .sidebar-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 15px;\r\n border-bottom: 1px solid rgba(255, 255, 255, 0.1);\r\n\r\n .sidebar-logo {\r\n color: $cBlue;\r\n text-decoration: none;\r\n font-size: 16px;\r\n white-space: nowrap;\r\n\r\n span {\r\n font-weight: 700;\r\n }\r\n }\r\n\r\n .sidebar-toggle {\r\n cursor: pointer;\r\n color: $sidebar-text;\r\n font-size: 16px;\r\n transition: color 0.2s ease;\r\n\r\n &:hover {\r\n color: #fff;\r\n }\r\n }\r\n }\r\n\r\n .sidebar-nav {\r\n flex: 1;\r\n overflow-y: auto;\r\n padding: 10px 0;\r\n\r\n ul {\r\n list-style: none;\r\n margin: 0;\r\n padding: 0;\r\n\r\n li {\r\n a {\r\n display: flex;\r\n align-items: center;\r\n padding: 10px 15px;\r\n color: $sidebar-text;\r\n text-decoration: none;\r\n font-size: 14px;\r\n transition: all 0.2s ease;\r\n white-space: nowrap;\r\n\r\n i {\r\n width: 20px;\r\n text-align: center;\r\n margin-right: 10px;\r\n font-size: 15px;\r\n }\r\n\r\n &:hover {\r\n background: $sidebar-hover-bg;\r\n color: $sidebar-active;\r\n }\r\n }\r\n\r\n &.active a {\r\n background: $sidebar-hover-bg;\r\n color: $sidebar-active;\r\n font-weight: 600;\r\n }\r\n\r\n &.has-submenu {\r\n >a .submenu-arrow {\r\n margin-left: auto;\r\n font-size: 12px;\r\n transition: transform 0.2s ease;\r\n width: auto;\r\n }\r\n\r\n &.open>a .submenu-arrow {\r\n transform: rotate(180deg);\r\n }\r\n\r\n .sidebar-submenu {\r\n max-height: 0;\r\n overflow: hidden;\r\n transition: max-height 0.25s ease;\r\n background: rgba(0, 0, 0, 0.15);\r\n\r\n li a {\r\n padding: 8px 15px 8px 45px;\r\n font-size: 13px;\r\n\r\n i {\r\n font-size: 13px;\r\n width: 16px;\r\n }\r\n }\r\n }\r\n\r\n &.open .sidebar-submenu {\r\n max-height: 200px;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n .sidebar-footer {\r\n border-top: 1px solid rgba(255, 255, 255, 0.1);\r\n padding: 10px 0;\r\n\r\n .sidebar-user {\r\n display: flex;\r\n align-items: center;\r\n padding: 8px 15px;\r\n color: $sidebar-text;\r\n font-size: 13px;\r\n white-space: nowrap;\r\n overflow: hidden;\r\n\r\n i {\r\n margin-right: 10px;\r\n color: $cBlue;\r\n }\r\n }\r\n\r\n .sidebar-footer-link {\r\n display: flex;\r\n align-items: center;\r\n padding: 8px 15px;\r\n color: $sidebar-text;\r\n text-decoration: none;\r\n font-size: 13px;\r\n transition: all 0.2s ease;\r\n white-space: nowrap;\r\n\r\n i {\r\n width: 20px;\r\n text-align: center;\r\n margin-right: 10px;\r\n }\r\n\r\n &:hover {\r\n background: $sidebar-hover-bg;\r\n color: $sidebar-active;\r\n }\r\n\r\n &.logout {\r\n color: $cRed;\r\n\r\n &:hover {\r\n color: #e07a66;\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n.content-wrapper {\r\n margin-left: $sidebar-width;\r\n min-height: 100vh;\r\n transition: margin-left 0.3s ease;\r\n\r\n &.expanded {\r\n margin-left: $sidebar-collapsed-width;\r\n }\r\n}\r\n\r\n.top-bar {\r\n background: #fff;\r\n border-bottom: 1px solid #e8e8e8;\r\n padding: 10px 20px;\r\n display: flex;\r\n align-items: center;\r\n\r\n .top-bar-left {\r\n display: flex;\r\n align-items: center;\r\n gap: 15px;\r\n\r\n i {\r\n cursor: pointer;\r\n font-size: 18px;\r\n color: #4e5e6a;\r\n\r\n &:hover {\r\n color: #000;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.main {\r\n padding: 25px;\r\n background: #D9DEE2;\r\n min-height: calc(100vh - 45px);\r\n}\r\n\r\n.tasks_container {\r\n display: grid;\r\n grid-template-columns: repeat(5, 1fr);\r\n gap: 20px;\r\n\r\n .column {\r\n width: 100%;\r\n\r\n h2 {\r\n display: flex;\r\n padding: 10px;\r\n background: #FFF;\r\n margin-bottom: 10px;\r\n font-size: 15px;\r\n font-weight: 300;\r\n border-radius: 3px 3px 0 0;\r\n justify-content: space-between;\r\n align-items: center;\r\n\r\n i {\r\n cursor: pointer;\r\n }\r\n }\r\n\r\n &.tasks_suspended {\r\n h2 {\r\n border-bottom: 5px solid $cRed;\r\n }\r\n }\r\n\r\n &.tasks_fvat {\r\n h2 {\r\n border-bottom: 5px solid #a900fc;\r\n }\r\n }\r\n\r\n &.tasks_new {\r\n h2 {\r\n border-bottom: 5px solid #ccc;\r\n }\r\n }\r\n\r\n &.tasks_bulk {\r\n h2 {\r\n border-bottom: 5px solid #ff8c00;\r\n }\r\n }\r\n\r\n &.tasks_to_do {\r\n h2 {\r\n border-bottom: 5px solid #2aaf47;\r\n }\r\n }\r\n\r\n &.tasks_to_review {\r\n h2 {\r\n border-bottom: 5px solid #2535c9;\r\n }\r\n }\r\n\r\n &.tasks_closed {\r\n h2 {\r\n border-bottom: 5px solid #000;\r\n }\r\n }\r\n\r\n ul {\r\n list-style-type: none;\r\n margin: 0;\r\n padding: 0;\r\n\r\n .task {\r\n margin-bottom: 5px;\r\n background: #FFF;\r\n padding: 10px;\r\n border-radius: 0;\r\n display: flex;\r\n position: relative;\r\n border-radius: 6px;\r\n flex-wrap: wrap;\r\n\r\n &.notopened {\r\n border: 2px solid $cRed;\r\n }\r\n\r\n .top {\r\n display: flex;\r\n justify-content: space-between;\r\n margin-bottom: 5px;\r\n width: 100%;\r\n\r\n ._users {\r\n display: flex;\r\n gap: 5px;\r\n flex-wrap: wrap;\r\n\r\n .user {\r\n display: flex;\r\n width: 25px;\r\n height: 25px;\r\n border-radius: 6px;\r\n justify-content: center;\r\n align-items: center;\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n ._timer {\r\n display: flex;\r\n gap: 5px;\r\n\r\n .recursively {\r\n color: #FFF;\r\n background: #405189;\r\n border-radius: 3px;\r\n cursor: pointer;\r\n margin-bottom: 5px;\r\n width: 25px;\r\n height: 25px;\r\n text-align: center;\r\n display: block;\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n .task_start {\r\n display: block;\r\n background: $cGreen;\r\n color: #FFF;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n margin-bottom: 5px;\r\n width: 25px;\r\n height: 25px;\r\n text-align: center;\r\n\r\n &.hidden {\r\n display: none;\r\n }\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n .task_end {\r\n background: $cRed;\r\n display: block;\r\n color: #FFF;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n margin-bottom: 5px;\r\n width: 25px;\r\n height: 25px;\r\n text-align: center;\r\n\r\n &.hidden {\r\n display: none;\r\n }\r\n\r\n i {\r\n font-size: 12px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .middle {\r\n width: 100%;\r\n }\r\n\r\n .name {\r\n font-size: 14px;\r\n color: #333;\r\n text-decoration: none;\r\n display: block;\r\n margin-bottom: 5px;\r\n }\r\n\r\n .bottom {\r\n display: flex;\r\n justify-content: space-between;\r\n }\r\n\r\n .client_info,\r\n .current_status {\r\n font-size: 12px;\r\n font-weight: 400;\r\n\r\n strong {\r\n font-weight: 600;\r\n }\r\n }\r\n\r\n .current_status {\r\n position: relative;\r\n cursor: pointer;\r\n\r\n .status_change {\r\n position: absolute;\r\n left: 0;\r\n top: 20px;\r\n background: #fff;\r\n padding: 15px;\r\n border: 1px solid #dfdfdf;\r\n border-radius: 3px;\r\n cursor: pointer;\r\n box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);\r\n z-index: 99;\r\n display: none;\r\n\r\n select {\r\n width: 250px;\r\n padding: 10px;\r\n border: 1px solid #cdcdcd;\r\n border-radius: 3px;\r\n\r\n option {\r\n font-size: 15px;\r\n padding: 3px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .dates {\r\n margin-bottom: 5px;\r\n display: flex;\r\n justify-content: space-between;\r\n font-size: 12px;\r\n\r\n .danger {\r\n color: $cRed;\r\n font-weight: 600;\r\n }\r\n\r\n .warning {\r\n color: #ff8c00;\r\n }\r\n\r\n i {\r\n font-size: 12px;\r\n color: #C9CED4;\r\n margin-right: 5px;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n/* page header */\r\n.block-header {\r\n margin-bottom: 20px;\r\n\r\n h2 {\r\n font-size: 20px;\r\n font-weight: 400;\r\n color: $cBlack;\r\n margin: 0;\r\n padding-bottom: 12px;\r\n border-bottom: 2px solid #e2e6ec;\r\n\r\n strong {\r\n font-weight: 700;\r\n }\r\n }\r\n}\r\n\r\n/* filters bar — reusable across modules */\r\n.filters-bar {\r\n display: flex;\r\n align-items: center;\r\n gap: 10px;\r\n flex-wrap: wrap;\r\n margin-bottom: 24px;\r\n padding: 12px 16px;\r\n background: #f5f7fa;\r\n border-radius: 8px;\r\n border: 1px solid #e2e6ec;\r\n\r\n select,\r\n input[type=\"text\"],\r\n input[type=\"date\"],\r\n input[type=\"number\"] {\r\n height: 36px;\r\n min-width: 170px;\r\n padding: 0 10px;\r\n border: 1px solid #d0d5dd;\r\n border-radius: 6px;\r\n background: #fff;\r\n font-size: 13px;\r\n color: $cBlack;\r\n font-family: \"Open Sans\", sans-serif;\r\n transition: border-color 0.2s;\r\n\r\n &:focus {\r\n border-color: $cBlue;\r\n outline: none;\r\n }\r\n }\r\n\r\n .btn {\r\n height: 36px;\r\n display: inline-flex;\r\n align-items: center;\r\n gap: 5px;\r\n padding: 0 14px;\r\n border-radius: 6px;\r\n font-size: 13px;\r\n font-weight: 500;\r\n border: none;\r\n cursor: pointer;\r\n transition: background 0.2s, box-shadow 0.2s;\r\n text-decoration: none;\r\n color: #fff;\r\n\r\n &.btn-primary {\r\n background: $cBlue;\r\n\r\n &:hover {\r\n background: #4a74d4;\r\n }\r\n }\r\n\r\n &.btn-success {\r\n background: $cGreen;\r\n\r\n &:hover {\r\n background: #077a6b;\r\n }\r\n }\r\n }\r\n}\r\n\r\n/* section title — reusable */\r\n.section-title {\r\n font-size: 14px;\r\n font-weight: 600;\r\n color: $cBlack;\r\n margin: 28px 0 12px;\r\n padding-bottom: 8px;\r\n border-bottom: 1px solid #e2e6ec;\r\n}\r\n\r\n.action_menu {\r\n display: flex;\r\n margin-bottom: 25px;\r\n gap: 20px;\r\n\r\n .btn {\r\n display: inline-flex;\r\n padding: 7px 15px;\r\n color: #FFF;\r\n text-decoration: none;\r\n align-items: center;\r\n justify-content: center;\r\n gap: 5px;\r\n\r\n &.btn_add {\r\n background: $cGreen;\r\n\r\n &:hover {\r\n background: #4a9c3b;\r\n }\r\n }\r\n\r\n &.btn_cancel {\r\n background: $cRed;\r\n\r\n &:hover {\r\n background: #b30000;\r\n }\r\n }\r\n\r\n &.disabled {\r\n opacity: .5;\r\n }\r\n }\r\n}\r\n\r\n.form_container {\r\n background: #FFF;\r\n padding: 25px;\r\n max-width: 1300px;\r\n\r\n &.full {\r\n max-width: 100%;\r\n }\r\n\r\n .form_group {\r\n margin-bottom: 10px;\r\n display: flex;\r\n\r\n >.label {\r\n width: 300px;\r\n display: inline-flex;\r\n align-items: flex-start;\r\n justify-content: right;\r\n padding-right: 10px;\r\n }\r\n\r\n .input {\r\n width: calc(100% - 300px);\r\n }\r\n }\r\n}\r\n\r\n.fullscreen_description {\r\n position: fixed !important;\r\n top: 25px;\r\n left: 25px;\r\n right: 25px;\r\n bottom: 25px;\r\n z-index: 9999;\r\n background: white;\r\n padding: 20px;\r\n overflow: auto;\r\n border-radius: 0.25rem;\r\n box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);\r\n}\r\n\r\n.fullscreen {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n color: #FFF;\r\n background: $cRed;\r\n display: inline-flex;\r\n height: 40px;\r\n width: 40px;\r\n border-radius: 6px;\r\n align-items: center;\r\n justify-content: center;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n transform: scale(1.05);\r\n text-decoration: none;\r\n }\r\n}\r\n\r\n.task_popup {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background: rgba(0, 0, 0, 0.5);\r\n display: none;\r\n z-index: 9999;\r\n\r\n .task_details {\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 6px;\r\n max-width: 1140px;\r\n width: 100%;\r\n transition: all 0.3s ease;\r\n height: 90vh;\r\n\r\n .content {\r\n height: calc(100% - 50px);\r\n }\r\n\r\n &.open_works_time {\r\n max-width: 1540px;\r\n\r\n .content {\r\n grid-template-columns: 1fr 300px 350px;\r\n\r\n .task_work_details {\r\n display: block;\r\n }\r\n }\r\n }\r\n\r\n .title {\r\n font-size: 20px;\r\n margin-bottom: 25px;\r\n display: flex;\r\n align-items: center;\r\n gap: 10px;\r\n\r\n a {\r\n border: 1px solid $cGreen;\r\n display: inline-flex;\r\n height: 30px;\r\n width: 30px;\r\n border-radius: 6px;\r\n align-items: center;\r\n justify-content: center;\r\n\r\n &:hover {\r\n text-decoration: none;\r\n }\r\n\r\n i {\r\n color: $cGreen;\r\n }\r\n\r\n &.task-delete {\r\n border: 1px solid $cRed;\r\n\r\n i {\r\n color: $cRed;\r\n }\r\n }\r\n\r\n i {\r\n font-size: 14px;\r\n }\r\n }\r\n\r\n .task-title-edit-box {\r\n align-items: center;\r\n gap: 6px;\r\n\r\n .task-title-input {\r\n height: 30px;\r\n font-size: 14px;\r\n padding: 2px 8px;\r\n width: 300px;\r\n border: 1px solid #ccc;\r\n border-radius: 4px;\r\n }\r\n\r\n a.task-title-save,\r\n a.task-title-cancel {\r\n height: 30px;\r\n width: 30px;\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n border-radius: 6px;\r\n\r\n i {\r\n font-size: 13px;\r\n }\r\n }\r\n\r\n a.task-title-save {\r\n background: $cGreen;\r\n border-color: $cGreen;\r\n\r\n i {\r\n color: #fff;\r\n }\r\n }\r\n\r\n a.task-title-cancel {\r\n background: $cRed;\r\n border-color: $cRed;\r\n\r\n i {\r\n color: #fff;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .close {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n }\r\n\r\n .content {\r\n display: grid;\r\n font-size: 14px;\r\n grid-template-columns: 1fr 300px;\r\n gap: 30px;\r\n transition: all 0.3s ease;\r\n\r\n h3 {\r\n width: 100%;\r\n margin-top: 0;\r\n margin-bottom: 5px;\r\n font-weight: 500;\r\n color: #000;\r\n font-size: 17px;\r\n }\r\n\r\n .left {\r\n height: 100%;\r\n overflow: hidden;\r\n\r\n .users {\r\n display: flex;\r\n gap: 20px;\r\n\r\n .user {\r\n display: flex;\r\n gap: 10px;\r\n align-items: center;\r\n margin-bottom: 10px;\r\n\r\n .avatar {\r\n height: 30px;\r\n width: 30px;\r\n border-radius: 6px;\r\n background: #ccc;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n }\r\n\r\n .comments {\r\n border-radius: 3px;\r\n max-height: 406px;\r\n overflow-y: auto;\r\n\r\n .new_comment {\r\n margin-bottom: 10px;\r\n\r\n textarea {\r\n height: 75px;\r\n margin-bottom: 10px;\r\n border-radius: 6px;\r\n }\r\n\r\n .add_comment {\r\n background: $cGreen;\r\n color: #FFF;\r\n padding: 10px;\r\n border-radius: 6px;\r\n cursor: pointer;\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n width: 200px;\r\n text-decoration: none;\r\n\r\n &:hover {\r\n background: #4a9c3b;\r\n }\r\n }\r\n }\r\n\r\n ul {\r\n margin: 0;\r\n padding: 0;\r\n list-style-type: none;\r\n\r\n li {\r\n background: #ced4da;\r\n margin-bottom: 5px;\r\n padding: 15px;\r\n border-radius: 6px;\r\n position: relative;\r\n\r\n .delete_comment {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n color: $cRed;\r\n }\r\n\r\n .author {\r\n font-weight: 600;\r\n margin-bottom: 5px;\r\n display: inline-flex;\r\n margin-right: 10px;\r\n }\r\n\r\n .date {\r\n font-size: 12px;\r\n margin-bottom: 5px;\r\n display: inline-flex;\r\n }\r\n\r\n .text {\r\n margin-bottom: 15px;\r\n font-size: 13px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .checklist {\r\n border-radius: 3px;\r\n margin-bottom: 10px;\r\n\r\n .new_element {\r\n display: flex;\r\n margin-bottom: 10px;\r\n\r\n input {\r\n border-radius: 6px 0 0 6px;\r\n }\r\n\r\n a {\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n padding: 10px;\r\n border-radius: 0 6px 6px 0;\r\n text-decoration: none;\r\n width: 35px;\r\n background: $cGreen;\r\n color: #FFF;\r\n }\r\n }\r\n\r\n ul {\r\n margin: 0;\r\n padding: 0;\r\n list-style-type: none;\r\n overflow-y: auto;\r\n max-height: calc(90vh - 400px);\r\n\r\n li {\r\n display: flex;\r\n gap: 10px;\r\n margin-bottom: 5px;\r\n background: #FFF;\r\n border-radius: 3px;\r\n padding: 10px;\r\n border: 1px solid #cdcdcd;\r\n font-size: 13px;\r\n align-items: flex-start;\r\n\r\n a {\r\n margin-left: auto;\r\n margin-right: 0;\r\n cursor: pointer;\r\n background: $cRed;\r\n display: flex;\r\n height: 25px;\r\n width: 25px;\r\n min-width: 25px;\r\n justify-content: center;\r\n align-items: center;\r\n border: 0;\r\n border-radius: 3px;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n text-decoration: none;\r\n background: #b30000;\r\n }\r\n\r\n i {\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n .attachments {\r\n margin-top: 10px;\r\n border: 1px solid #e6e9ed;\r\n border-radius: 8px;\r\n padding: 12px;\r\n background: #f9fbfd;\r\n\r\n h3 {\r\n margin-bottom: 10px;\r\n font-size: 16px;\r\n font-weight: 600;\r\n }\r\n\r\n .attachments_upload {\r\n display: flex;\r\n gap: 10px;\r\n align-items: center;\r\n margin-bottom: 10px;\r\n\r\n .attachment_file_input {\r\n flex: 1;\r\n margin-bottom: 0;\r\n border-radius: 6px;\r\n background: #fff;\r\n }\r\n\r\n .attachment-upload-btn {\r\n white-space: nowrap;\r\n border-radius: 6px;\r\n min-width: 150px;\r\n\r\n &.is-loading {\r\n pointer-events: none;\r\n opacity: 0.85;\r\n\r\n i {\r\n margin-right: 6px;\r\n }\r\n }\r\n }\r\n }\r\n\r\n .attachments_list {\r\n margin: 0;\r\n padding: 0;\r\n list-style: none;\r\n display: grid;\r\n gap: 8px;\r\n max-height: 180px;\r\n overflow-y: auto;\r\n\r\n li {\r\n display: flex;\r\n align-items: center;\r\n gap: 8px;\r\n background: #fff;\r\n border: 1px solid #e4e8ee;\r\n border-radius: 6px;\r\n padding: 8px 10px;\r\n\r\n .attachment-link {\r\n color: #1f3d72;\r\n text-decoration: none;\r\n font-weight: 600;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n max-width: calc(100% - 140px);\r\n\r\n &:hover {\r\n text-decoration: underline;\r\n }\r\n }\r\n\r\n small {\r\n color: #6b7280;\r\n margin-right: auto;\r\n }\r\n\r\n .attachment-rename,\r\n .attachment-delete {\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n height: 28px;\r\n width: 28px;\r\n border-radius: 4px;\r\n text-decoration: none;\r\n transition: all 0.2s ease;\r\n }\r\n\r\n .attachment-rename {\r\n border: 1px solid #d8e2f6;\r\n color: $cBlue;\r\n background: #f4f8ff;\r\n\r\n &:hover {\r\n background: #e7f0ff;\r\n }\r\n }\r\n\r\n .attachment-delete {\r\n border: 1px solid #f1d3d1;\r\n color: $cRed;\r\n background: #fff6f6;\r\n\r\n &:hover {\r\n background: #ffeaea;\r\n }\r\n }\r\n }\r\n\r\n .attachments-empty {\r\n color: #6b7280;\r\n border-style: dashed;\r\n justify-content: center;\r\n font-size: 13px;\r\n }\r\n }\r\n }\r\n\r\n .description {\r\n padding: 15px;\r\n border-radius: 0.25rem;\r\n border: 1px solid #cdcdcd;\r\n margin-bottom: 15px;\r\n max-height: 202px;\r\n overflow-x: hidden;\r\n position: relative;\r\n }\r\n }\r\n\r\n .right {\r\n\r\n .box {\r\n margin-bottom: 15px;\r\n }\r\n\r\n .time {\r\n a.time_worked_toggle {\r\n @extend .default-btn;\r\n color: #299cdb;\r\n display: inline-flex;\r\n border: 1px solid #299cdb;\r\n\r\n &:hover {\r\n background: #dff0fa;\r\n text-decoration: none;\r\n }\r\n\r\n &:active,\r\n &:focus {\r\n text-decoration: none;\r\n }\r\n }\r\n\r\n a:not(.time_worked_toggle) {\r\n @extend .default-btn;\r\n margin-top: 10px;\r\n text-decoration: none;\r\n gap: 10px;\r\n\r\n &.task_start {\r\n background: #0ab39c;\r\n color: #FFF;\r\n\r\n &:hover {\r\n background: #099885;\r\n }\r\n }\r\n\r\n &.task_end {\r\n background: $cRed;\r\n color: #FFF;\r\n }\r\n\r\n &.hidden {\r\n display: none;\r\n }\r\n }\r\n }\r\n\r\n .dates {\r\n display: flex;\r\n justify-content: space-between;\r\n flex-wrap: wrap;\r\n\r\n .danger {\r\n color: $cRed;\r\n font-weight: 600;\r\n }\r\n\r\n .warning {\r\n color: #ff8c00;\r\n }\r\n\r\n i {\r\n color: #C9CED4;\r\n margin-right: 5px;\r\n }\r\n }\r\n }\r\n\r\n .task_work_details {\r\n display: none;\r\n overflow-y: auto;\r\n max-height: 508px;\r\n width: 100%;\r\n padding-right: 10px;\r\n padding-top: 4px;\r\n\r\n ._line {\r\n display: flex;\r\n flex-wrap: wrap;\r\n justify-content: space-between;\r\n align-items: center;\r\n margin-bottom: 5px;\r\n\r\n ._user {\r\n width: 100%;\r\n font-size: 13px;\r\n }\r\n\r\n input {\r\n width: calc(50% - 25px);\r\n text-align: center;\r\n margin-left: 2px;\r\n margin-right: 2px;\r\n }\r\n }\r\n\r\n ._work_delete {\r\n display: inline-flex;\r\n height: 35px;\r\n width: 35px;\r\n border-radius: 6px;\r\n align-items: center;\r\n justify-content: center;\r\n cursor: pointer;\r\n border: 1px solid $cRed;\r\n margin-left: 2px;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n background: $cRed;\r\n\r\n i {\r\n color: #FFF;\r\n }\r\n }\r\n\r\n i {\r\n transition: all 0.3s ease;\r\n color: $cRed;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n.table {\r\n width: 100%;\r\n border: none;\r\n border-radius: 8px;\r\n overflow: hidden;\r\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);\r\n background: #fff;\r\n\r\n th,\r\n td {\r\n padding: 10px 14px;\r\n border: none;\r\n border-bottom: 1px solid #eef0f3;\r\n text-align: left;\r\n vertical-align: middle;\r\n }\r\n\r\n thead th {\r\n background: #f5f7fa;\r\n color: #4e5e6a;\r\n font-weight: 600;\r\n font-size: 12px;\r\n text-transform: uppercase;\r\n letter-spacing: 0.3px;\r\n white-space: nowrap;\r\n border-bottom: 2px solid #e2e6ec;\r\n }\r\n\r\n tbody tr {\r\n transition: background 0.15s ease;\r\n\r\n &:last-child td {\r\n border-bottom: none;\r\n }\r\n\r\n &:hover {\r\n background: #f8fafd;\r\n }\r\n }\r\n\r\n td.center,\r\n th.center {\r\n text-align: center;\r\n }\r\n\r\n td.left,\r\n th.left {\r\n text-align: left;\r\n }\r\n\r\n td.right,\r\n th.right {\r\n text-align: right;\r\n }\r\n\r\n // empty state\r\n td[colspan] {\r\n text-align: center;\r\n color: #8896a4;\r\n padding: 24px 14px;\r\n font-style: italic;\r\n }\r\n}\r\n\r\n.projects_container {\r\n background: #FFF;\r\n padding: 15px;\r\n border-radius: 6px;\r\n display: flex;\r\n gap: 20px;\r\n\r\n .left {\r\n width: calc(100% - 250px);\r\n\r\n ._projects,\r\n ._users {\r\n display: flex;\r\n gap: 20px;\r\n flex-wrap: wrap;\r\n }\r\n }\r\n\r\n .right {\r\n width: 250px;\r\n display: flex;\r\n flex-wrap: wrap;\r\n align-items: flex-start;\r\n justify-content: center;\r\n gap: 20px;\r\n border-left: 1px solid #cdcdcd;\r\n padding-left: 15px;\r\n\r\n select {\r\n width: 200px;\r\n }\r\n }\r\n}\r\n\r\n.default_popup {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background: rgba(0, 0, 0, 0.5);\r\n display: none;\r\n\r\n .popup_content {\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 0;\r\n max-width: 1140px;\r\n width: 100%;\r\n\r\n .close {\r\n position: absolute;\r\n top: 10px;\r\n right: 10px;\r\n cursor: pointer;\r\n }\r\n }\r\n}\r\n\r\n#fg-cron {\r\n margin: 10px 0;\r\n\r\n .countdown {\r\n background: $cGreen;\r\n color: #FFF;\r\n padding: 10px;\r\n }\r\n\r\n #cron-container {\r\n max-height: 300px;\r\n overflow-x: hidden;\r\n overflow-y: auto;\r\n\r\n .msg {\r\n font-size: 13px;\r\n padding: 5px;\r\n border-bottom: 1px solid #e8e8e8;\r\n }\r\n }\r\n}\r\n\r\n.card {\r\n background: #FFF;\r\n padding: 25px;\r\n border-radius: 6px;\r\n color: #000;\r\n font-size: 15px;\r\n max-width: 1280px;\r\n\r\n &.mb25 {\r\n margin-bottom: 25px;\r\n }\r\n\r\n .card-header {\r\n font-weight: 600;\r\n }\r\n\r\n .card-body {\r\n padding-top: 10px;\r\n\r\n table {\r\n border-collapse: collapse;\r\n\r\n th,\r\n td {\r\n font-size: 14px;\r\n\r\n &.bold {\r\n font-weight: 600;\r\n }\r\n\r\n &.text-right {\r\n text-align: right;\r\n }\r\n\r\n &.text-center {\r\n text-align: center;\r\n }\r\n\r\n .close-task {\r\n text-decoration: none;\r\n color: $cBlue;\r\n\r\n &:hover {\r\n color: $cRed;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\n.finance-summary {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr 1fr 1fr;\r\n gap: 10px;\r\n\r\n .panel {\r\n background: #FFF;\r\n border-radius: 6px;\r\n padding: 15px;\r\n\r\n h1 {\r\n font-size: 20px;\r\n margin: 0;\r\n }\r\n\r\n span {\r\n font-size: 0.85em;\r\n }\r\n }\r\n}\r\n\r\n.finance-manager {\r\n display: grid;\r\n gap: 10px;\r\n grid-template-columns: 200px 1fr 500px;\r\n padding-top: 25px;\r\n\r\n .manage-menu {\r\n display: inline-block;\r\n margin-right: 10px;\r\n\r\n a {\r\n color: #333333;\r\n text-decoration: none;\r\n font-weight: 300;\r\n display: block;\r\n }\r\n }\r\n\r\n .actions {\r\n width: 100px;\r\n text-align: center;\r\n\r\n a {\r\n display: inline-flex;\r\n margin: 0 2px;\r\n height: 25px;\r\n width: 25px;\r\n align-items: center;\r\n justify-content: center;\r\n text-decoration: none;\r\n color: #000;\r\n border: 1px solid #e7e7e7;\r\n font-size: 11px;\r\n border-radius: 3px;\r\n transition: all 0.3s ease;\r\n\r\n &:hover {\r\n border: 1px solid $cBlue;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.bootstrap-tagsinput {\r\n .tag {\r\n background: $cBlue;\r\n font-size: 13px;\r\n padding: 5px 10px;\r\n border-radius: 12px;\r\n\r\n [data-role=\"remove\"] {\r\n color: #FFF !important;\r\n\r\n &:hover {\r\n box-shadow: none !important;\r\n color: #000 !important\r\n }\r\n }\r\n }\r\n}\r\n\r\n.finance-tags {\r\n display: flex;\r\n flex-wrap: wrap;\r\n gap: 5px;\r\n\r\n a:not(.btn) {\r\n display: flex;\r\n width: 100%;\r\n text-decoration: none;\r\n color: $cBlack;\r\n\r\n &.zoom-100 {\r\n font-size: 1.2em;\r\n }\r\n\r\n &.zoom-90 {\r\n font-size: 1.15em;\r\n }\r\n\r\n &.zoom-80 {\r\n font-size: 1.1em;\r\n }\r\n\r\n &.zoom-70 {\r\n font-size: 1.05em;\r\n }\r\n\r\n &.zoom-60 {\r\n font-size: 1em;\r\n }\r\n\r\n &.zoom-50 {\r\n font-size: 0.95em;\r\n }\r\n\r\n &.zoom-40 {\r\n font-size: 0.9em;\r\n }\r\n\r\n &.zoom-30 {\r\n font-size: 0.85em;\r\n }\r\n\r\n &.zoom-20 {\r\n font-size: 0.8em;\r\n }\r\n\r\n &.zoom-10 {\r\n font-size: 0.75em;\r\n }\r\n\r\n &.zoom-0 {\r\n font-size: 0.7em;\r\n }\r\n }\r\n}\r\n\r\n.manage-menu {\r\n position: relative;\r\n\r\n .context-menu {\r\n border-left: 4px dotted #000;\r\n width: 1px;\r\n height: 100%;\r\n }\r\n\r\n .context-menu-container {\r\n position: absolute;\r\n display: none;\r\n background: #FFF;\r\n box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.1);\r\n top: 2px;\r\n left: 2px;\r\n\r\n ul {\r\n list-style-type: none;\r\n margin: 0;\r\n padding: 0;\r\n\r\n li {\r\n a {\r\n display: block;\r\n padding: 7px 15px;\r\n white-space: nowrap;\r\n\r\n &:hover {\r\n background: #f8f8f8;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n &:hover {\r\n .context-menu-container {\r\n display: block;\r\n }\r\n }\r\n}\r\n\r\n.wiki-categories {\r\n display: grid;\r\n gap: 10px;\r\n margin-top: 25px;\r\n grid-template-columns: 1fr 1fr 1fr 1fr;\r\n\r\n .category {\r\n background: #FFF;\r\n padding: 10px;\r\n\r\n .users {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr 1fr 1fr;\r\n gap: 5px;\r\n\r\n .user {\r\n display: flex;\r\n height: 25px;\r\n width: 25px;\r\n border-radius: 50%;\r\n background: #ccc;\r\n justify-content: center;\r\n align-items: center;\r\n color: #FFF;\r\n font-size: 12px;\r\n }\r\n }\r\n\r\n .actions {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr;\r\n\r\n a {\r\n display: block;\r\n color: $cBlack;\r\n font-size: 13px;\r\n text-align: center;\r\n }\r\n }\r\n\r\n .title {\r\n margin-bottom: 5px;\r\n\r\n a {\r\n display: block;\r\n color: $cBlack;\r\n font-size: 13px;\r\n font-weight: 600;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.bootstrap-datetimepicker-widget .picker-switch {\r\n a {\r\n display: block;\r\n color: #000;\r\n }\r\n}\r\n\r\n.gantt_users {\r\n display: flex;\r\n gap: 20px;\r\n}\r\n\r\n#g-results {\r\n background: #FFF;\r\n padding: 25px;\r\n}\r\n\r\n.g-menu-container {\r\n margin-bottom: 15px;\r\n\r\n .right-menu {\r\n display: none;\r\n }\r\n}\r\n\r\n.g-center {\r\n text-align: center;\r\n}\r\n\r\n.alert {\r\n background: $cGreen;\r\n border: 0;\r\n color: #FFF;\r\n}\r\n\r\n.tasks_main_view {\r\n display: flex;\r\n gap: 20px;\r\n\r\n ._left_column {\r\n padding: 25px;\r\n background: #fcfcfc;\r\n border-right: 1px solid #e8e8e8;\r\n width: 350px;\r\n\r\n label {\r\n font-weight: 400;\r\n font-size: 14px;\r\n }\r\n\r\n select[name=\"filtr\"] {\r\n margin-bottom: 10px;\r\n }\r\n\r\n ._buttons {\r\n display: flex;\r\n gap: 10px;\r\n justify-content: space-between;\r\n\r\n .btn {\r\n flex: 1;\r\n }\r\n }\r\n }\r\n\r\n ._right_column {\r\n flex: 1;\r\n max-width: calc(100% - 350px);\r\n }\r\n}\r\n\r\n#billing-summary {\r\n .card-header {\r\n padding: 10px;\r\n }\r\n\r\n .billing-kpi {\r\n border: 1px solid #dee2e6;\r\n border-radius: 6px;\r\n padding: 10px 12px;\r\n background: #ffffff;\r\n box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);\r\n }\r\n\r\n .billing-kpi-label {\r\n font-size: 12px;\r\n color: #6c757d;\r\n margin-bottom: 3px;\r\n }\r\n\r\n .billing-kpi-value {\r\n font-size: 21px;\r\n font-weight: 700;\r\n line-height: 1.1;\r\n }\r\n\r\n .billing-details-row {\r\n display: none;\r\n }\r\n\r\n .billing-client-name {\r\n font-weight: 600;\r\n }\r\n\r\n .billing-table>thead>tr>th {\r\n background: #f8f9fa;\r\n }\r\n\r\n .billing-details-wrap {\r\n background: #f8fbff;\r\n }\r\n}\r\n\r\n/* sidebar submenu */\r\n\r\n/* vacations module */\r\n\r\n.vacation-type-badge {\r\n display: inline-block;\r\n padding: 2px 8px;\r\n border-radius: 4px;\r\n font-size: 12px;\r\n font-weight: 500;\r\n background: #e3f0ff;\r\n color: #2563eb;\r\n\r\n &.type-chorobowe {\r\n background: #fff3e0;\r\n color: #e65100;\r\n }\r\n\r\n &.type-inna_nieobecnosc {\r\n background: #f3e5f5;\r\n color: #7b1fa2;\r\n }\r\n}"]} \ No newline at end of file diff --git a/layout/style.scss b/layout/style.scss index f00f10d..81d8108 100644 --- a/layout/style.scss +++ b/layout/style.scss @@ -1044,19 +1044,27 @@ $sidebar-hover-bg: rgba(255, 255, 255, 0.08); justify-content: center; border-radius: 6px; - i { font-size: 13px; } + i { + font-size: 13px; + } } a.task-title-save { background: $cGreen; border-color: $cGreen; - i { color: #fff; } + + i { + color: #fff; + } } a.task-title-cancel { background: $cRed; border-color: $cRed; - i { color: #fff; } + + i { + color: #fff; + } } } } diff --git a/templates/tasks/task_edit.php b/templates/tasks/task_edit.php index bb7dcb0..75e23f2 100644 --- a/templates/tasks/task_edit.php +++ b/templates/tasks/task_edit.php @@ -35,6 +35,23 @@ if ( is_array( $this -> clients ) ) foreach ( $this -> clients as $client ) $clients[ $client[ 'id' ] ] = $client[ 'firm' ]; +$wiki_categories = ( isset( $this -> wiki_categories ) and is_array( $this -> wiki_categories ) ) ? $this -> wiki_categories : []; +$current_user_id = isset( $this -> user['id'] ) ? (int)$this -> user['id'] : 0; +if ( !count( $wiki_categories ) and $current_user_id > 0 ) + $wiki_categories = \factory\Wiki::get_categories_for_user( $current_user_id ); +if ( !count( $wiki_categories ) ) + $wiki_categories = \factory\Wiki::get_all_categories(); +$task_wiki_ids = isset( $this -> task['wiki_ids'] ) && is_array( $this -> task['wiki_ids'] ) ? array_map( 'intval', $this -> task['wiki_ids'] ) : []; +$wiki_values = []; +if ( is_array( $wiki_categories ) ) + foreach ( $wiki_categories as $wiki_category ) + { + $wiki_id = isset( $wiki_category['id'] ) ? (int)$wiki_category['id'] : 0; + if ( !$wiki_id ) + continue; + $wiki_values[ $wiki_id ] = isset( $wiki_category['name'] ) ? (string)$wiki_category['name'] : (string)$wiki_id; + } + $parent_tasks = [ 0 => '--- wybierz zadanie nadrzędne ---' ]; if ( is_array( $this -> parent_tasks ) ) foreach ( $this -> parent_tasks as $parent_task ) @@ -130,6 +147,20 @@ ob_start(); 'values' => $parent_tasks ] ); ?> +
+ +
+ + + +
Brak dostepnych wpisow Wiki.
+ +
+
'Status', 'name' => 'status', @@ -434,6 +465,29 @@ ob_start(); font-style: italic; } + #wiki_ids + .select2-container { + width: 100% !important; + } + + #wiki_ids + .select2-container .select2-selection--multiple { + min-height: 38px; + border: 1px solid #cfd8e3; + border-radius: 4px; + padding: 2px 6px; + } + + #wiki_ids + .select2-container .select2-selection__choice { + margin-top: 4px; + max-width: 100%; + overflow-wrap: anywhere; + word-break: break-word; + } + + .task-wiki-empty { + color: #6b7280; + font-style: italic; + } + .task-edit-message { margin: 12px 0 16px 0; padding: 12px 16px; @@ -957,12 +1011,12 @@ echo $grid -> draw(); height: '100' }); - $( '#project_id, #client_id, #status, #parent_id, #priority' ).select2({ + $( '#project_id, #client_id, #status, #parent_id, #priority, #wiki_ids' ).select2({ theme: 'bootstrap-5', minimumResultsForSearch: 0 }); - $( '#project_id, #client_id, #status, #parent_id, #priority' ).on( 'select2:open', function() { + $( '#project_id, #client_id, #status, #parent_id, #priority, #wiki_ids' ).on( 'select2:open', function() { setTimeout( function() { var search_field = document.querySelector( '.select2-container--open .select2-search__field' ); if ( search_field ) diff --git a/templates/tasks/task_popup.php b/templates/tasks/task_popup.php index 52ad683..2ee4bcc 100644 --- a/templates/tasks/task_popup.php +++ b/templates/tasks/task_popup.php @@ -26,6 +26,10 @@ $checklist_count = is_array( $this -> task['actions'] ) ? count( $this -> task['actions'] ) : 0; $comments_count = is_array( $this -> task['comments'] ) ? count( $this -> task['comments'] ) : 0; $attachments_count = is_array( $this -> task_attachments ) ? count( $this -> task_attachments ) : 0; + $popup_wiki_data = \factory\Tasks::task_wiki_entries_for_user( (int)$this -> task['id'], (int)$this -> user['id'] ); + $task_wiki_entries = isset( $popup_wiki_data['entries'] ) && is_array( $popup_wiki_data['entries'] ) ? $popup_wiki_data['entries'] : []; + $wiki_visible_count = isset( $popup_wiki_data['visible_count'] ) ? (int)$popup_wiki_data['visible_count'] : 0; + $wiki_hidden_count = isset( $popup_wiki_data['hidden_count'] ) ? (int)$popup_wiki_data['hidden_count'] : 0; ?> task['text'] ); @@ -74,6 +78,7 @@ Lista kontrolna () Komentarze () Załączniki () + Wiki () user['id'] == 1 ):?> Uczestnicy @@ -177,6 +182,35 @@ +
+
+

Powiazane wpisy Wiki

+ 0 ):?> +
+ Nie masz dostepu do powiazanych wpisow Wiki. +
+ + +
+ +
+

+
+ + user['id'] == 1 or $this -> user['id'] == 3 ):?> + +
+ + +
+
+ +
+ +
Brak widocznych wpisow Wiki dla tego zadania.
+ +
+
user['id'] == 1 ):?>
@@ -407,6 +441,36 @@ font-weight: 600; } + .task_popup .task_details .task-wiki-list { + display: grid; + gap: 12px; + } + .task_popup .task_details .task-wiki-entry { + border: 1px solid #e5e7eb; + border-radius: 8px; + padding: 12px; + background: #fff; + } + .task_popup .task_details .task-wiki-entry h4 { + margin: 0 0 8px 0; + font-size: 14px; + font-weight: 700; + color: #1f3d72; + } + .task_popup .task_details .task-wiki-content { + font-size: 13px; + line-height: 1.5; + } + .task_popup .task_details .task-wiki-admin { + margin-top: 10px; + padding-top: 10px; + border-top: 1px dashed #d1d5db; + } + .task_popup .task_details .task-wiki-empty { + color: #6b7280; + font-style: italic; + } + /* Lightbox - powiększanie zdjęć w opisie */ .task_popup .task_details .description img { cursor: zoom-in; @@ -676,8 +740,16 @@ if ( !tab_panels.length ) return; - var allowed_tabs = [ 'description', 'checklist', 'comments', 'attachments', 'users' ]; - var selected_tab = allowed_tabs.indexOf( tab_name ) >= 0 ? tab_name : 'description'; + var available_tabs = []; + tab_buttons.each( function() { + var tab = $( this ).attr( 'data-tab' ); + if ( tab ) + available_tabs.push( tab ); + }); + + var selected_tab = available_tabs.indexOf( tab_name ) >= 0 ? tab_name : 'description'; + if ( available_tabs.indexOf( selected_tab ) < 0 && available_tabs.length ) + selected_tab = available_tabs[0]; tab_panels.each( function() { var panel = $( this ); diff --git a/templates/wiki/main-view.php b/templates/wiki/main-view.php index ff8ca86..6a2193f 100644 --- a/templates/wiki/main-view.php +++ b/templates/wiki/main-view.php @@ -1,71 +1,303 @@ -
+ user['id'] === 1 or (int)$this -> user['id'] === 3 );?> +

Wiki

-
- user['id'] == 1 or $this -> user['id'] == 3 ):?> -