/* STYLE CSS */
@font-face{
	font-family:'Futura';
	src:url('/fonts/FuturaBookC.ttf') format('truetype');
	font-weight:400;
	font-style:normal
}
@font-face{
	font-family:'Futura';
	src:url('/fonts/FuturaDemiC.ttf') format('truetype');
	font-weight:700;
	font-style:normal
}
@font-face{
	font-family:'Futura';
	src:url('/fonts/FuturaLightC.ttf') format('truetype');
	font-weight:300;
	font-style:normal
}
@font-face{
	font-family:'Futura';
	src:url('/fonts/FuturaMediumC.ttf') format('truetype');
	font-weight:500;
	font-style:normal
}



:root{
    --dark: #444;
    --wh: #fff;
    --l-grey: #F3F4F6;
    --grey: #C2C0C0;
    --d-grey: #777676;
    --a-blue: #2574BC;
    --blue: #5E97CC;
    --red: #F00;
}

::placeholder {
    font-size: inherit;
}

input, select, textarea {
    font-size: inherit;
    font-family: inherit;
    font-weight: inherit;
    border-radius: 3px;
}

body {
    font-family: 'Futura';
    height: 100vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

section {
    width: 100%;
    align-self: flex-start;
}

.error{
    border: 1px solid var(--red) !important;
}

.std_btn {
    display: block;
    width: max-content;
    padding: 10px 40px;
    border: 1px solid var(--a-blue);
    border-radius: 3px;
    margin-right: 20px;
    font-weight: 700;
    background: var(
    --wh);
    color: var(
    --a-blue);
    cursor: pointer;
}

.std_btn.active, .std_btn:hover {
    background: var(--a-blue);
    color: var(--wh);
}

img, svg{
    max-width: 100%;
}

.docode_loader {
    position: fixed;
    z-index: 100;
    width: 50px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    display: none;
}

.flex-column {
    display: flex;
    flex-direction: column;
    flex: 1 0 auto;
}
/* Header */
header {
    background: var(--l-grey);
    padding: 20px 0;
    font-size: 16px;
    border-bottom: 1px solid var(--grey);
}

.menu_btn {
    display: flex;
    align-items: center;
}

.user_ctrl {
    display: flex;
    align-items: center;
    margin-left: auto;
}

.user_status {
    margin-right: 20px;
    font-weight: 500;
}

.user_name {
    margin-right: 20px;
}

.user_logout{
    cursor: pointer;
}

.user_logout svg,
.user_logout img{
    width: 15px;
}

.user_logout svg path {
    transition: 0.3s;
    stroke: var(--dark);
    fill: var(--dark);
}

.user_logout:hover svg path {
    stroke: var(--a-blue);
    fill: var(--a-blue);
}

.user_status a {
    color: var(--dark);
    text-decoration: underline;
}

.user_status a:hover {
    color: var(--a-blue);
}

/* END Header */

/* All Projects */
.user_alert {
    margin: 100px auto;
    font-size: 20px;
    font-weight: 600;
}

.add_btn {
    width: 100%;
    text-align: center;
    border-radius: 0;
    color: var(--wh);
    border: none;
    background: var(--blue);
    font-weight: 700;
}

.added_list {
    border: 1px solid var(--grey);
    border-top: none;
    padding: 20px;
    overflow: auto;
    flex: 1 0 auto;
    height: 100px;
}
main {
    background: var(--l-grey);
    font-size: 16px;
    flex: 1 0 auto;
    display: flex;
    overflow: hidden;
    flex-direction: column;
    height: 100px;
}

.name_row {
    display: flex;
    position: relative;
}

#name_project,
#name_template{
    background: transparent;
    border: 1px solid transparent;
    flex: 1;
    margin-right: 100px;
}

.action_btns {
    display: flex;
    align-items: center;
}

.desc_area {
    position: absolute;
    top: 100%;
    background: var(--l-grey);
    width: 100%;
    border: 1px solid var(--grey);
    padding: 20px;
    margin-top: 15px;
    transition: 0.3s;
    transform: scaleY(0);
    transform-origin: top;
    pointer-events: none;
    z-index: 100;
}

.desc_area textarea {
    width: 100%;
    height: 80px;
    padding: 10px;
}

.desc_area.open {
    transform: scaleY(1);
    pointer-events: all;
}

.open_desc {
    display: flex;
    align-items: center;
    cursor: pointer;
}

.open_desc svg path {
    transition: 0.3s;
}

.open_desc:hover svg path {
    fill: var(--dark);
}

#name_project:focus,
#name_template:focus{
    background: var(--wh);
}

.open_desc svg,
.open_desc img{
    transition: 0.3s;
}

.open_desc.open svg,
.open_desc.open img{
    transform: rotate(180deg);
}

