/* RESET */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    border: 0;
    font: inherit;
    font-size: 100%;
    margin: 0;
    padding: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}

ol, ul {
    list-style: none;
}

blockquote, q {
    quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
    content: '';
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

/*** COLORS ***/
/*** TYPOGRAPHY ***/
@font-face {
    font-family: 'TradeGothicLTStd';
    src: url('../fonts/TradeGothicLTStd.eot');
    src: local('☺'), url('../fonts/TradeGothicLTStd.woff') format('woff'), url('../fonts/TradeGothicLTStd.ttf') format('truetype'), url('../fonts/TradeGothicLTStd.svg') format('svg');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Blokletters-Balpen';
    src: url('../fonts/Blokletters-Balpen.eot');
    src: local('☺'), url('../fonts/Blokletters-Balpen.woff') format('woff'), url('../fonts/Blokletters-Balpen.ttf') format('truetype'), url('../fonts/Blokletters-Balpen.svg') format('svg');
    font-weight: normal;
    font-style: normal;
}

:root {
    color: #6E747D;
    font-family: 'TradeGothicLTStd';
    font-size: 18px;
}

* {
    font-family: 'TradeGothicLTStd';
}

a {
    color: #6E747D;
    text-decoration: none;
}

a:focus {
    outline: none;
}

a:hover {
    text-decoration: none;
}

p, ul, ol {
    line-height: 1.5;
}

strong, b {
    font-weight: 700;
}

em, i {
    font-style: italic;
}

del {
    text-decoration: line-through;
}

ins, u {
    text-decoration: underline;
}

small, .small {
    font-size: 80%;
}

/** HEADINGS **/
h1, h2, h3, h4, h5 {
    font-weight: 700;
    line-height: 1.5;
    word-wrap: break-word;
}

h2 {
    font-size: 2.667rem;
}

h3 {
    font-size: 1.778rem;
}

h4 {
    font-size: 1.333rem;
    margin-bottom: 0.667rem;
}

h5 {
    font-size: 1rem;
}

/** LISTS **/
ol {
    list-style: decimal inside;
}

ul {
    list-style: inside none;
}

/*** START ***/
*, *::after, *::before {
    box-sizing: border-box;
}

html, body {
    height: 100%;
    font-family: 'TradeGothicLTStd';
}

:root {
    background-color: #F5F7FA;
}

/*** COMPONENTS ***/
/** FORM **/
input, textarea, select {
    font-family: inherit;
}

button:focus, input:focus, select:focus, textarea:focus {
    outline: none;
}

button:hover, input[type="submit"]:hover, input[type="reset"]:hover {
    cursor: pointer;
}

/* Form Group */
.form_group {
    margin-bottom: 2rem;
    position: relative;
    text-align: center;
}

/* Label */
label, legend, .label {
    display: block;
    font-size: 0.778rem;
    margin-bottom: 0.278rem;
}

legend {
    margin-bottom: 0.556rem;
}

fieldset .form_group {
    align-items: center;
    display: flex;
    flex: 0 1 auto;
}

fieldset label {
    font-weight: 700;
    flex: 0 0 80px;
}

/* Input and Textarea */
.input-text, .input-textarea {
    -webkit-appearance: none;
    border: 0.056rem solid #e6e6e6;
    border-radius: 0.444rem;
    font-size: 0.778rem;
    padding: 0.472rem 0.278rem;
    width: 100%;
}


.input_group {
    align-items: center;
    border: 0.056rem solid #00355f;
    border-radius: 0.444rem;
    display: flex;
    flex: 0 1 auto;
    height: 2.222rem;
    overflow: hidden;
}
.input_group.has-error {
    color:#a94442;
}
.input_group_prepend {
    background-color: #00355f;
    color: white;
    flex-grow: 0;
    flex-shrink: 0;
    height: 2.222rem;
    line-height: 2.222rem;
    width: 2.667rem;
    text-align: center;
}

.input_group_input {
    border: none;
    flex-grow: 1;
    flex-shrink: 1;
    font-size: 0.778rem;
    padding: 0.472rem 0.278rem;
}

.input_group.error {
    border-color: #E21414;
}

.input_group.error .input_group_prepend {
    background-color: #E21414;
}

.error_msg {
    color: #E21414;
    display: block;
    font-size: 0.778rem;
    margin-left: 2.667rem;
    margin-top: 0.222rem;
    text-align: left;
}

/* Placeholder */
input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
    color: #a0a0a0;
}

input:-ms-input-placeholder, textarea:-ms-input-placeholder {
    color: #a0a0a0;
}

