:root {
    --wb360-pink: #821e7d;
    --wb360-white: #ffffff;
    --wb360-blue: #337ab7;
    --wb360-text-color: #333333;
    --wb360-light-grey: #b0b0b8;
    --wb360-light-blue: #0079a3;
    --wb360-dark-blue: #005576;
    --wb360-dark-red: #d32f2f;
    --wb360-grey-border: #d7d7d8;
    --wb360-grey: #a3a3a3;
    --wb360-grey-background: #f1f1f1;
    --wb360-black-opacity: rgba(0, 0, 0, 0.6);
    --wb360-checkbox-color: #821e7d;
    --wb360-radio-color: #821e7d;
    --wb360-checked-color: #821e7d;
    --wb360-action-link-color: #35353a;
    --wb360-liander-primary: #821e7d;
    --wb360-faq-bg: #eaf3f9;
}

html { scroll-behavior: smooth; font-size: 100%; }
body { font-family: "Roboto", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; font-size: 1rem; line-height: 1.5; }

/* GENERAL */
.wb360 { font-size: 16px; }
@media (min-width: 768px) {
    .wb360 { font-size: 18px; }
}
.wb360 .wb360-rescheduler { margin-bottom: 30px; }
.wb360 .wb360-rescheduler a:not(.btn) { color: var(--wb360-blue); text-decoration: none; }
.wb360 .wb360-rescheduler a:not(.btn):hover,
.wb360 .wb360-rescheduler a:not(.btn):focus { color: var(--wb360-dark-blue); text-decoration: underline; }
.wb360 .btn { padding: 12px 20px; border-radius: 8px; font-weight: bold; font-size: 18px; line-height: 1.1; background-color: var(--wb360-light-blue) !important; border: 2px solid var(--wb360-light-blue) !important; color: var(--wb360-white) !important; background-image: none !important; border-bottom: ; }
.wb360 .btn:hover,
.wb360 .btn:focus,
.wb360 .btn.primary:hover,
.wb360 .btn.primary:focus { background-color: var(--wb360-dark-blue); border-color: var(--wb360-dark-blue); box-shadow: none !important; }
.wb360 .btn-small { font-size: 16px; padding: 10px 20px; }
.wb360 label { font-weight: normal; }
.wb360 .form-check-input[type=checkbox] { width: 32px; height: 32px; border: 0px; border-radius: 8px; box-shadow: inset 0px 0px 0px 2px var(--wb360-checkbox-color); background-color: var(--wb360-white); transition: background-color 0.25s cubic-bezier(0.33, 0, 0.35, 1) 0s, box-shadow 0.25s cubic-bezier(0.33, 0, 0.35, 1) 0s, box-shadow 0.25s cubic-bezier(0.33, 0, 0.35, 1) 0s; }
.wb360 .form-check-input:checked[type=checkbox] { background-image: url('../../images/rescheduler/checkmark.svg'); background-size: 20px; background-color: var(--wb360-checked-color); box-shadow: inset 0px 0px 0px 2px var(--wb360-checked-color); }
.wb360 .form-check-label { padding-left: 10px; padding-top: 10px; }
.wb360 .form-check-input[type=radio] { width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--wb360-radio-color); }
.wb360 .form-check-input:checked[type=radio] { background-color: var(--wb360-white); background-image: none; position: relative; border-color: var(--wb360-checked-color); }
.wb360 .form-check-input:checked[type=radio]:focus { box-shadow: none; }
.wb360 .form-check-input:checked[type=radio]:before { position: absolute; width: 16px; height: 16px; content: " "; background-color: var(--wb360-checked-color); border-radius: 50%; transform: translate(-50%, -50%); top: 50%; left: 50%; }
.wb360 .wb360-house-number, 
.wb360 .wb360-house-number-addition { padding-top: 32px; }
@media (min-width: 576px) {
    .wb360 .wb360-house-number,
    .wb360 .wb360-house-number-addition { padding-top: 0px; }
}
.wb360 img { max-width: 100%; height: auto !important; }

/* DATE PICKER */
#ui-datepicker-div { font-size: initial; }
.ui-datepicker { margin-top: 5px; }

