@import url("variables.css?v=202409");

/*
 * Base structure
 */

/* Move down content because we have a fixed navbar that is 120px tall */
body 
{
  padding-top: 100px;
  font-family: "Poppins", sans-serif !important;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 1600px) 
{
	.main-width
	{
		padding-left: 50px;
		padding-right: 50px;
	}
}



/*
 * Global add-ons
 */

.sub-header {
  padding-bottom: 10px;
  border-bottom: 1px solid #eee;
}

/*
 * Top navigation
 * Hide default border to remove 1px line.
 */


/*
 * Sidebar
 */

/* Hide for mobile, show later */
.x-sidebar {
  display: none;
}
.sidebar {
  margin-top: 20px;
}
@media (min-width: 768px) {
  .x-sidebar {
    position: fixed;
    top: 51px;
    bottom: 0;
    left: 0;
    z-index: 1000;
    display: block;
    padding: 20px;
    overflow-x: hidden;
    overflow-y: auto; /* Scrollable contents if viewport is shorter than content. */
    border-right: 1px solid #eee;
  }
  
  
	.nav-separator 
	{
	}

	.nav-separator  a
	{
		border-left: 2px solid #d9d9d9;		
	}

}

/* Sidebar navigation */
.nav-sidebar {
  margin-right: -21px; /* 20px padding + 1px border */
  margin-bottom: 20px;
  margin-left: 0px;
}
.nav-sidebar > li > a {
  padding-top: 1px;
  padding-bottom: 1px;
  padding-left: 0px;
  padding-right: 0px;
}

.submenu>li>a
{
  padding-top: 1px;
  padding-bottom: 1px;
  padding-left: 0px;
  padding-right: 0px;
}



/*
 * Main content
 */

.main {
  padding: 20px;
}
.col-xs-12.main {
  padding-top: 55px;
}
@media (min-width: 768px) {
  .main {
    padding-right: 40px;
    padding-left: 40px;
  }
}
.main .page-header , .main .page-header-show-always
{
  margin-top: 6px;
  margin-bottom: 5px;
  font-size: 30px;
  text-transform: initial;
}


/*
 * Placeholder dashboard ideas
 */

.placeholders {
  margin-bottom: 30px;
  text-align: center;
}
.placeholders h4 {
  margin-bottom: 0;
}
.placeholder {
  margin-bottom: 20px;
}
.placeholder img {
  display: inline-block;
  border-radius: 50%;
}

/**
 * Värejä
 */
.navbar-inverse
{
	background-color: var(--text-color);
	border-color: #101010;
}	
.navbar-inverse .navbar-brand
{
	color: #fff;
	font-weight: bold;
}

.navbar
{
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	background-attachment: fixed;
}
.nav-container
{
  background-color: transparent;
      box-shadow: none;
    background-image: url(tausta.jpg?v=202409);
    background-color: transparent !important;
    background-size: cover !important;
    background-position: bottom !important;
    background-attachment: initial;
    background: var(--sidebar-background) !important;
}
.nav-container .container-fluid.main-width
{
	border-bottom: 0px solid var(--theme-color);
	background-color: var(--banner-background);
	/*tehty variable bannerin värille. Default asetuksena 'transparent'*/
}
.navbar-fixed-top 
{
  border: 0;
  x-border-top: 5px solid var(--theme-color);
  /*background: url(banner.jpg) !important;*/
  background-position: 0 83% !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  /*border-bottom: 8px solid var(--theme-color);*/
}

.navbar-brand
{
	height: 123px;
	padding: 0px 0px 30px 0px;
}

/* submenu */
.submenu
{
	padding-left: 0px;
}

.submenu-level-1 > .active 
{
}

.submenu-level-2 > .active 
{
}


.tila-info > .tila-info-item,
.tila-info-subitem:last-child
{
	margin-right: 0px !important;
}
/*
.tila-info
{
	display: inline-block;
}	



.tila-info
{
	margin-right: 25px;
	margin-bottom: 25px;
	background-color: #fff;
}
.tila-info-subitem table
{
	width: 350px !important;
	max-width: 350px !important;
	margin-bottom: 0px;
}
*/
.tila-info-item > .tila-info-subitem
{
	width: 50%;
}
.tila-info-subitem table
{
	max-width: 100% !important;
}

.tila-info
{
	margin-bottom: 25px;
}
.tilakortti > .tila-info
{
	background-color: #edeff6;
	box-shadow: 0 8px 8px rgba(0,0,0,0.10);
}

.tila-info-subitem
{
	vertical-align: top !important;
	font-size: 16px;
}
.select-btn {
	position: absolute;
	bottom:20px;
	right:25px;
}

.asio-bg-thumbnail
{
	/*min-width: 200px;*/
	margin-right: 0px !important;
	height: auto !important;
	background-size: cover;
	background-position: center; 
}
.asio-thumbnail
{
	max-height: 125px;
	overflow: hidden;
	margin-right: 0px !important;
}
.asio-thumbnail > img
{
	width: 250px !important;
	max-width: 250px !important;
}
.asio-calendar .fc-center > h2
{
	font-size: 14px;
	margin: 0 !important;
	padding: 0;
}

.tiladata-lomake .panel-body
{
	padding-left: 0px;
	padding-right: 0px;
}



/* ... from Asio-common-bootstrap ... */

/**
 * Asio-Bootstrap - yhteiset stylet
 */

.loading-marker
{
	display: none;
	}

body.loading .loading-marker
{
	display: block;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 300px;
	height: 300px;
	margin-top: -150px; /* Half the height */
	margin-left: -150px; /* Half the width */	
}

