/*
* IMPORTANT READ 
*
* Updating any of these .less files WILL NOT AUTOMATICLY CAUSE A RECOMPILE OF THIS LESS FILE.
* We need to run a little tool to make that synchronization work automaticly. Otherwise, everytime you 
* update any of these .less files, you will have to manually save this main.less file to run the compiler.
*
* Instructions: 
*
* Install node.js if you haven't already. 
* Install on your pc: npm install -g less less-watch-compiler
* Create a less-listenser.sh file in the root of htdocs (it is automaticly ignored).
* Put the following batch script in there: 
*
* #!/bin/bash
* less-watch-compiler ./less ./css main.less
*
* If you need to update css, execute this script in a terminal. It will then automaticly 'listen' to changes and will enforce 
* a recompile whenever any of the below .less files change. You can keep the terminal open so that the listener stays.
*
*
*
*
* ALSO IMPORTANT 
* This base was setup to continue development on, sadly on the FLX redesign (the version of this less logic that is in kbsfoundation) 
* is breaking all kinds of things on this portal that have to be fixed. There's no time to address this for now, so this file currently 
* isn't using the kbsfoundation version. It should at some point be updated to use the kbsfoundation version. 
*/
/* 
* BASE CSS SKELETON STRUCTURE - DO NOT PUT ANYTHING PROJECT SPECIFIC INTO THIS CSS,
* THIS CSS WILL EVENTUALLY FUNCTION AS A CLEAN BASE FOR FUTURE PROJECTS REUSING THE FLX SKELETON WITHOUT ALL THE FLX STUFF.
*
* ALSO KEEP IN MIND THAT STYLING SHOULD GO IN THEME.LESS - NOT HERE!! THIS FILE SHOULD ONLY CREATE THE SKELETON; NOTHING MORE NOTHING LESS.
*/
body {
  /********************************
    *** FORMS / INPUTS
    ********************************/
}
body input[type="text"],
body input[type="password"],
body textarea,
body select {
  border-radius: 4px;
  background-color: white;
  color: #000;
}
body input[type="text"]:focus,
body input[type="password"]:focus,
body textarea:focus,
body select:focus {
  border-color: #b4d2d9;
  outline: none;
  box-shadow: 0 0 3px rgba(35, 17, 63, 0.7);
}
body .dx-selectbox,
body .dx-datebox,
body .dx-textbox,
body .dx-numberbox,
body .dx-checkbox-container {
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
}
body .wd-form-field .wd-field-value .wd-field-label {
  margin: 4px 0;
  width: 100%;
  color: #6d6d6d;
}
body .wd-form-field.wd-form-modern-field {
  padding: 0px 0px 10px;
  margin-bottom: 0px;
}
body .wd-form-field.wd-form-modern-field .wd-field-value {
  padding: 0;
  margin: 0;
}
body .wd-form-field.wd-form-modern-field .wd-field-label {
  margin: 4px 0;
  width: 100%;
}
body {
  /********************************
    *** BUTTONS
    ********************************/
}
body button.btn,
body a.btn,
body .btn {
  border-radius: 4px;
  font-weight: bold;
  font-size: 12px;
}
body .btn-primary {
  background-color: #b4d2d9;
  border: none;
  color: #130922;
}
body .btn-primary:hover {
  background-color: #92bec8;
}
body {
  /********************************
    *** WD -> PANELS / GROUPS
    ********************************/
}
body div.wd-group-panel {
  border: 1px solid #dddddd;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}
body div.wd-group-panel .wd-header-container {
  background: linear-gradient(190deg, #251242, #301756);
  border-bottom: 1px solid #dddddd;
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
}
body div.wd-group-panel .wd-header-container.py-2 {
  padding-top: 0.4rem !important;
  padding-bottom: 0.4rem !important;
}
body div.wd-group-panel .wd-header-container .wd-header-title {
  color: #bbd6dc;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding-top: 2px;
}
body div.wd-group-panel .wd-header-container .wd-icon {
  color: #b4d2d9;
  font-size: 1.2rem;
}
body div.wd-group-panel .wd-panel-content {
  color: #333333;
  font-size: 14px;
}
body div.wd-group-panel .wd-panel-content .wd-group-panel {
  background-color: #f3f3f3;
}
body div.wd-group-panel .wd-panel-content .wd-group-panel .wd-header-container {
  background: linear-gradient(90deg, #b4d2d9, #cfe2e7);
}
body div.wd-group-panel .wd-panel-content .wd-group-panel .wd-header-container .wd-icon,
body div.wd-group-panel .wd-panel-content .wd-group-panel .wd-header-container .wd-header-title {
  color: #23113f;
}
body div.wd-group-panel .wd-panel-content .wd-group-panel .wd-header-container .wd-header-right {
  display: flex;
  flex-grow: 1;
  justify-content: right;
}
body div.wd-group-panel .wd-panel-content .wd-group-panel .wd-header-container .wd-header-right .flx-button-bar a.flx-bar-button:hover {
  background-color: #fff;
}
body {
  /********************************
    *** WD -> SIDEBAR
    ********************************/
}
body .wd-sidebar .wd-side-menu {
  color: #b4d2d9;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-modern-sidebar-button-collapse {
  background-color: #ece9e3;
  border-color: #b4d2d9;
  color: #4d666e;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-menu-heading {
  color: #b4d2d9;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-menu-link {
  color: white;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-menu-link:hover,
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-menu-link:focus {
  background: #3d2760;
  color: white;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-menu-link.active {
  background-color: #3d2760;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-navigation-item .wd-side-navigation-item-icon {
  color: white;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-navigation-item .wd-side-navigation-item-icon:hover {
  background: #b4d2d9;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-navigation-item .wd-side-navigation-item-icon.active {
  background: #4d666e;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-modern-sidebar-navigation-bar {
  background-color: #130922;
  border: none;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-modern-sidebar-sub-menu {
  background-color: #251242;
}
body {
  /********************************
    *** WD -> TABSTRIP
    ********************************/
}
body div.wd-tabstrip.tabbed .container-tabstrip > .container-tabs > .wd-tabbar-button {
  padding-top: 11px;
}
body div.wd-tabstrip.tabbed .container-tabstrip > .container-tabs > .wd-tabbar-button a {
  color: #333333;
  text-decoration: none;
}
body div.wd-tabstrip.tabbed .container-tabstrip > .container-tabs > .wd-tabbar-button.active {
  background: linear-gradient(190deg, #58747d, #43585f);
  border-bottom: none;
}
body div.wd-tabstrip.tabbed .container-tabstrip > .container-tabs > .wd-tabbar-button.active a {
  color: white;
  background-color: transparent;
}
body div.wd-tabstrip.tabbed .container-tabstrip > .container-tabs > .wd-tabbar-button:hover {
  background-color: #8ca6af;
}
body div.wd-tabstrip.tabbed .container-tabstrip > .container-tabs > .wd-tabbar-button:hover a {
  color: white;
  background-color: transparent;
}
html,
body {
  height: 100%;
  margin: 0;
  font-family: 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
  background-color: #ece9e3;
  color: #333333;
  /************************************************************
    *** LAYOUT STRUCTURE
    *************************************************************/
  /*##########################################################
    ************************ LEFT SIDEBAR WITH CONTENT STRUCTURE
    ###########################################################*/
  /************************************************************
    *** ELEMENTS
    *************************************************************/
  /********************************
    *** PUBLIC WIDGET
    ********************************/
  /************************************************************
    *** PUBLIC PAGE
    *************************************************************/
}
html a,
body a {
  color: #23113f;
}
html a:hover,
body a:hover {
  color: #4d666e;
  text-decoration: underline;
}
html .container-fluid,
body .container-fluid {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
html #content,
body #content {
  background-color: #ece9e3;
  flex: 1;
}
html #footer,
body #footer {
  height: 60px;
  padding: 20px 20px;
  text-align: center;
  border: none;
  background-color: #130922;
  color: white;
  font-size: 13px;
}
html #footer a,
body #footer a {
  color: #b4d2d9;
  text-decoration: none;
}
html #header,
body #header {
  background-color: #23113f;
}
html #header .topsection,
body #header .topsection {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}
html #header .topsection .logo,
body #header .topsection .logo {
  margin-left: 20px;
  margin-top: 20px;
  margin-bottom: 20px;
}
html .page-left-sidebar,
body .page-left-sidebar {
  display: flex;
  height: 100%;
  flex-direction: row;
}
html .page-left-sidebar .sidebar,
body .page-left-sidebar .sidebar {
  min-width: 300px;
  margin-right: 10px;
}
html .page-left-sidebar .content,
body .page-left-sidebar .content {
  flex: 1;
  min-width: 0;
  margin: 30px;
}
html form,
body form {
  display: flex;
  flex-direction: column;
  height: 100%;
}
html button.btn,
body button.btn,
html a.btn,
body a.btn {
  margin-right: 5px;
}
html .message-box-info,
body .message-box-info {
  margin-bottom: 10px;
  border-radius: 3px;
  padding: 10px;
  background-color: #f5f5f5;
  border: 1px solid #d3d3d3;
}
html .modern-column .modern-column,
body .modern-column .modern-column {
  padding-left: 10px;
  padding-right: 10px;
}
html .kbs-public-widget .panel-container,
body .kbs-public-widget .panel-container {
  background-color: #f8f8f8;
  border: 1px solid #dddddd;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border-radius: 16px;
}
html .kbs-public-widget .panel-container h3,
body .kbs-public-widget .panel-container h3 {
  color: #4d666e;
}
html .kbs-public-widget .panel-container a,
body .kbs-public-widget .panel-container a {
  color: #44217b;
  cursor: pointer;
}
html .kbs-public-widget .panel-container a:hover,
body .kbs-public-widget .panel-container a:hover {
  color: #23113f;
  text-decoration: underline;
}
html #public-content,
body #public-content {
  margin: 70px 0;
}
html .kbs-public-widget,
body .kbs-public-widget {
  min-width: 600px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}
@media (max-width: 999.99999px) {
  html .kbs-public-widget,
  body .kbs-public-widget {
    margin-top: 50px;
    margin-bottom: 50px;
  }
}
html .kbs-public-widget.extended,
body .kbs-public-widget.extended {
  min-width: auto;
  max-width: 1000px;
  margin: auto;
}
html .kbs-public-widget .row,
body .kbs-public-widget .row {
  width: 100%;
}
html .kbs-public-widget div.panel-container,
body .kbs-public-widget div.panel-container {
  margin-top: 20px;
  margin-bottom: 20px;
  max-width: 500px;
  min-height: 150px;
  padding: 20px;
  width: 80%;
}
/********************************
*** VARIABLE UTILITIES
********************************/
.primary-color {
  color: #130922;
}
.primary-color-bg {
  background-color: #130922;
}
.secondary-color {
  color: #23113f;
}
.secondary-color-bg {
  background-color: #23113f;
}
.primary-accent-color {
  color: #4d666e;
}
.primary-accent-color-bg {
  background-color: #4d666e;
}
.secondary-accent-color {
  color: #b4d2d9;
}
.secondary-accent-color-bg {
  background-color: #b4d2d9;
}
/************************************************************
*** UTILITIES
*************************************************************/
.justify-content-evenly {
  justify-content: space-evenly;
}
.mt-xs-3,
.my-xs-3 {
  margin-top: 1rem;
}
.strong {
  font-weight: bold;
}
.underline {
  text-decoration: underline;
}
body {
  /************************************************************
    *** BOOTSTRAP OVERRIDES
    *************************************************************/
}
body .display-5 {
  font-size: calc(1.425rem + 2.1vw);
}
body .display-1 {
  font-size: calc(1.425rem + 0.2vw);
}
/* 
* ANY STYLING/SKELETONS WHATEVER, SPECIFIC TO THE PROJECT GOES HERE.
* REMEMBER: for this file if you write new classes you don't have to use the theme.less file for the styling, just configure them locally here.
*/
body .alert-eurosafe-notification {
  font-size: 14px;
  border: 1px solid #4d666e;
}
body .alert-eurosafe-notification strong,
body .alert-eurosafe-notification b {
  color: #4d666e;
}
body .public-action-card {
  background-color: #b4d2d9;
  color: white;
  border-radius: 12px;
  min-height: 250px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 15px;
}
body .public-action-card:hover {
  transform: scale(1.05);
}
body .public-action-card .public-action-card-body {
  padding: 30px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
body .public-action-card .public-action-card-body .icon {
  font-size: 68px;
  color: #130922;
  margin-bottom: 20px;
}
body .public-action-card .public-action-card-body h3 {
  color: #23113f;
  margin-bottom: 10px;
  font-size: 24px;
}
@media (max-width: 768px) {
  body .public-action-card {
    min-height: 200px;
  }
  body .public-action-card-body .icon {
    font-size: 48px;
  }
}
body .stepper::before {
  content: '';
  position: absolute;
  top: 22px;
  left: 0;
  right: 0;
  height: 2px;
  background-color: #4d666e;
  z-index: 0;
}
body .step {
  position: relative;
  z-index: 1;
  flex: 1;
}
body .step-circle {
  width: 40px;
  height: 40px;
  margin: 0 auto;
  background: linear-gradient(190deg, #c5dce2, #8bbac4);
  color: #23113f;
  border-radius: 50%;
  line-height: 40px;
  font-weight: bold;
  transition: all 0.3s ease;
}
body .step.active .step-circle {
  background: linear-gradient(190deg, #6e8f9a, #43585f);
  color: #fff;
}
body {
  /************************************************************
    *** BOOTSTRAP OVERRIDES
    *************************************************************/
  /********************************
    *** ALERTS - to complement the darker background colors
    ********************************/
  /************************************************************
    *** KSBFOUNDATION OVERRIDES
    *************************************************************/
}
body .content {
  margin: 20px;
}
body .row {
  margin-right: 0px;
  margin-left: 0px;
}
body .alert-danger {
  color: #86323a;
  background-color: #ffc9cd;
  border-color: #f2a7af;
}
body .alert-success {
  color: #246833;
  background-color: #b6e6c1;
  border-color: #83d396;
}
body .alert-warning {
  color: #95720e;
  background-color: #ffefbb;
  border-color: #e8d18c;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar {
  min-width: 75px;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-modern-sidebar-navigation-bar {
  position: fixed;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-modern-sidebar-navigation-bar-bottom {
  padding-bottom: 40px;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-modern-sidebar-sub-menu {
  margin-left: 75px;
  height: 100%;
}
body .wd-sidebar .wd-side-menu.wd-side-modern-sidebar .wd-side-modern-sidebar-button-collapse {
  position: fixed;
}
body .wd-side-navigation-item-logo img {
  max-width: 55px;
}
body div.wd-group-panel div.wd-header-container {
  display: flex;
  justify-content: inherit !important;
}
body div.wd-group-panel div.wd-header-container .wd-icon {
  margin-right: 3px;
}
body .wd-tabstrip.tabbed .wd-tabbar-button {
  padding-top: 12px;
}
body .upload-widget .preview {
  text-align: center;
}
body .upload-widget .preview img {
  max-width: 200px;
}
