@import url('https://fonts.googleapis.com/css2?family=Open+Sans:400&display=swap');

html {
    font-size: 16px;
}

html,
body {
    font-family: 'Open Sans', sans-serif;
    margin: 0;
    padding: 0;
    background-color: #fff;
    color: #808080;
    font-weight: 400;
    height: 100vh;
}

body strong,
body b {
    font-weight: 700;
}

body .semibold {
    font-weight: 600;
}

body .medium {
    font-weight: 500;
}

body.dragging, body.dragging * {
  cursor: move !important;
}
@media screen and (min-width: 1536px) {
    .container {
        max-width: 1400px !important;
    }
}

.dragged {
  position: absolute;
  opacity: 0.5;
  z-index: 2000;
}
ol.draggable {
    list-style: disc;
}
ol.draggable li {
    cursor: pointer;
}
ol.draggable li.placeholder {
  position: relative;
  /** More li styles **/
}
ol.draggable li.placeholder:before {
  position: absolute;
  /** Define arrowhead **/
}


small {
    font-size: 50%;
    font-weight: normal;
}

a.switch-section {
    background: #cd1c43;
    color: #fff;
    padding: 5px;
}

a.current-section {
    background: green;
    color: #fff;
    padding: 5px;
}

/* Typography */
h1,
.h1 {
    font-size: 2.5rem;
    font-weight: 500;
    margin-bottom: 1.5rem;
    color: #f8be20;
    line-height: 1;
}

h2,
.h2 {
    font-size: 1.4rem;
    font-weight: 700;
}

.small {
    font-size: .75rem;
}

.font-18 {
    font-size: 1.15rem;
}

.font-30 {
    font-size: 1.9rem;
}

.text-muted {
    font-size: 0.8rem;
}

.col-form-label {
    font-weight: bold;
}
/* Palette */
.red {
    color: #cd1c43;
}

.yellow {
    color: #f8be20;
}

.grey {
    color: #808080;
}

.green {
    color: #027648;
}

.white {
    color: #fff;
}

/* general */
a {
    color: #808080;
}

a:hover {
    color: #808080;
}

h1+p {
    margin-bottom: 1.5rem;
}

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

.bg-primary {
    background: #f8be20 !important;
}
.modal-body {
    text-align: center;
}


/* form validation */
#status {
    padding: 1rem;
    margin: 0 0 1rem;
    border-radius: 10px;
    color: #fff;
    font-size: .85rem;
}

#login #status {
    margin: 0 -15px 1rem;
}

#status.status-error {
    background: #cd1c43;
}

#status.status-success {
    background: #027648;
}

#notification.status {
    background: #027648;
    padding: 1rem;
    margin: 0 0 1rem;
    border-radius: 10px;
    color: #fff;
    font-size: .85rem;
}

#status.status-warning {
    background: #ffcc00;
}

button[type=submit].btn-primary,
button.btn_wait {
    position: relative;
}

button[type=submit].btn-primary span,
button.btn_wait span {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #6c757d url(../images/ajax-loader.gif) no-repeat center;
    display: none;
}

button[type=submit]:disabled {
    opacity: 1;
    background: #999;
    border-color: #999;
}

button[type=submit].btn-assign {
    position: relative;
}

button[type=submit].btn-assign span {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #f8f9fa url(../images/ajax-loader_2.gif) no-repeat center;
    display: none;
}



header {
    background: #f8be20;
    padding: 5px;
    color: #fff;
    font-size: 14px;
}

header a,
header a:hover {
    color: #fff;
}

#v-cal .vcal-date--selected {
    background: #f8be20;
    border-radius: 50%;
    color: #fff;
    font-weight: 700;
}

#v-cal .vcal-btn:hover i {
    color: #f8be20;
}

#v-cal .vcal-week span {
    padding: 1.2rem 0
}

.v-slot {
    opacity: .4;
}
.v-slot.available {
    opacity: 1;
}
.v-slot span {
    color: #fff;
    font-weight: 700;
    display: block;
    text-align: center;
    background: #808080;
    cursor: default;
}
.v-slot.available span {
    cursor: pointer;
}
.v-slot.unavailable span {
    cursor: not-allowed;
}
.v-slot.available span:hover {
    color: #f8be20;
}