.badge-notify
{
   background:red;
   position:relative;
   top: -20px;
   left: -35px;
} 

.navbar-legacy-ylapalkki
{
    position: relative;
    float: right;
    margin-top: 8px;
    x-margin-right: 15px;
    margin-bottom: 8px;
    background-color: transparent;
    background-image: none;
    border: 1px solid transparent;
	border-top-color: transparent;
	border-right-color: transparent;
	border-bottom-color: transparent;
	border-left-color: transparent;
    border-radius: 4px;
}

.legacy
{
	display: none;
}

.resp-hdr
{
	background-color: #f0f0f0;
}


.nopadding 
{
   padding: 0 !important;
   margin: 0 !important;
}

.navbar-brand
{
	/*max-width: 85%;*/
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* navbar related styles
-------------------------------------------------- */

.navbar-inverse .navbar-toggle
{
	border: 0px none;
}

.nav-logo
{
	max-width: 250px;
	margin-top: 25px;
	display: inline-block;
}
@media (max-width: 991px) 
{
	.navbar-brand img {
		width: 110px !important;
		margin-top: 5px !important;
	}
}

@media (max-width: 767px) 
{
	body 
	{
		padding-top: 140px;
	}
	
	.navbar
	{
		min-height: 90px;
	}
	
	.navbar-brand
	{
		min-height: 90px;
		height: 90px;
	}
	.navbar-brand img
	{
		margin-left: 15px;
	}

	.navbar-brand img
	{
		margin-left: 15px;
		width: 95px !important;
		margin-top: 0px !important;
	}
	
	.navbar-brand
	{
		padding-bottom: 5px;
	}
	.navbar-nav
	{
		margin-top: 0px !important;
	}
	.navbar
	{
		background-position: top right;
		background-attachment: fixed;
	}
	.nav > li
	{
		margin-top: 10px;
		margin-bottom: 10px;
	}
	.navbar-header {
        background: #ffffff9e;
    }
    .navbar-inverse .navbar-collapse, .navbar-inverse .navbar-form {
        background: white;
    }
}

@media (min-width: 768px) {
	.x-sidebar {
		top: 121px;
	}
	body 
	{
		padding-top: 180px;
	}
	.breadcrumb-container > .container
	{
		padding-left: 0px;
	}
}

@media (max-width: 420px) {
	.nav-logo
	{
		max-width: 200px;
	}
}

.navbar
{
	/*border-bottom: 1px solid #dedede;*/
	box-shadow: 0 8px 8px rgba(0,0,0,0.10);
}



/* Sticky footer styles
-------------------------------------------------- */
html {
  position: relative;
  min-height: 100%;
}
body {
  /* Margin bottom by footer height */
  margin-bottom: 100px;  
}
.footer {
  position: absolute;
  bottom: 0;
  width: 100%;
  /* Set the fixed height of the footer here */
  height: 80px;
  
  background-color: var(--footer-background);
  
  z-index: 1040;  
}
footer a {
    color: var(--footer-links-color);
}
footer a:hover, footer a:focus {
    color: var(--footer-links-color);
    text-decoration: underline;
}
.footer > div.top:first-child
{	
}

.footer hr
{
	border: 1px solid #bbb;
	margin-top: 10px;
	margin-bottom: 10px;
}
ul.footer-links
{
	margin: 0;
	padding: 0;
}
ul.footer-links li
{
	display: inline-block;
	margin-right: 30px;
	font-size: 0.75em;
}


@media (min-width:768px)
{
	.navbar-brand
	{
		overflow: visible;
	}
	
	.navbar-top-left
	{
		margin-left: 40px;
	}
	
	.navbar-top-left li a
	{
		color: #2d2d2d;
		font-weight: bold;
		font-size: 1.6rem;
	}
	
	.navbar-right li a
	{
		color: #333333;
		font-weight: bold;
		font-size: 1.6rem;
	}
	
	.nav-container
	{
		/* navigaation "taustaraitakuvaa" varten */
		background-repeat: repeat-x;
		background-position: bottom left;
		background-size: 45px 45px;
        /*border-left: 30px solid #000000;*/
	}
	
}

.breadcrumb-container {
    background-color: var(--breadcrumb-background);
    margin-top: 24px;
    padding-top: 10px;
}

@media (max-width: 991px)
{
	.navbar-top-left li a
	{
		font-size: 1.5rem;
	}
	.navbar-right li a
	{
		font-size: 1.5rem;
	}
	
	
	.fc-right, .fc-left
	{
		margin-bottom: 8px;
	}
	
	.x-sidebar 
	{
		xmargin-bottom: 280px;  
	}
	
	body
	{
		margin-bottom: 300px;  
	}		
	
	.footer
	{
		height: 90px;
	}
	
	.select-btn {
		bottom:0px;
	}
	.breadcrumb-container {
        margin-top: 12px;
        padding-top: 11px;
        padding-bottom: 2px;
    }
	
}

/*
@media (max-width:480px)
{
	.container
	{
      padding: 0;
      margin: 0;
    }
	
	.row
	{
		margin-left: 0;
		margin-right: 0;
	}

    .navbar-fixed-top, .navbar-fixed-bottom, .navbar-static-top
	{
      margin-left: 0;
      margin-right: 0;
      margin-bottom:0;
    }
	
	.well
	{
		margin-left: 0px;
		margin-right: 0px;
	}

}
*/

@media (max-width:767px)
{
	.page-header
	{
		display: none;
	}
}

/* -- LOADING-vehje -- */
body.loading div.container-main > *
{
	opacity: 0.25;
}
body.loading div.container-main > nav
{
	opacity: 1;
}

.loading-marker
{
	display: none;
}

body.loading .loading-marker
{
	display: block !important;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 300px;
	height: 300px;
	margin-top: -150px; /* Half the height */
	margin-left: -150px; /* Half the width */
	z-index: 9999;
}



.navbar-keuda
{
	background-color: #fff;
}

.navbar
{

}

.breadcrumb-container
{	
	background-color: var(--breadcrumb-background);
	/*margin-top: 27px;*/
}
.breadcrumb-container .breadcrumb
{
	margin-bottom: 0px;
	padding-left: 0px;
	/*padding-top: 3px;*/
	padding: 12px 0px 3px 0px;
}
.breadcrumb-container .breadcrumb > .active
{
	color: var(--breadcrumb-text-color-active);
}
.breadcrumb-container .breadcrumb a
{	
	color: var(--breadcrumb-text-color);
}


.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6
{
	font-family: 'Montserrat', sans-serif;	
	font-weight: bold;
	color: var(--headings-color);
	letter-spacing: 0;
}


h1,h2,h3,.h1,.h2,.h3
{
	font-weight: 700;	
}

.h1, h1
{
	font-size: 48px;
}

.h2, h2
{
	font-size: 24px;
}

.h4, h4
{
	font-size: 17px;
}

.page-header, .page-header-show-always
{
	border-bottom: none;
	position: relative;
	padding-bottom: 10px;
	margin-bottom: 25px !important;
}

.page-header-show-always::after , .page-header::after 
{
    content: ' ';
    position: absolute;
    bottom: -5px;
    left: 23px;
    width: 40px;
    border: 3px solid var(--theme-color);
    transform: translateX(-50%);
}

.navbar-top-left li.active a
{
	color: #333333;
}


/* Bootstrap -> Joensuu - css-runnomiset */

/* Yhteystietopaneelin ontin kokoa pienemmäksi jotta sähköpostiosoite ei valu yli */
.panel-body a
{
	font-size: 12px;
}

.panel , .panel-heading
{
	x-border-radius: 0px;
	x-border: 0px none;
	x-border-color: transparent;
}
.panel
{
	box-shadow: 0 0px 2px 0 rgba(0,0,0,0.2),0 3px 10px 0 rgba(0,0,0,0.19);
}

.panel-primary > .panel-heading
{
	background-color: #337ab7;	
}
.panel-warning > .panel-heading
{
	background-color: #ffce00;	
	color: var(--text-color);
}

.panel-heading
{
	font-size: 16px;
	font-weight: 500;
}

.btn
{
	
}

.tila-info-subitem .btn
{
	padding: 8px 12px 8px;
	margin-bottom: 8px;
}

.btn-warning
{
	background-color: #ffce00;
	border-color: #ffce00;
	color: var(--text-color);
}

button.ui-state-active
{
	background-image: none;
	background-color: #333333;
	color: #fff;
}


/* Tilainfon puukot */
.tilainfo .panel-body
{
	padding: 0;
}
.tilainfo .panel-body  div > div > div:first-child > div
{
	padding: 0px 15px;
}
.tilainfo .panel-body  div > div > div:first-child > div img
{
	margin-top: 15px;
}



@media (max-width: 1199px)
{
	select.navigation-select
	{
		background-image: none;
		background-color: #fff;
		-webkit-appearance: none;		
		min-width: 250px;
	}
	
	h2.page-header
	{
		display: none;
	}
	.breadcrumb-container {
    }
}


.vk-laji .panel-body
{
	padding: 0;
}


.asio-bg-thumbnail
{
	height: auto;
}

label.required:after 
{
  content: "*";
  color: red;
}

span.hlolkm
{
	padding-left: 15px;
	font-weight: normal;
}
.bg-primary .hlolkm
{
	color: #7be0ff;
}
.tila-info-item
{
	min-height: 180px;
}

.html-after-tilainfo-container
{
	position: relative;
	display: block;
	float: right;
	width: 50%;	
}
.html-after-tilainfo-container > span
{
	text-align: right;
}
.html-after-tilainfo-container > *,
.modal-content > *
{
	text-align: left;
}
.html-after-tilainfo
{
	position: absolute;
	right: 0px;
	bottom: 0px;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-bottom: 5px solid transparent;
}
.html-after-tilainfo button, .html-after-tilainfo input
{
	margin-bottom: 5px;
}
.loadmore-button-container
{
	min-height: 150px;
}

.vapaahaku-form-container
{
	max-width: 900px;
}

.asio-search-results-container
{
	max-width: 1100px;
}


.asio-favorite-indication
{
	color: #09f !important;
}

.clickable
{
	cursor: pointer;
}


.modal-body .star-rating-item
{
	font-size: 24px;	
	letter-spacing: 3px;
}

.label-primary
{
	background-color: rgba(24,38,43,0.8);
}

.sidebar .btn
{
	text-align: left;
	border: 0px none;
	font-size: 16px;	
	border-radius: 0px;
}
.sidebar .submenu .btn
{
	font-weight: normal;
}

.sidebar .btn a
{
	color: #fff;
	overflow: hidden;
	text-overflow: ellipsis;
	padding: 7px 12px;
}

.sidebar .btn a:hover, .sidebar .btn a:focus
{
	background-color: transparent;
}
.nav > li > a:hover, .nav > li > a:focus
{
	background-color: transparent;
	color: rgba(24,38,43,0.8);
}
.sidebar .submenu .btn:last-child
{
    margin-bottom: 10px;
}
.sidebar .btn i.fa-plus,
.sidebar .btn i.fa-minus
{
    padding: 5px 10px;
}
.sidebar .submenu li.btn
{
    padding: 0;
    margin-left: 0px;
}
.sidebar .submenu .submenu li.btn.btn-active
{
    padding: 6px 18px;
    margin-left: 0px;
}
.nav-sidebar li
{
	margin-bottom: 8px;
	margin-top: 8px;
}

.sidebar .btn-info
{
	background-color: var(--sidebar-background);		
	border: var(--sidebar-borders);
	box-shadow: var(--sidebar-shadows);
	padding: 0px;
}
.sidebar .btn-info > a
{
	color: var(--sidebar-text-color);
	border: 2px solid var(--sidebar-left-border-color);
	display: block;
	padding: 10px 20px;
    font-weight: 600;
}

.sidebar .btn-basic
{
	background-color: #d9d9d9;
}

.sidebar .btn-basic > a
{
	color: #252525;
}

.sidebar .btn-active
{
	background-color: var(--theme-color);
}
.sidebar .btn-active > a
{
	border-color: var(--sidebar-left-border-color);
	color: var(--sidebar-background-active-color);	
}


.sidebar .btn-active > a:hover,
.sidebar .btn-info > a:hover
{
	color: var(--sidebar-text-color-hover);
	border-color: var(--sidebar-left-border-color-hover);
	background-color: var(--sidebar-background-hover);
	text-decoration: none;
}

.sidebar .submenu .btn-active > a:hover,
.sidebar .submenu .btn-active > a:focus
{
	background-color: transparent;
	color: white;
}

.sidebar .btn-info-opened
{
	border: 2px solid var(--theme-color);
}

.sidebar .btn-info-opened > a
{
	color: var(--theme-color);
}

li.nav-search
{
	
}
span.magnifying-glass
{
	background-image: url('search.php?color=000000');
	background-repeat: no-repeat;
	background-size: contain;
	background-position: left center;
	background-color: transparent !important;
	
	display: inline-block;
	width: 28px;
	margin-left: 10px;
	margin-right: 0px;
}
li.nav-search > a:hover > span.magnifying-glass
{
	
}


.panel-primary
{
	border-radius: 0px;
	border: 0px none;
}
.bg-primary, .panel-primary > .panel-heading
{
    background-color: #000000;
    border-left: 9px solid #676767;
	border-bottom: 0px none;
	border-top: 0px none !important;
	color: #fff;
	font-weight: normal;
	border-radius: 0px;
}

.bg-primary .modal-title, .panel-primary .modal-title
{
	color: #fff;
}

.btn-primary
{
    background-color: var(--theme-color3);
	border: 2px solid var(--text-color);
	color: var(--text-color);
	border-radius: 24px;
}
label .btn.btn-primary: active {
	/* Darker background color when button is active */
  background-color: #0056b3; /* Darker background color */
}

.kuva-container
{
	margin-left: 15px;
	margin-right: 15px;
	margin-bottom: 15px;
	overflow: hidden;	
}
.kuva-container .img-responsive
{
	max-width: 96%;
}

.map-container > a
{
	display: inline-block;
	padding: 5px 15px;
	margin-bottom: 15px;
	background-color: var(--theme-color);
	color: #fff;
}
.map-container > a:hover, .map-container > a:focus
{
	text-decoration: none;
}

.tilainfo > .panel > .panel-body
{
	padding-bottom: 15px;
}
.tila-info-text-item
{
	margin-left: 15px;
	margin-right: 15px;
}

.tasmahaku-container > h3
{
	margin-top: 2px;
}

.tila-info-subitem .longvalue 
{
	font-size: 13px;
	overflow: hidden;
	text-overflow: ellipsis;
}
.tila-info-subitem > table
{
	margin-bottom: 40px;	
}
.tila-info-subitem 
{
	
}

.mobi-navi-container
{
	margin-top: 15px;
}


/* no-gutters trick */
.row.no-gutters {
  margin-right: 0;
  margin-left: 0;
}
.row.no-gutters > [class^="col-"],
.row.no-gutters > [class*=" col-"] {
  padding-right: 0;
  padding-left: 0;
}


.navbar-nav
{
    margin-top: 92px;
    padding-bottom: 10px;
}
.navbar-nav > li > a
{
	padding-bottom: 0px;
	padding-top: 0px;
	vertical-align: bottom;
	font-weight: normal;
	color: #1960ab;
}

.navbar-inverse .navbar-nav > li > a,
.navbar-inverse .navbar-nav > li.active > a
{
	color: #252525;
}
.navbar .navbar-nav  li > a:hover
.navbar .navbar-nav  li.active > a:hover,
.navbar-inverse .navbar-nav > li > a
{
	color: #cacaca !important;	
}


.navbar-inverse .navbar-right > .active > a,
.navbar-inverse .navbar-right > .active > a:hover
{
	background-color: transparent;
}


@media (min-width: 971px) 
{	
	.nav-logo
	{
		max-width: 280px;
	}

	.shopping-cart-container
	{
		display: block;
		position: relative;
	}

	.shopping-cart-container > #asio-basket
	{
		position: absolute;
		right: 0;
		bottom: 8px;
	}
	.breadcrumb
	{
		padding-right: 200px;
	}
}
@media (max-width: 970px) 
{
	.shopping-cart-container
	{
		display: block;
		padding-top: 5px;
		padding-bottom: 5px;
	}
}

.tasmahaku-formi span.kt-no-search-match
{
	display: none;
}


.frontpage-picture-item, .frontpage-small-picture-item
{
	margin-right: 15px;
}

.frontpage-picture-item > .panel-body, 
.frontpage-small-picture-item > .panel-body
{
	
}
.frontpage-item-title
{
	margin: 10px 5px;
	text-decoration: none;
	font-weight: normal;
	color: var(--text-color)000;	
	font-size: 20px;
}
.panel.frontpage-picture-item
{
	overflow: hidden;
	border-radius: 2px;
}
.panel-body.clickable-item
{
	padding: 0px;
	overflow: hidden;
	border-radius: 2px;
}





/* Täsmähaku / multiselect */
.panel-tasmahaku
{
	border-radius: 0px;
	border: 0px none;
}
.panel-tasmahaku > .panel-heading
{
	font-size: 18px;
	font-weight: normal;
	font-family: 'Montserrat', sans-serif;
	cursor: pointer;
	border-radius: 0px;
	border-bottom: 0px none;
	color: var(--text-color);
	background-color: #ededed;				
}
.panel-tasmahaku-expanded > .panel-heading
{
	background-color: #ffffff;
	color: var(--text-color);
	border-left: 5px solid #a4eddd;
}
.panel-tasmahaku > .panel-body
{
	padding-left: 8px;
	padding-right: 8px;
	background-color: #f0f0f0;
}
i.expand-marker 
{
	display:none;
	float: right;
	margin-top: 5px;
}
div.panel-tasmahaku-expanded i.expand-marker 
{
	display:inline;
	color: #fff;
}	
.multiselect-item > input
{
	display: none;
}	
.multiselect-item
{
	cursor: pointer;
	font-size: 16px;
	display: inline-block;
	margin-right: 1px;
	margin-bottom: 8px;
	color: var(--text-color);
	font-weight: normal;
	border-radius: 15px;
	background-color: #ffffff;
	padding: 8px 18px;
}
.multiselect-item:hover
{
	background-color: rgba(24,38,43,0.7) !important;
	color: #fff;
}
.multiselect-item-selected
{
	background-color: var(--theme-color);
	color: #fff;
}
.multiselect-item-selected:hover
{
	background-color: #0098cf !important;
	color: #ff0;
}


.breadcrumb
{
	background-color: transparent;
}

.mini-shoping-cart-empty, .cart-parent-container-is-empty
{
	display: none;
}

	
.mini-shopping-cart a
{
	color: #fff;
	text-decoration: none;
}

@media (max-width:480px)
{
	.tila-info-item-flexing
	{
		display: block !important;
		width: 100%  !important;
	}
	.asio-bg-thumbnail.tila-info-item-flexer
	{
		min-height: 180px;
	}	
	.tila-info-item-flexer
	{
		display: block !important;
		width: 100%  !important;
	}
	.html-after-tilainfo-container
	{
		float: none;
		position: static;
		display: block;
		width: 100%  !important;
		}
	.html-after-tilainfo
	{
		position: static;
		display: block;
	}
	.tila-info-subitem .longvalue.room-notes
	{
		padding-bottom: 5px;
	}
	.tila-info-subitem > table
	{
		margin-bottom: 5px;
	}
	table tbody tr th.longlabel.bg-primary
	{
		border-top: 0px none;
	}
}



.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6, th.longlabel, a.asio-calendar-link-vertical
{
	-webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
    text-transform: uppercase;
}



.app-varauspyynto .field-label
{
	font-weight: normal;
	color: #333;
}

.app-varauspyynto .section-header
{
	background-color: #f0f0f0;
	font-weight: normal;
	color: #333;
	font-size: 13px;
	padding-left: 15px;
	padding-right: 15px;
}
.app-varauspyynto .field-label,
.app-varauspyynto .field-value,
table.shopping-cart-contents > tbody > tr > td:first-of-type,
tr.shopping-cart-item > td:first-of-type,
.catering-rendered
{
	padding-left: 15px;
	padding-right: 15px;
}
.section-header.catering-header
{
	padding-top: 8px;
	padding-bottom: 8px;
}
.field-value-full
{
	padding-top: 15px;
	padding-bottom: 15px;
}
.app-varauspyynto .required > span
{
	font-size: 22px;
	font-weight: bold;
	color: red;
}
.app-varauspyynto .check-missing td, .app-varauspyynto .check-missing th
{
	background-color: #ffcccc;
}
.app-varauspyynto .field-value.field-type-catering
{
	padding: 0px;
}
.app-varauspyynto .buttons
{
	margin: 15px;
}
.app-messages
{
	margin: 0;
}

.mobi-submenu li.mobi-navi-item
{
	margin-top: 0px;
	margin-bottom: 0px;
}

.navbar-inverse .navbar-nav > li > a,
.navbar-inverse .navbar-nav > li.active > a
{
    margin-top: 8px;
}

/* fix responsive sidebar */
@media (max-width: 1199px) {
    .sidebar {
        display: initial !important;
    }
}

@media (max-width: 991px) and (min-width: 768px) {
    .nav-sidebar {
        float: left;
        width: 20%;
    }
    .col-md-3 ul {
        float: left;
        width: 25%;
    }
    .col-md-3 ul li {
        margin-left: 10px;
    }
    .col-md-3 ul.submenu {
        width: auto;
        float: inherit;
    }
    .main {
        float: left;
        width: 75%;
    }
	.main.col-xs-12 {
		width: 100%;
	}
}
/* end fix responsive sidebar */

/* start mobile burger menu custom css */
@media (max-width: 767px) {
    .navbar .navbar-nav > li {
        padding: 0;
        margin: 0;
    }
    .navbar .navbar-nav > li > a {
        background: #fff;
        color: #021928 !important;
        border-top: 1px solid #00292b;
        padding: 8px 0px 8px 20px;
        text-transform: uppercase;
        border-color: #aeaeae;
    }
    .navbar .navbar-nav > li:first-child a {
        border-top: none;
    }
    .navbar .navbar-nav > li.active > a {
        background: var(--sidebar-background-active);
        color: var(--sidebar-background-active-color) !important;
    }
    }
    .navbar .navbar-nav > li.nav-search {
        /* padding: 16px;
        border-top: 1px solid var(--text-color)f1b;
        background: #002f53; */
    }
    .navbar .navbar-nav > li > a:hover {
        color: white;
    }
    .navbar .navbar-nav > li > a:hover {
        color: white;
        background: black;
    }
    .navbar .navbar-nav > li .submenu {
        background: #006326;
    }
    .navbar .navbar-nav > li .submenu li {
        padding: 0;
        margin: 0;
    }
    .navbar .navbar-nav > li .submenu li a {
        color: white;
        border-top: 1px solid #00461b;
        padding: 5px 0px 5px 30px;
    }
    .navbar .navbar-nav > li .submenu li.active a {
        background: #002b11;
    }
    .navbar .navbar-nav > li .submenu li a:hover {
        background: black;
    }
    .navbar-brand img {
        margin-top: -18px;
        /*max-height: 100%;*/
    }
    .navbar-inverse .navbar-right > .active > a:hover {
	    background-color: white;
    }
	.navbar-header .navbar-brand img {
        margin-left: 48px !important;
        max-width: 110px !important;
        margin-right: 14px !important;
        margin-top: 10px !important;
    }
    .navbar-inverse .navbar-nav > li > a,
    .navbar-inverse .navbar-nav > li.active > a
    {
	    margin-top: 0px;
    }
    .breadcrumb-container {
        margin-top: -11px;
    }
    span.brand-text {
        width: auto !important;
        margin-top: 29px !important;
    }
    .breadcrumb-container {
        margin-top: -29px;
        padding-top: 2px;
    }
}
/* start mobile burger menu custom css */