/* LOADER */
.wb360 .wb360-loader { display: none; position: fixed; width: 100%; height: 100%; top: 0; left: 0; z-index: 999999; background-color: var(--wb360-black-opacity); }
.wb360 .wb360-loader-text { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--wb360-light-blue); padding: 1rem 2rem; font-size: 1rem; border-radius: 6px; color: var(--wb360-white); font-weight: 500; min-width: 290px; }

/* MAIN */
.wb360 .wb360-rescheduler { padding-bottom: 24px; /*max-width: 1170px;*/ }
@media (min-width: 768px) {
    .wb360 .wb360-rescheduler { border: 1px solid var(--wb360-grey-border); border-radius: 8px; }
    .wb360 .wb360-rescheduler { box-shadow: 0px 3px 0px var(--wb360-grey-border); }
}
.wb360 .wb360-content { padding: 0px 15px; }
@media (min-width: 768px) {
    .wb360 .wb360-content { padding: 0px 24px; }
}
.wb360 .wb360-header { background-color: var(--wb360-pink); padding: 30px 15px 30px; border-top-left-radius: 8px; border-top-right-radius: 8px; margin-bottom: 32px; position: relative; }
@media (min-width: 768px) {
    .wb360 .wb360-header { padding: 36px 24px 30px; }
}
.wb360 .wb360-header h2 { color: var(--wb360-white); font-weight: bold; font-size: 28px; line-height: 1.2; margin: 0; padding: 0; overflow-wrap: break-word; word-break: break-word; width: calc(100% - 15px); }
.wb360 .wb360-header-info { font-size: 18px; color: var(--wb360-white); line-height: 1.5; margin-top: 8px; }

/* ACTIONS */
.wb360 .wb360-actions { position: absolute; top: 5px; right: 5px; }
.wb360 .wb360-actions .dropdown-menu { border: 1px solid var(--wb360-grey-border); background-clip: border-box; border-radius: 4px; font-size: 15px; }
.wb360 .wb360-actions .dropdown-toggle { font-size: 20px; color: var(--wb360-white); padding: 8px 10px; cursor: pointer; }
.wb360 .wb360-actions .dropdown-toggle:after { display: none; }
.wb360 .wb360-actions .dropdown-divider { border-top: 1px solid var(--wb360-grey-border); }
.wb360 .wb360-actions a:not(.btn),
.wb360 .wb360-actions a:focus:not(.btn),
.wb360 .wb360-actions a:hover:not(.btn) { color: var(--wb360-action-link-color); text-decoration: none; background-color: var(--wb360-white); outline: none; }
.wb360 .wb360-actions a:focus:not(.btn),
.wb360 .wb360-actions a:hover:not(.btn) { color: var(--wb360-pink); }
.wb360 .wb360-actions .dropdown-item i.fa { font-size: 14px; display: inline-block; padding-right: 5px; position: relative; top: -1px; }
.wb360 .wb360-actions .wb360-action-language i.fa { top: 0px; }

/* PREV */
.wb360 .wb360-prev { display: inline-block; padding-top: 10px; text-decoration: none !important; line-height: 1.4; }
.wb360 .wb360-prev:hover,
.wb360 .wb360-prev:focus,
.wb360 .wb360-prev:active { text-decoration: none !important; }
.wb360 .wb360-prev .fa { position: relative; top: 1px; padding-right: 5px; }

/* FORM */
.wb360 .wb360-form-title { font-weight: bold; font-size: 26px; line-height: 1.2; margin-bottom: 28px; }
.wb360 .wb360-form-row { padding-bottom: 32px; }
.wb360 .form-floating > .form-control { height: 48px; max-height: 48px; border: none; font-size: 18px; border-radius: 8px; box-shadow: 0 0 0 2px var(--wb360-light-grey); }
.wb360 .form-floating > textarea.form-control { height: 120px; max-height: 120px; }
.wb360 .form-floating > label { padding-top: 12px; padding-left: 14px; font-size: 18px; padding-right: 8px; }
.wb360 .form-label-above,
.wb360 .form-floating > .form-control:focus ~ label,
.wb360 .form-floating > .form-control:not(:placeholder-shown) ~ label,
.wb360 .form-floating > .form-select ~ label { opacity: 1; transform: scale(.75) translateY(-20px) translateX(10px); padding: 4px 8px; height: auto; background-color: var(--wb360-white); }
.wb360 .form-floating > .form-control:focus { box-shadow: 0 0 0 3px var(--wb360-light-blue); }
.wb360 .form-input-label-above,
.wb360 .form-floating > .form-control:focus,
.wb360 .form-floating > .form-control:not(:placeholder-shown) { padding-top: 0px !important; padding-bottom: 0px !important; }
.wb360 .form-floating > textarea.form-control:focus,
.wb360 .form-floating > textarea.form-control,
.wb360 .form-floating > textarea.form-control:not(:placeholder-shown) { padding-top: 22px !important; padding-bottom: 22px !important; line-height: 1.6rem; }
.wb360 .wb360-rescheduler .form-check label { cursor: pointer; }
@media (min-width: 992px) {
    .wb360 .wb360-form { max-width: 700px; }
    .wb360 .form-floating > textarea.form-control { height: 150px; max-height: 150px; }
}
.wb360 .wb360-buttons { margin-top: 45px; }
.wb360 .wb360-buttons .btn { margin-bottom: 30px; }