input::-ms-input-placeholder, textarea::-ms-input-placeholder {
    color: #a0a0a0;
}

input::placeholder, textarea::placeholder {
    color: #a0a0a0;
}

/* Select */
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.custom-select {
    background: white url("../img/select.svg") no-repeat right 0.444rem center;
    border: 0.056rem solid #e6e6e6;
    border-radius: 0.444rem;
    font-size: 0.778rem;
    height: 2.222rem;
    line-height: normal;
    overflow: hidden;
    padding: 0.278rem 1.278rem 0.278rem 0.278rem;
}

.custom-select:hover, .custom-select:focus {
    border-color: #00355f;
}

select::-ms-expand {
    display: none;
}

/* Checkbox */
.checkbox_choice {
    display: inline-block;
    font-size: 0.778rem;
    margin-right: 3.333rem;
}

.checkbox_choice input[type="checkbox"] {
    margin-right: 0.222rem;
}

.checkbox_choice:last-of-type {
    margin-right: 0;
}

/* Button */
.button_ghost {
    background-color: white;
    border: 0.056rem solid currentColor;
    border-radius: 0.444rem;
    color: #00355f;
    display: inline-block;
    font-size: 1rem;
    line-height: 1rem;
    padding: 0.556rem 2.222rem;
    text-align: center;
    transition: all .15s;
}

.button_ghost:hover {
    background-color: #00355f;
    color: white;
    cursor: pointer;
    text-decoration: none;
}

.button_ghost:disabled:hover {
    cursor: not-allowed;
}

.button_ghost_danger {
    background-color: white;
    border: 0.056rem solid currentColor;
    border-radius: 0.444rem;
    color: #E21414;
    display: inline-block;
    font-size: 1rem;
    line-height: 1rem;
    padding: 0.556rem 2.222rem;
    text-align: center;
    transition: all .15s;
}

.button_ghost_danger:hover {
    background-color: #E21414;
    color: white;
    cursor: pointer;
    text-decoration: none;
}

.button_ghost_danger:disabled:hover {
    cursor: not-allowed;
}


/* File Input */
.inputfile {
    height: 0.1px;
    opacity: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
    width: 0.1px;
}

.inputfile + label {
    cursor: pointer;
    display: inline-block;
    overflow: hidden;
    white-space: nowrap;
}

.inputfile + label .label_attach {
    background-color: white;
    border: 0.056rem solid #e6e6e6;
    border-radius: 0.444rem;
    display: inline-block;
    font-size: 0.778rem;
    padding: 0.528rem 0.833rem;
}

.inputfile + label:hover .label_attach {
    background-color: #00355f;
    color: white;
}

.inputfile + label .label_image {
    background-color: white;
    border: 0.056rem solid currentColor;
    border-radius: 0.444rem;
    color: #00355f;
    display: inline-block;
    font-size: 1rem;
    padding: 0.167rem 0.556rem;
}

.inputfile + label:hover .label_image {
    background-color: #00355f;
    border-color: #00355f;
    color: white;
}

/*** MODULES ***/
/** SITE BODY **/
#site_body {
    padding-left: 3.111rem;
}

/** SITE TOP **/
#site_body_top {
    align-items: center;
    background-color: white;
    border-bottom: 0.111rem solid #e6e6e6;
    box-shadow: 0 0.111rem 0.222rem rgba(60, 60, 60, 0.1);
    display: flex;
    flex: 0 1 auto;
    height: 3.667rem;
    justify-content: space-between;
    width: 100%;
}

#site_body_top > * {
    align-items: center;
    border-right: 0.056rem solid white;
    display: inline-flex;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
}

#site_body_top a {
    color: #6E747D;
}

#open_nav {
    align-items: center;
    border-right: 0.056rem solid #e6e6e6;
    color: #6E747D;
    cursor: pointer;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 0.722rem;
    font-weight: 700;
    height: 100%;
    padding: 0 1.944rem 0 0.722rem;
    position: relative;
    text-transform: uppercase;
    z-index: 11;
}

#open_nav span {
    right: 0.722rem;
    top: calc(50% - 1.5px);
}

#open_nav span, #open_nav span::before, #open_nav span::after {
    background: currentColor;
    border-radius: 0.083rem;
    content: '';
    cursor: pointer;
    display: block;
    height: 0.167rem;
    position: absolute;
    transition: all 250ms ease-in-out;
    width: 0.833rem;
}

#open_nav span::before {
    right: 0;
    top: -0.389rem;
}

#open_nav span::after {
    right: 0;
    bottom: -0.389rem;
}