/* start breadcrumb layout fix */
.breadcrumb-container .breadcrumb {
    padding: 17px 0px 10px 0px;
}
.navbar-inverse .navbar-nav>li>a:hover
{
    text-decoration: underline;
    color: var(--theme-color) !important;
}
.navbar-inverse .navbar-nav>li>a:hover {
    color: #000 !important;
}
@media (max-width: 971px) {
    .breadcrumb-container .breadcrumb {
        padding: 6px 0px 0px 0px;
    }
}
@media (max-width: 767px) {
    .navbar-fixed-top {
        border-bottom: none;
    }
    .breadcrumb-container .breadcrumb {
        padding: 10px 0px 0px 0px;
    }

    .navbar-inverse .navbar-nav>li>a:hover {
        text-decoration: none;
        background: var(--sidebar-background-hover);
        color: var(--sidebar-text-color-hover) !important;
    }
}
/* end breadcrumb layout fix */


.date-picker.btn-primary > h2
{
	color: inherit;
}
.tilakortti .btn-virtual-tour
{
	font-weight: normal;
	font-size: 85%;
	line-height: 160%;
}

.asio-calendar .fc-time-grid-event .fc-title
{
    font-size: 12px;
    text-transform: lowercase;
}
.asio-calendar .fc-time-grid-event .fc-title:first-letter
{
    text-transform: uppercase;
}
.fc-time-grid .fc-bgevent, .fc-time-grid .fc-event
{
    margin-top: 1px;
}
.asio-calendar .fc-time-grid-event .fc-time
{
    font-size: 12px;
}