/* LOGIN FORM */
.wb360 .form-label-above { padding-top: 8px !important; padding-left: 10px !important; height: auto !important; padding-bottom: 0 !important; }
#wb360LoginForm input::placeholder,
#wb360ContactForm input::placeholder,
#wb360ContactForm textarea::placeholder { color: var(--wb360-grey); }

/* OBJECTS */
.wb360 .wb360-object-titles { margin: 0px; padding: 0px; }
.wb360 .wb360-object-titles li { list-style: none; padding-bottom: 20px; position: relative; padding-left: 30px; }
.wb360 .wb360-object-titles li:last-child { padding-bottom: 0px; }
.wb360 .wb360-object-titles li .fa-wrench { position: absolute; top: 3px; left: 2px; font-size: 15px; color: var(--wb360-pink); }

/* NOTIFICATIONS */
.wb360 .wb360-notifications { margin-bottom: 45px; border-radius: 4px; }
.wb360 .wb360-notification { position: relative; padding-left: 28px; }
.wb360 .wb360-notification i { position: absolute; top: 2px; left: 0px; }

/* FORM ERROR */
.wb360 .form-floating > .form-control.is-invalid,
.wb360 .form-floating > .form-select.is-invalid { box-shadow: 0 0 0 3px var(--wb360-dark-red); color: var(--wb360-dark-red); background-image: none; }
.wb360 .form-floating.wb360-error > label { color: var(--wb360-dark-red); }
.wb360 .invalid-feedback { color: var(--wb360-dark-red); margin-top: 10px; position: relative; padding-left: 24px; }
.wb360 .invalid-feedback i { position: absolute; top: 3px; left: 2px; }

/* APPOINTMENTS */
.wb360 .wb360-appointment-value { font-weight: bold; }
.wb360 .wb360-appointments-data hr { background-color: var(--wb360-light-grey); }
.wb360 .wb360-appointment hr { background-color: var(--wb360-light-grey); }
.wb360 .wb360-appointments { margin-top: 60px; }
.wb360 .wb360-appointments .wb360-form-title { margin-bottom: 10px; }
.wb360 .wb360-appointment { margin-top: 32px; }
@media (min-width: 768px) {
    .wb360 .wb360-appointment { margin-top: 45px; }
}
.wb360 .wb360-appointment-title { color: var(--wb360-pink); font-weight: bold; margin-bottom: 15px; font-size: 22px; line-height: 1.2; }
.wb360 .wb360-update-info { margin-top: 15px; }

/* NEW APPOINTMENT */
.wb360 .wb360-new-appointment .wb360-form-title { margin-bottom: 10px; }
.wb360 .wb360-new-appointment-part { margin-bottom: 30px; }
.wb360 .wb360-new-appointment-title { font-size: 18px; font-weight: 700; margin-bottom: 10px; }
.wb360 .wb360-new-appointment-text { margin-bottom: 45px; }
.wb360 .wb360-new-appointment-info { margin-bottom: 30px; }
.wb360 .wb360-new-appointment-date { position: relative; }
.wb360 .wb360-new-appointment .fa-calendar { position: absolute; top: 15px; right: 15px; font-size: 18px; color: var(--wb360-text-color); cursor: pointer; }
.wb360 .hasDatepicker { cursor: pointer; }
.wb360 .wb360-new-appointment-datepicker.form-control[readonly] { background-color: var(--wb360-white); }
.wb360 .wb360-new-appointment-day { margin-bottom: 22px; }
@media (min-width: 768px) {
    .wb360 .wb360-new-appointment-date { max-width: 300px; }
    .wb360 .wb360-new-appointment-days .col-lg-2 { width: 33.33333333%; }
}
@media (min-width: 992px) {
    .wb360 .wb360-new-appointment-days .col-lg-2 { width: 20%; }
    .wb360 .wb360-new-appointment-day-part .col-lg-3 { width: 20%; }
}