.list_pro_name {
    border: 1px solid var(--dark);
    border-radius: 3px;
    padding: 20px;
    margin-right: 40px;
    text-align: center;
    width: 25%;
    transition: 0.3s;
}

.list_pro_desc {
    border: 1px solid var(--dark);
    border-radius: 3px;
    flex: 1;
    width: 10px;
    padding: 20px;
    transition: 0.3s;
}

.list_row {
    display: flex;
    align-items: flex-start;
    cursor: pointer;
    color: var(--dark);
    flex: 1;
    margin-right: 40px;
}

.project_li {
    display: flex;
    width: 100%;
    margin-bottom: 40px;
    border-bottom: 1px solid var(--grey);
    padding-bottom: 40px;
    align-items: flex-start;
}

.list_row:hover .list_pro_name,
.list_row:hover .list_pro_desc {
	border-color: var(--blue);
}



.list_row:last-child {
    margin-bottom: 0;
    border: none;
    padding-bottom: 0;
}

section.any_pro_head {
    padding: 20px 0;
    border-bottom: 1px solid var(--grey);
}

section.project_area {
    background: var(--wh);
    flex: 1 0 auto;
    display: flex;
    padding-bottom: 20px;
}

.any_pro_row {
    flex: 1 0 auto;
    position: absolute;
    display: flex;
    height: 100%;
    width: 100%;
}

.pro_text_col {
    background: var(--l-grey);
    width: 20%;
    min-width: 450px;
    overflow: auto;
    padding: 20px;
    height: 100%;
}

.add_new_block {
    border: 1px solid var(--d-grey);
    border-radius: 3px;
    text-align: center;
    position: relative;
    padding: 10px;
    cursor: pointer;
    transition: 0.3s;
}

.add_new_block svg,
.add_new_block img{
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    width: 10px;
}

.add_new_block:hover, .add_new_block.open {
    background: var(--wh);
}

ul.new_block_list {
    position: absolute;
    background: var(--wh);
    width: calc(100% + 2px);
    list-style: none;
    z-index: 1;
    left: -1px;
    padding: 5px 10px 0;
    border: 1px solid var(--d-grey);
    border-top: none;
    top: calc(100% - 5px);
    border-radius: 0 0 3px 3px;
    transition: 0.3s;
    transform: scaleY(0);
    transform-origin: top;
    pointer-events: none;
}

ul.new_block_list li {
    padding: 10px 0;
    border-top: 1px solid var(--grey);
    transition: 0.3s;
}

.open ul.new_block_list {
    pointer-events: all;
    transform: scaleY(1);
}

ul.new_block_list li:hover {
    color: var(--blue);
}

.block_wrap {
    border: 1px solid transparent;
    border-radius: 3px;
    margin: 5px -10px;
    padding: 10px 10px 0;
}

.block_title {
    position: relative;
    color: var(--dark);
    transition: 0.3s;
    background: transparent;
    padding: 5px;
    border-radius: 3px;
    text-align: center;
    cursor: pointer;
}

.block_title svg,
.block_title img{
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    width: 10px;
    transition: 0.3s;
}

.block_title svg path {
    fill: var(--dark);
    transition: 0.3s;
}

.open .block_title:hover {
    background: var(--a-blue);
    color: var(--wh);
}

.block_row label,
.block_row .label{
    display: flex;
    position: relative;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 10px 0;
    align-items: center;
    pointer-events: none;
}

.block_row input {
    width: 50%;
    border: 1px solid var(--d-grey);
    height: 30px;
    padding: 0 20px 0 10px;
    pointer-events: all;
}

.block_row textarea {
    width: 100%;
    height: 60px;
    margin-top: 5px;
    padding: 5px 20px 5px 10px;
    pointer-events: all;
}

.block_row [type="checkbox"] {
    width: 16px;
    height: 16px;
}

.open .block_title {
    background: var(--blue);
    color: var(--wh);
    margin: 0;
}

.open .block_title svg,
.open .block_title img{
    transform: rotate(180deg) translateY(50%);
}

.block_wrap.open {
    border: 1px solid var(--blue);
}

.open .block_title:hover svg path, 
.open .block_title svg path {
    fill: var(--wh);
}

.block_param {
    overflow: hidden;
    transition: 0.3s;
    border-bottom: 1px solid var(--grey);
    height: 0;
    padding-bottom: 10px;
}

.open .block_param {
    height: auto;
    border-bottom: none;
    overflow: visible;
}

.block_title:hover {
    color: var(--blue);
}

.block_title:hover svg path {
    fill: var(--blue);
}

.block_row label svg,
.block_row label img{
    position: absolute;
    z-index: 1;
    right: 5;
    top: 10px;
    width: 10px;
    height: 10px;
}