.nav-container .container-fluid.main-width.page-container
{
    background: var(--theme-color2);
}

.enroll-form
{
	max-width: 880px;
}

span.brand-text {
    color: #ffffff;
    font-weight: 400;
    text-transform: uppercase;
    font-size: 22px;
    display: block;
    width: 250px;
    float: left;
    margin-left: 33px;
    margin-top: 53px;
    cursor: default;
}

ul.language-select
{
	list-style-type: none;
}
ul.language-select li a, .language-select
{
	color: #404547;	
	text-transform: uppercase;
	font-size: 12px;
}


@media (min-width: 768px) 
{
	.nav-container
	{
	}
	.language-select-container
	{
		position: relative;
	}
	.language-select-container > .language-select
	{
		position: absolute;
		top: 40px;
		right: 2px;
	}
	
	.language-select-container > .language-select
	{
		right: 0px;
	}
}

@media (min-width: 1300px) 
{
	.language-select-container > .language-select
	{
		width: 70px;
		right: 150px;
		top: 83px;
	}
}

.city-name-container { display:none; }

.well.well-lg.login-opt h4 {
    color: white;
}
.page-header-show-always::after, .page-header:empty::after {
    height: 0;
    padding: 0;
    margin: 0;
    display: none;
}

.page-header-show-always::after, .page-header:empty {
    display: none;
}