/* PROPOSALS */
.wb360 .wb360-proposal { margin-bottom: 75px; }
.wb360 .wb360-proposal:last-child { margin-bottom: 30px; }
.wb360 .wb360-proposal-title { color: var(--wb360-pink); font-weight: bold; margin-bottom: 15px; font-size: 18px; line-height: 1.2; }
.wb360 .wb360-proposal .wb360-buttons { margin-top: 25px; }
.wb360 .wb360-proposal .wb360-proposal-value { font-weight: bold; }
.wb360 .wb360-proposal hr { background-color: var(--wb360-light-grey); }

/* PROPOSAL */
.wb360 .wb360-proposal-form { margin-top: 30px; }

/* CONFIRM */
.wb360 .wb360-confirm-title { margin-bottom: 10px; }

/* FORM UPDATE */
.wb360 .wb360-update-info .wb360-form-title { margin-bottom: 10px; }
.wb360 .wb360-update-info .wb360-form-row { padding: 10px 2px 30px 2px; }
.wb360 .wb360-form-row-hidden { display: none; }
.wb360 .wb360-form-row-block { display: block; }
.wb360 .wb360-form-row-address-title { font-size: 18px; margin-bottom: 22px; padding-left: 12px; }

/* HEADER */
.wb360 .navbar-light .navbar-toggler { border: 2px solid var(--wb360-liander-primary); background-color: var(--wb360-white); }
.wb360 .navbar-light .navbar-toggler-icon { background-image: none; position: relative; }
.wb360 .navbar-light .navbar-toggler-icon span,
.wb360 .navbar-light .navbar-toggler-icon::before,
.wb360 .navbar-light .navbar-toggler-icon::after { position: absolute; width: 100%; height: 3px; background-color: var(--wb360-liander-primary); content: ""; transition: all 0.3s ease-in-out; }
.wb360 .navbar-light .navbar-toggler.collapsed .navbar-toggler-icon::before { top: 5px; left: 0; }
.wb360 .navbar-light .navbar-toggler.collapsed .navbar-toggler-icon span { top: 14px; left: 0; }
.wb360 .navbar-light .navbar-toggler.collapsed .navbar-toggler-icon::after { bottom: 4px; left: 0; }
.wb360 .navbar-light .navbar-toggler:not(.collapsed) .navbar-toggler-icon::before { top: 13px; left: 0; transform: rotate(45deg); }
.wb360 .navbar-light .navbar-toggler:not(.collapsed) .navbar-toggler-icon span { display: none; }
.wb360 .navbar-light .navbar-toggler:not(.collapsed) .navbar-toggler-icon::after { bottom: 13px; left: 0; transform: rotate(-45deg); }
.wb360 .navbar-light .navbar-nav .nav-link:focus,
.wb360 .navbar-light .navbar-nav .nav-link:hover,
.wb360 .navbar-light .navbar-nav .nav-link.active,
.wb360 .navbar-light .navbar-nav .show > .nav-link { color: var(--wb360-liander-primary); }
.wb360 .navbar-light .navbar-nav .nav-link { color: var(--wb360-text-color); }
.wb360 .navbar-light .navbar-nav .nav-link.active { font-weight: 500; }
.wb360 .navbar-toggler:focus { box-shadow: none; }
.wb360 .nav-link { padding: 0.75rem; border-bottom: 1px solid var(--wb360-light-grey); }
.wb360 .nav-link:last-child { border-bottom: 0; }
.wb360 .navbar-nav .nav-link { padding-left: 2px; }
.wb360 .navbar-nav { padding-top: 10px; }
.wb360 .logo:not(.logo-maintenance) { position: absolute; top: 0px; right: 15px; width: 130px; }
@media (min-width: 992px) {
    .wb360 .logo:not(.logo-maintenance) { display: block; position: relative; top: 15px; right: initial; width: 150px; }
    .wb360 .navbar-collapse { flex-grow: initial; }
    .wb360 .navbar-expand-lg .navbar-nav .nav-link { border-bottom: 0; padding-left: 1rem; padding-right: 1rem; }
}