#open_nav.active span {
    background: transparent;
}

#open_nav.active span::before, #open_nav.active span::after {
    top: 0;
}

#open_nav.active span::before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

#open_nav.active span::after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

#search {
    flex-grow: 1;
    flex-shrink: 1;
    height: 100%;
}

#search * {
    height: 100%;
}

#search form {
    align-items: flex-start;
    display: flex;
    flex: 1 1 auto;
}

#search input[type="text"] {
    border: none;
    font-size: 0.778rem;
    padding-left: 0.889rem;
    width: calc(100% - 64px);
}

#search input[type="submit"], #search button {
    background-color: #00355f;
    border: none;
    color: white;
    font-size: 1.333rem;
    padding: 0.833rem 0;
    width: 3.556rem;
}

.add_project, .open_ticket, .create_user, .create_company {
    color: white !important;
    font-size: 0.889rem;
    font-weight: 700;
    height: 100%;
    padding: 0 1.278rem;
    text-transform: uppercase;
}

.add_project {
    background-color: #00355f;
}

.open_ticket {
    background-color: #E21414;
}

.create_user {
    background-color: #38C713;
}

.create_company {
    background-color: #FEA844;
}

.open_settings, .last_tickets_open, .user_option_open {
    border-right-color: #e6e6e6 !important;
    padding: 0 0.889rem;
}

.open_settings i, .last_tickets_open i {
    font-size: 1.333rem;
}

.last_tickets_open, .user_option_open {
    align-items: center;
    display: inline-flex;
    flex: 0 1 auto;
    height: 100%;
}

ul.last_ticket > li {
    height: 100%;
    position: relative;
}

ul.last_ticket .last_tickets_open {
    position: relative;
    height: 100%;
}

ul.last_ticket .last_tickets_open .ticket_number {
    align-items: center;
    background-color: #E21414;
    border-radius: 50%;
    color: white;
    display: flex;
    flex: 0 1 auto;
    font-size: 0.667rem;
    font-weight: 700;
    height: 1.333rem;
    justify-content: center;
    left: 50%;
    position: absolute;
    top: 0.444rem;
    width: 1.333rem;
}

ul.last_ticket li ul {
    background-color: white;
    border-radius: 0 0 0.444rem 0.444rem;
    box-shadow: 0 0.111rem 0.222rem rgba(60, 60, 60, 0.1);
    display: none;
    font-size: 0.667rem;
    position: absolute;
    right: 0;
    top: 100%;
    width: 17.778rem;
    z-index: 10;
}

ul.last_ticket li ul li {
    border-top: 0.056rem solid #e6e6e6;
}

ul.last_ticket li ul li a {
    align-items: flex-start;
    background-color: white;
    display: flex;
    flex: 0 1 auto;
    padding: 0.889rem;
}

ul.last_ticket li ul li a .last_ticket_user {
    align-items: center;
    background-color: #00355f;
    border-radius: 50%;
    color: white;
    display: inline-flex;
    flex-grow: 0;
    flex-shrink: 0;
    height: 1.778rem;
    justify-content: center;
    margin-right: 0.889rem;
    width: 1.778rem;
}

ul.last_ticket li ul li a .last_ticket_user i {
    font-size: 0.944rem;
}

ul.last_ticket li ul li a .last_ticket_text {
    flex-grow: 1;
    flex-shrink: 1;
}

ul.last_ticket li ul li a .last_ticket_user_name {
    color: #00355f;
}

ul.last_ticket li ul li:hover a {
    background-color: #F5F7FA;
}

ul.last_ticket li ul li:last-child {
    border-radius: 0 0 0.444rem 0.444rem;
    font-size: 1rem;
    overflow: hidden;
}

ul.last_ticket li ul li:last-child a {
    background-color: #00355f;
    color: white !important;
    justify-content: center;
}

ul.last_ticket li:hover {
    cursor: pointer;
}

ul.last_ticket li:hover ul {
    display: block;
}

ul.user_option {
    background-color: #F5F7FA;
}

ul.user_option > li {
    height: 100%;
    position: relative;
}

ul.user_option li ul {
    box-shadow: 0 0.111rem 0.222rem rgba(60, 60, 60, 0.1);
    display: none;
    font-size: 0.889rem;
    position: absolute;
    right: 0;
    top: 100%;
    z-index: 10;
}

ul.user_option li ul li {
    background-color: white;
    border: 0.056rem solid #e6e6e6;
    white-space: nowrap;
}

ul.user_option li ul li a {
    display: block;
    padding: 0.833rem 1.278rem;
}