.block_row label svg.area,
.block_row label img.area{
    top: 29px;
}

.point_list {
    position: absolute;
    width: 100%;
    top: calc(100% - 2px);
    background: var(--wh);
    z-index: 10;
    border: 1px solid var(--a-blue);
    max-height: 220px;
    overflow: auto;
    transform: scaleY(0);
    transition: 0.3s;
    transform-origin: top;
    pointer-events: none;
}

.point_list.up_open {
    bottom: calc(100% - 2px);
    top: auto;
    transform-origin: bottom;
}

.point_list_item {
    padding: 10px 20px 10px 0;
    margin: 0 10px;
    border-bottom: 1px solid var(--grey);
    transition: 0.3s;
    position: relative;
}

.point_list_item:hover {
    color: var(--blue);
}

.point_list.open {
    transform: scaleX(1);
    pointer-events: all;
}

.block_row {
    position: relative;
}

.block_row_actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.del_block, 
.del_link, 
.block_row_actions .save_project{
    color: var(--blue);
    transition: 0.3s;
    cursor: pointer;
    width: max-content;
    text-decoration: underline
}

.del_block:hover,
.del_link:hover,
.block_row_actions .save_project:hover{
    color: var(--a-blue);
}

.any_link_wrap {
    border-bottom: 1px solid var(--grey);
    padding-bottom: 10px;
    margin-bottom: 10px;
}

.del_point,
.an_close_point,
.sharing_pro_close{
    position: absolute;
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: 1px solid var(--grey);
    border-radius: 50%;
    cursor: pointer;
    transition: 0.3s;
}

.an_close_point:hover,
.sharing_pro_close:hover,
.del_point:hover {
    border: 1px solid var(--red);
}

.sharing_pro_close span,
.an_close_point span,
.del_point span {
    display: block;
    width: 15px;
    height: 1px;
    background: var(--grey);
    position: absolute;
    top: 50%;
    right: 50%;
    transition: 0.3s;
}

.sharing_pro_close span:first-child,
.an_close_point span:first-child,
.del_point span:first-child {
    transform: translate(50%, -0px) rotate(45deg);
}

.sharing_pro_close span:last-child,
.an_close_point span:last-child,
.del_point span:last-child {
    transform: translate(50%, -0px) rotate(-45deg);
}

.sharing_pro_close:hover span,
.an_close_point:hover span,
.del_point:hover span {
    background: var(--red);
}

.what_is {
    position: absolute;
    right: 0;
    top: 100%;
    z-index: 1;
    background: var(--wh);
    padding: 5px;
    display: none;
    border: 1px solid var(--blue);
}

svg:hover + .what_is {
    display: block;
}

.add_new_link {
    display: flex;
    width: 100%;
    justify-content: center;
    align-items: center;
    height: 30px;
    border: 1px solid;
    color: var(--grey);
    border-radius: 4px;
    transition: 0.3s;
    cursor: pointer;
    margin: 20px 0;
}

.add_new_link:hover {
    color: var(--dark);
}

label.user_for_share,
label.user_for_can_share{
    display: flex;
    transition: 0.3s;
    flex-wrap: wrap;
    align-items: center;
    width: 30%;
}

label.user_for_share input,
label.user_for_can_share input{
    margin-right: 10px;
}

.share_list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 20px 0;
}

label.user_for_share:hover,
label.user_for_can_share:hover{
    color: var(--blue);
}

.popup_title {
    font-weight: 600;
    margin-bottom: 10px;
    width: 100%;
}

.session_alert {
    /* margin-top: 10px; */
    text-align: center;
    display: flex;
    color: var(--red);
    font-weight: 600;
    /* position: absolute; */
    width: 100%;
    background: rgba(0,0,0,0.2);
    z-index: 1000;
    justify-content: center;
    align-items: center;
}

.send_session_request {
    margin: 10px 20px;
    transition: 0.3s;
}

.share_requests {
    margin: 20px 0 0;
}

.share_req_users {
    display: flex;
    flex-wrap: wrap;
}

.share_alert:after {
    content: '';
    display: block;
    width: 10px;
    height: 10px;
    background: var(--red);
    border-radius: 50%;
    position: absolute;
    right: 30px;
    top: -4px;
}

.any_req_user {
    padding: 2px 4px;
    border: 1px solid var(--d-grey);
    border-radius: 4px;
    cursor: pointer;
    transition: 0.3s;
    margin-right: 5px;
}

.any_req_user:hover {
    color: var(--blue);
    border-color: var(--blue);
}

.any_req_user_wrap {
    display: flex;
    align-items: center;
    margin-right: 20px;
}