.row.row-lomakevaraus {
    margin-top: 9px;
}

h2.page-header:empty {
    display: none !important;
}

/* korostettu modalin sulje-nappi */
.modal-dialog .modal-content button.close {
    opacity: 1;
    font-size: 43px;
    margin-top: -16px;
    color: #fff;
}
.modal-header {
    padding-bottom: 10px;
}

.breadcrumb>li {
    display: none;
}
img.social {
    width: 24px;
    padding-right: 4px;
    margin-top: -3px;
}
.vk-kuva {
    width: 100%;
}

.vk-kuva img {
    max-width: 320px;
}

.sidebar .btn-active a {
    border-color: var(--sidebar-left-active-border-color);
    font-weight: bold;
}
.sidebar .btn-active {
    background: var(--sidebar-background-active);
}

/* BOTTOM BAR: crumbs piiloon, värit */
@media (max-width: 767px) 
{
	.main { margin-top: -15px; }			
	body .bottom-bar > a
	{
		color: #000;
	}
	body .bottom-bar > a:hover, body .bottom-bar > a.active
	{
		background-color: #000000;
		color: #fff;
	}	
	.navbar {
        background-size: contain;
        background-position: top right;
        background-repeat: repeat-x;
		background-position: 0 100% !important;
    }
        .nav-container .container-fluid.main-width {
        border-bottom: 0px solid var(--theme-color);
    }
    .navbar-header {
        background: transparent !important;
    }
}