ul.user_option li ul li a i {
    margin-right: 0.722rem;
}

ul.user_option li ul li:hover {
    background-color: #F5F7FA;
}

ul.user_option li ul li:hover a i {
    color: #00355f;
}

ul.user_option li:hover {
    cursor: pointer;
}

ul.user_option li:hover ul {
    display: block;
}

.user_option .user_option_open i {
    transition: -webkit-transform 0.25s;
    transition: transform 0.25s;
    transition: transform 0.25s, -webkit-transform 0.25s;
}

.user_option:hover .user_option_open i {
    -webkit-transform: rotate(-180deg);
    transform: rotate(-180deg);
}

.user_option_image {
    margin-right: 0.5rem;
}

/** SITE INTRO **/
#site_body_intro {
    background: white;
    padding: 3.889rem 1.222rem;
}

#site_body_intro h2 {
    font-size: 2.667rem;
}

#site_body_intro [class^="intro_ticket_"], #site_body_intro [class*=" intro_ticket_"] {
    font-size: 0.667rem;
    font-weight: 700;
    line-height: 1.5rem;
    text-align: center;
    text-transform: uppercase;
}

#site_body_intro .intro_ticket_number {
    display: block;
    font-size: 2.667rem;
    line-height: 2.556rem;
}

#site_body_intro .intro_ticket_type {
    align-items: center;
    display: flex;
    flex: 0 1 auto;
    justify-content: center;
}

#site_body_intro .intro_ticket_type::before {
    background-color: currentColor;
    border-radius: 50%;
    content: '';
    display: inline-block;
    height: 0.889rem;
    margin-right: 0.333rem;
    width: 0.889rem;
}

#site_body_intro .intro_ticket_new .intro_ticket_type {
    color: #E21414;
}

#site_body_intro .intro_ticket_open .intro_ticket_type {
    color: #FEA844;
}

#site_body_intro .intro_ticket_closed .intro_ticket_type {
    color: #38C713;
}

#site_body_intro .intro_ticket_total .intro_ticket_type {
    color: #00355f;
}

#site_body_intro .intro_ticket_total .intro_ticket_type::before {
    content: none;
}

/** SITE CONTENT **/
#site_body_content {
    background-color: #F5F7FA;
    padding: 1.333rem 0.833rem;
}

.site_header_opened #site_body {
    padding-left: 16.667rem;
}

/** CARD **/
.card {
    background-color: white;
    border: 0.056rem solid #e6e6e6;
    border-radius: 0.444rem;
    box-shadow: 0;
    margin-bottom: 1.778rem;
    overflow: hidden;
    transition: box-shadow 0.1s;
    width: 100%;
}

.card:hover {
    box-shadow: 0 0.111rem 0.222rem rgba(60, 60, 60, 0.1);
}


.card_login_body {
    padding: 1.778rem 0.944rem;
}

.card_login_lost {
    font-size: 0.778rem;
}

.table, .table_head, .table_body {
    width: 100%;
}
/** MODAL **/
.modal {
    background-color: #00355f;
    background-color: rgba(107, 166, 238, 0.9);
    color: #6E747D;
}

.modal-content {
    border-color: #e6e6e6;
}

.modal-header {
    border-bottom: 0;
    padding-bottom: 0;
}

/*** CONTENTS ***/
/** LOGIN **/
#site_login {
    align-items: center;
    background-color: #F5F7FA;
    display: flex;
    flex: 0 1 auto;
    height: 100%;
    width: 100vw;
}

.card_login {
    background-color: white;
    margin: auto;
    max-width: 17.778rem;
    width: 100%;
}

.card_login_logo {
    align-items: center;
    background-color: #fff;
    display: flex;
    flex: 0 1 auto;
    height: 8.056rem;
    justify-content: center;
    flex-direction: column;
}


a.btn-outline {
    display: inline-block;
    background-color: #FFF;
    color: #00355f;
    text-align: center;
    padding: 9px 15px;
    border: 1px solid #00355f;
    text-transform: uppercase;
}

a.btn-outline:hover {
    display: inline-block;
    background-color: #00355f;
    color: #fff;
    text-align: center;
    border: 1px solid #00355f;

}

.help-block {
    position: absolute;
    margin-top: 74px;
    font-size: 80%;
}

#modalRecuperaPassword .help-block {
    margin-top: 5px;
    color:#a94442;
}

.recupera {
    margin-top:10px;
}
.recupera a {
    font-size:12px;
}
.recupera a:hover {
    color:#cc0000;
}