/* PAGE */
.wb360 .page h1 { font-size: 2.25rem; color: var(--wb360-liander-primary); font-weight: 500; margin-bottom: 1rem; }
.wb360 .page h2 { font-size: 1.5rem; color: var(--wb360-blue); font-weight: 400; margin-bottom: 0.25rem; }
.wb360 .page section { padding-bottom: 1.5rem; }
.wb360 .page section:last-of-type { padding-bottom: 0; }
.wb360 .page a,
.wb360 .page a:link,
.wb360 .page a:focus { color: var(--wb360-blue); }
.wb360 .page a:hover { color: var(--wb360-dark-blue); }

/* SP */
.wb360 .service-partner { display: block; text-decoration: none; color: var(--wb360-text-color); border: 1px solid var(--wb360-grey); border-radius: 4px; padding: 30px 15px; transition: background-color 0.3s ease-in-out; }
.wb360 .service-partner .sp-logo { text-align: center; }
.wb360 .service-partner .sp-info { color: var(--wb360-text-color); }
.wb360 .service-partner .sp-info h3 { color: var(--wb360-liander-primary); font-size: 1.25rem; font-weight: 500; }
.wb360 .service-partner .sp-info p { font-size: 0.9rem; }
.wb360 .service-partner .sp-info p:last-child { margin-bottom: 0; padding-bottom: 0; }
.wb360 .service-partner:hover { background-color: var(--wb360-grey-background); }
.wb360 .service-partner .contact-page { color: var(--wb360-light-blue); }

/* FAQ */
.wb360 .page .faq-category-title { color: var(--wb360-liander-primary); font-weight: 500; }
.wb360 .faq-category { padding-left: 0; list-style: none; }
.wb360 .faq-category li a { display: block; text-decoration: none; border-bottom: 1px solid var(--wb360-grey-background); padding: 0.8rem 0; }
.wb360 .faq-category li a:hover,
.wb360 .faq-category li a:focus { text-decoration: underline; }
.wb360 .faq-category li a.active { text-decoration: underline; font-weight: 500; }

.wb360 .accordion-item { margin: 1rem 0; border: 0; border-radius: 0; }
.wb360 .accordion-header { font-weight: normal; margin: 0 !important; line-height: 1.5rem; }
.wb360 .accordion-button { background-color: var(--wb360-grey-background); border: 0 !important; border-radius: 0; }
.wb360 .accordion-button:not(.collapsed) { background-color: var(--wb360-light-blue); color: var(--wb360-white) }
.wb360 .accordion-button:after { position: relative; right: -5px; background-image: none; content: "\f107"; font-family: "FontAwesome"; font-size: 1.5rem; }
.wb360 .accordion-button:not(.collapsed):after { background-image: none; }
.wb360 .accordion-button:focus { box-shadow: none; }
.wb360 .accordion-item:first-of-type .accordion-button { border: 0; border-radius: 0; }
.wb360 .accordion-body { background-color: var(--wb360-faq-bg); font-size: 1rem; }

/* SITEMAP */
.wb360 .sitemap li { position: relative; }

/* CONTACT */
.wb360 #formWrapper .alert.alert-success { max-width: 700px; }
.wb360 .contact-phone { padding-left: 45px; position: relative; }
.wb360 .contact-phone span { position: absolute; top: -4px; left: 0; width: 35px; height: 35px; border: 3px solid var(--wb360-grey); border-radius: 50%; }
.wb360 .contact-phone .fa.fa-phone { position: relative; top: 4px; left: 7px; font-size: 18px; color: var(--wb360-grey); }
@media (min-width: 768px) {
    .wb360 .contact-phone .fa.fa-phone { top: 1px; left: 8px; }
}

/* FOOTER */
.wb360 footer { background-color: var(--wb360-dark-blue); }
.wb360 footer *, 
.wb360 footer a, 
.wb360 footer a:link, 
.wb360 footer a:hover, 
.wb360 footer:focus { color: var(--wb360-white); font-size: 0.9rem; }

/* MAINTENANCE */
.wb360 .wb360-maintenance { border: 2px solid #FFCC33; }
.wb360 .logo-maintenance { max-width: 150px; }