.asio-vt-E
{
	opacity: 1 !important;
}

.brand-text a {
    color: white;
}

@media only screen and (min-width: 972px) and (max-width: 991px)
{
    .breadcrumb-container.show {
        /*margin-top: 11px !important;*/
        margin-bottom: 0px;
        padding-bottom: 0px;
    }
}


.breadcrumb-container {
    margin-top: 0px;
}

@media (max-width: 991px) 
{
    .main.maximize-wide-window
    {
        margin-top: -15px;
        padding-top: 0px;
    }
    .breadcrumb-container
    {
        /*margin-top: 5px;*/
    }
}
@media (max-width: 767px) 
{
    .breadcrumb-container
    {
        /*margin-top: 4px;*/
    }
    
	.alekoodi-container button {
        margin-top: 10px;
    }
}

@media (max-width: 1200px) 
{
    .window-size-tgl-top-placer
    {
        display: none;
    }
}

.breadcrumb-container.show .container-fluid {
    padding-top: 34px !important;
    background: var(--breadcrumb-background);
}


/* Teemun fullcalendar viritys kalenterin otsikoiden fonttivärin muuttamiseksi */
.fc-col-header .fc-col-header-cell
{
	color: #fff !important;
	font-weight: normal !important;
}
a.fc-col-header-cell-cushion, a.fc-timegrid-axis-cushion
{
	color: #000 !important;
}