.v-slot.available span.selected {
    background: #f8be20;
    color: #fff;
}

.highlight {
    color: #fff;
    background: #28a745;
    transition: background-color .5s linear, color .5s linear;
}

ol.log,
ol.log li {
    margin: 0;
    padding: 0;
}

.hidden {
    display: none;
}

/*** Offerte ***/

#alert_appointment {
    background: red;
    color: white;
}

#product-description p {
    margin-bottom: 0;
}

/*** Prodotti ***/

.ql-container {
    height: inherit;
    min-height: 150px;
}

/*** Calendar Top Navigation ***/


/* Tooltip */
div.tooltip-inner {
    text-align: left;
    max-width: 100%;
    border-radius: 5px;
    color: #fff;
    opacity: 1;
}

#procedures tr {
    cursor: pointer;
}

#procedures th,
#procedures td {
    padding: 0.75rem 0.4rem;
}
/*
#procedures .checkbox input[type=checkbox]:checked+label:before {
    background: transparent url('../images/ico-alert.png') no-repeat;
    background-size: contain;
    content: '';
    color: orange;
    border: none;
}
*/
.btn.disabled,
.btn:disabled {
    opacity: .3;
}

table {
    font-size: 12px;
}


/* Code helpers box style */
.code-helper {
    font-size: 14px;
}

/* Checkbox style */
.checkbox input[type=checkbox] {
    display: none;
}

.checkbox label {
    display: block;
    cursor: pointer;
    position: relative;
    padding-left: 28px;
    margin-right: 20px;
    margin-bottom: 10px;
    line-height: 18px;
    font-size: 16px;
}

.checkbox label:before {
    content: "";
    display: inline-block;
    width: 19px;
    height: 19px;
    margin-right: 10px;
    position: absolute;
    left: 0;
    top: 3px;
    background-color: #fff;
    border: 2px solid #d0d0d0;
    border-radius: 4px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    transition: all 0.25s;
    font-size: 12px;
    color: #fff;
    text-align: center;
    line-height: 15px;
}

.checkbox input[type=checkbox]:checked+label:before {
    content: "✔";
    background-color: #d3830c;
    border: 2px solid #d3830c;
}

dialog {
    border: #777 1px solid;
    background-color: #fff;
    color: #808080;
    border-radius: 37px;
    font-weight: bold;
}

dialog button#close {
    background-color: #fff;
    border: none;
    color: #808080;
    outline: 5px auto #808080;
    cursor: grab;
}

dialog button:focus {
    outline: 5px auto #808080;
}

dialog label {
    font-weight: normal;
}

dialog h3 {
    font-weight: bold;
}

dialog menu {
    padding: 0;
}

i.fa.fa-bullhorn:before {
    content: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' aria-labelledby='title' aria-describedby='desc' role='img' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Ctitle%3EMegaphone%3C/title%3E%3Cdesc%3EA line styled icon from Orion Icon Library.%3C/desc%3E%3Cpath data-name='layer2' d='M20 38c0 6 0 14 10 18' fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='2' stroke-linejoin='round' stroke-linecap='round'%3E%3C/path%3E%3Cpath data-name='layer1' d='M20 18v20' fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='2' stroke-linejoin='round' stroke-linecap='round'%3E%3C/path%3E%3Cpath data-name='layer2' d='M56 34a6 6 0 1 0 0-12' fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='2' stroke-linejoin='round' stroke-linecap='round'%3E%3C/path%3E%3Cpath data-name='layer1' d='M22 38H8a6 6 0 0 1-6-6v-8a6 6 0 0 1 6-6h18A55 55 0 0 0 56 8v40a50.4 50.4 0 0 0-30-10z' fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='2' stroke-linejoin='round' stroke-linecap='round'%3E%3C/path%3E%3C/svg%3E") "pre" / "Megaphone";
    text-wrap: wrap;
    color: transparent;
}