.del_any_req_user {
    border: 1px solid;
    border-radius: 50%;
    padding: 2;
    cursor: pointer;
    transition: 0.3s;
    transform: rotate(45deg);
}

.del_any_req_user:hover {
    color: var(--red);
}

.can_share_session {
    display: flex;
    flex-wrap: wrap;
    margin-top: 20px;
}

.jq_color_wrap {
    width: 30px;
    height: 30px;
    border: 1px solid;
    border-radius: 4px;
    margin-left: auto;
    margin-right: 10px;
    cursor: pointer;
    pointer-events: all;
    position: relative;
}

.colors_wrap {
    position: absolute;
    top: 100%;
    width: calc(100% + 10px);
    background: var(--wh);
    border: 1px solid var(--d-grey);
    padding: 5px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
    display: none;
}

.any_dep_color {
    width: 100%;
    margin-bottom: 5px;
    cursor: pointer;
    transition: 0.3s;
    height: 30px;
    border: 1px solid;
}
/* END All Projects */


/* ALL GRAPHS */
.pro_graf_col {
    flex: 1;
    height: 100%;
    overflow: auto;
    padding: 20px 20px 0 0;
}

.errorclass rect {
    fill: var(--red) !important;
}

.errorclass div {
    color: var(--wh);
}

.edgePath {
    cursor: pointer;
}

.edgePath .path {
    transition: 0.3s;
    stroke-width: 2 !important;
}

.edgePath:hover .path {
    stroke: var(--blue) !important;
}

.edgeLabel {
    cursor: pointer;
}

span.edgeLabel {
    background: var(--l-grey);
    transition: 0.3s;
}

span.edgeLabel:hover {
    color: var(--blue) !important;
}

.lighting {
    fill: var(--a-blue);
    background: var(--blue) !important;
    color: var(--wh) !important;
}

.edgePath.lighting .path {
    stroke: var(--a-blue) !important;
}

span.edgeLabel.lighting:hover {
    color: var(--wh) !important;
}

.block,
#mainCanvas{
    position: absolute;
}
    
.block {
    position: absolute;
    border: 1px solid var(--d-grey);
    background-color: var(--grey);
    padding: 10px;
    border-radius: 5px;
    color: var(--wh);
    width: 200px;
    height: 40px;
    text-align: center;
    overflow: auto;
}

.connector {
    background-color: #FF9900;
}
.source-label, 
.middle-label, 
.destination-label {
    padding: 5px;
    background: var(--l-grey);
    transform: translateY(-50%);
    max-width: 200px;
}

.scale {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 10;
    display: flex;
    background: var(--wh);
}

.scale > div {
    border: 1px solid var(--grey);
    border-radius: 3px;
    position: relative;
    width: 30px;
    height: 30px;
    transition: 0.3s;
    cursor: pointer;
}

.scale span {
    display: block;
    width: 14px;
    height: 2px;
    background: var(--grey);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
}

.scale_plus span:first-child {
    transform: translate(-50%, -50%) rotate(90deg);
}

.scale > div:hover {
    border: 1px solid var(--blue);
}

.scale > div:hover span {
    background: var(--blue);
}

.mermaid {
    transform-origin: top left;
    position: relative;
}

.myDiagramDiv_hidder {
    position: relative;
    overflow: hidden;
    width: 100%;
    /* margin-bottom: -80px; */
}

div#myDiagramDiv {
    /* top: -100px; */
    border: none !important;
    background: var(--l-grey) !important;
    width: 100%;
    height: 200%;
    position: relative;
    /* top: 50%; */
    left: 50%;
    transform: translate(-50%, 0);
}

.graph_actions {
    position: relative;
    z-index: 10;
}
/* END ALL GRAPHS */

/* ANALYTICS */
.analytics_btn {
    position: absolute;
    bottom: 0;
    left: 0;
    background: var(--wh);
    font-size: 20px;
    padding: 10px 20px;
    border-radius: 5px;
    border: 1px solid var(--grey);
    transition: 0.3s;
    cursor: pointer;
    z-index: 10;
}

.analytics_btn::selection {
    background: var(--wh);
}

.analytics_btn:hover {
    border: 1px solid var(--blue);
    color: var(--blue);
}

.analytics,
.sharing_pro{
    width: 80%;
    position: fixed;
    background: var(--wh);
    border: 1px solid var(--grey);
    padding: 20px;
    border-radius: 5px;
    box-shadow: 0 0 3px 5px rgba(0,0,0,0.1);
    z-index: 100;
    top: -100%;
    left: 50%;
    transition: 0.3s;
    transform: translate(-50%, -50%);
}

.analytics.open,
.sharing_pro.open{
    top: 50%;
}

.sharing_pro_close,
.an_close_point{
    top: 5px;
    right: 5px;
    transform: none;
}
/* END ANALYTICS */