.btn-primary.active, .btn-primary:active, .open>.dropdown-toggle.btn-primary {
    color: #fff;
    background-color: var(--text-color);
    border-color: var(--text-color);
}

.btn-primary:hover, .btn-primary:focus, .btn-primary.active.focus, .btn-primary.active:focus, .btn-primary.active:hover, .btn-primary:active.focus, .btn-primary:active:focus, .btn-primary:active:hover, .open>.dropdown-toggle.btn-primary.focus, .open>.dropdown-toggle.btn-primary:focus, .open>.dropdown-toggle.btn-primary:hover {
    color: #fff !important;
    background-color: var(--text-color) !important;
    border-color: var(--text-color) !important;
}

.navbar-inverse .navbar-collapse, .navbar-inverse .navbar-form {
    border-color: var(--sidebar-background);
}

.navbar-header {
    background: transparent;
}


@media (max-width: 971px) {
    .breadcrumb-container.show .container-fluid {
        padding-top: 0px !important;
        background: var(--breadcrumb-background-mobile);
        margin-top: -7px;
		padding-right: 0px;
        padding-left: 10px;
    }
    /*
    .mini-shopping-cart-item-total.mini-shopping-cart-item-price-total {
        float: left;
        text-align: left;
        width: 100%;
		padding-bottom: 2px;
    }
    */
}

/* Multiclick-ostoskorin säätö */ 

/* mobiiliresponsiivisuus */
@media (max-width: 370px)
{
	
	.mini-shopping-cart .minicart-kassalle
	{
		margin-top: 4px !important;
		margin-bottom: 3px !important;
		margin-right: 5px!important;
	}
	
	
}

.mini-shopping-cart
{
	display: block;
	padding-top: 2px;
	padding-bottom: 2px;
	text-align: right;
	padding-right: 15px;
}
.fa-shopping-cart
{
	color: #fff;
}

/* Multiclick-vilkkumisen säätö */ 
/* - ostoskoribädgen container, tausta */
.mini-shopping-cart.blink-on
{
	background-color: transparent !important;
}
/* - tekstin väri */
.mini-shopping-cart.blink-on a
{
	background-color: #3788d8 !important;
	color: #fff !important;
	
}

/* jatka-nappi perusväri ja hover */
.btn.btn-warning.btn-sm.minicart-kassalle
{
	background-color: transparent !important;
	border-color: #EDFBE2 !important;
	box-shadow: 0px 0px 0px 0px #3788d8 !important;
	color: #EDFBE2 !important;
	border-radius: 24px;
}
.btn.btn-warning.btn-sm.minicart-kassalle:hover
{
	background-color: #EDFBE2 !important;
	border-color: #EDFBE2 !important;
	box-shadow: 0px 0px 0px 0px #3788d8 !important;
	color: #54B435 !important;
}


/* - jatka-nappi vilkkuminen: väri, tausta ja box-shadow */
.mini-shopping-cart.blink-on .minicart-kassalle
{
	background-color: transparent !important;
	border-color: white !important;
	box-shadow: 0px 0px 0px 0px #3788d8 !important;
	color: #fff !important;
}

/* mobiiliresponsiivisuus */
@media (max-width: 410px) 
{
    .mini-shopping-cart a 
	{
		font-size: 12px;
	}
}

.asi-yht
{
	border: 0px solid var(--theme-color);
	background-color: var(--theme-color3);
	color: var(--text-color);
	border-radius: 8px;
}
.asi-yht a 
{
	word-break: break-word;
	color: var(--text-color);
}

/* slottikalenterin ostoskoriin klikatun slotin tausta- ja tekstin väri */
a.fc-event.fc-event-start.fc-event-end.fc-event-future.in-cart.asio-vt-E.fc-timegrid-event.fc-v-event
{
	background-color: #40823e !important;
	border-color: #40823e !important;
}


body .bottom-bar > a
{
    color: #000;
}
body .bottom-bar > a:hover, body .bottom-bar > a.active
{
    background-color: #93bb83;
    color: #030303;
    font-weight: bolder;
}	


/* UUSI custom mobiilinavi --> aukeaa ruudun vasemmasta laidasta */

@media (max-width: 768px) {
	.custom-navbar-collapse {
		position: fixed;
		top: 0;
		left: 0;
		width: 75%;
		
		height: 92svh !important;
		max-height: 92svh !important;
		height: 92vh !important;
		max-height: 92vh !important;
		
		background: #ffffff7d !important;
		color: rgba(0,0,0,0.8) !important;
		border-radius: 0px 12px 12px 0px;
		backdrop-filter: blur(33px);
		-webkit-backdrop-filter: blur(33px);
		background-blend-mode: overlay;
		padding: 20px 30px 100px 30px;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		transform: translateX(-100%);
		transition: all 0.3s ease-in-out;
		z-index: 1050;
	}
	
	.custom-navbar-collapse .submenu {
		background: none !important;
	}
	/*rgba(255,255,255,0.5)
	0 10px 15px rgb(0 0 0 / 10%)*/

	.custom-navbar-collapse.open {
		transform: translateX(0%);
		box-shadow: 0 10px 15px rgb(0 0 0 / 20%);
	}
	
	.custom-navbar-collapse ul>li>a,
	.custom-navbar-collapse ul>li.nav-search {
		margin: 0 1rem 1rem 0;
		padding: 10px !important;
		background: rgba(255,255,255,0.5) !important;
		border-radius: 8px;
		box-shadow: 0 10px 15px rgb(0 0 0 / 10%);
		border: 0px solid #f2f2f2 !important;
	}
	.custom-navbar-collapse li.active>a {
		background: var(--theme-color, rgba(255,255,255,0.5)) !important;
		border: 1px solid rgba(255, 255, 255, 0.1) !important;
		color: #f5f5f5 !important;
	}
	
	.custom-navbar-collapse li.active>a:hover {
		color: #fff !important;
		background-color: var(--theme-color, rgba(255,255,255,0.5)) !important;
	}
	.custom-navbar-collapse li>a:hover {
		background-color: rgba(255,255,255,0.2) !important;
	}
	
	/* mobiili submenu */
	.visible-xs.sub-opened>a {
		background-color: rgba(30, 30, 30, 0.85) !important;
		color: #f5f5f5 !important;
	}
	.visible-xs.sub-opened .submenu li {
		padding-left: 20px !important;
	}
	
	/* navigaation sulkeminen klikkaamalla ruudun tyhjää tilaa */
	.navbar-overlay {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 1040;
		display: none;
	}

	.navbar-overlay.active {
		display: block;
	}
}

.custom-navbar-collapse.no-transition {
	transition: none !important;
}

.navigation-icon {
	margin-right: 3px;
}

.menu-icon {
	width: 30px;
	height: 24px;
	position: relative;
	cursor: pointer;
	transition: transform 0.3s ease;
	display: inline-block;
	margin: 4px 2px 1px 2px;
}

.menu-icon span {
	display: block;
	position: absolute;
	height: 4px;
	width: 100%;
	background: #333;
	border-radius: 2px;
	opacity: 1;
	left: 0;
	transition: all 0.3s ease;
}

.menu-icon span:nth-child(1) {
	top: 0px;
}

.menu-icon span:nth-child(2) {
	top: 10px;
}

.menu-icon span:nth-child(3) {
	top: 20px;
}

.menu-icon.open span:nth-child(1) {
	top: 10px;
	transform: rotate(45deg);
}

.menu-icon.open span:nth-child(2) {
	transition: 0s;
	opacity: 0;
}

.menu-icon.open span:nth-child(3) {
	top: 10px;
	transform: rotate(-45deg);
}

.submenu .submenu-level-2
{
    padding-left: 23px;
}
/* custom mobiilinavi päättyy */

.breadcrumb-container.show {
    padding: 23px;
}

.shopping-cart-container {
    position: absolute;
    top: 142px;
    right: 10px;
    width: 100%;
}

@media (max-width: 767px) {
    .navbar-header .navbar-brand img {
        margin-left: 8px !important;
        max-width: 130px !important;
        margin-right: 0px !important;
        margin-top: 1px !important;
    }
}
@media (max-width: 970px) {
    .shopping-cart-container {
        position: absolute;
        top: 95px;
        right: -17px;
        width: 100%;
    }
    .mini-shopping-cart {
        padding-right: 41px;
    }
}


@media (max-width: 350px) 
{
    .mini-shopping-cart a 
	{
		font-size: 9px;
	}
    .minicart-kassalle {
        margin-left: 6px;
    }
}