/*
html5doctor.com Reset Stylesheet v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
body {
    line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
    display:block;
}
nav ul {
    list-style:none;
}
blockquote, q {
    quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}
/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000;
    font-style:italic;
    font-weight:bold;
}
del {
    text-decoration: line-through;
}
abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}
table {
    border-collapse:collapse;
    border-spacing:0;
}
/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
input, select {
    vertical-align:middle;
}

/******************/
/*
/* FINE RESET CSS */
/*
/******************/

body {
    font-family: 'Arimo', sans-serif;
    font-size: 14px;
    line-height: 20px;
    color: #333;
    background-color: #efefef;
}

.width-100 {
    width: 100% !important;
}

a {
	color: #333;
	transition: all 0.20s ease;
	text-decoration: none;
}

ol,ul {
	margin-left: 20px;
}


/* SELECT STYLE */

.select-style {
    display: inline-block;
}

.select-hidden {
  display: none;
  visibility: hidden;
  padding-right: 10px;
}

.select {
    cursor: pointer;
    display: inline-block;
    position: relative;
    font-size: 16px;
    color: #000;
    width: 110px;
    height: 38px;
}

.select-styled {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #FFF;
    padding: 9px 10px;
    -moz-transition: all 0.2s ease-in;
    -o-transition: all 0.2s ease-in;
    -webkit-transition: all 0.2s ease-in;
    transition: all 0.2s ease-in;
    border-bottom: 1px solid #AAA;
    vertical-align: top;
}
.select-styled:after {
      content: "";
    width: 0;
    height: 0;
    border: 5px solid transparent;
    border-color: #000 transparent transparent transparent;
    position: absolute;
    top: 15px;
    right: 10px;
}
.select-styled:hover {
  background-color: #FFF;
}
.select-styled:active, .select-styled.active {
  background-color: #FFF;
}
.select-styled:active:after, .select-styled.active:after {
  top: 9px;
  border-color: transparent transparent #000 transparent;
}

.select-options {
      display: none;
    position: absolute;
    top: 100%;
    right: 0;
    left: 0;
    z-index: 999;
    margin: 0;
    padding: 0;
    list-style: none;
    background-color: #1d191c;
    color: #FFF;
}
.select-options li {
  margin: 0;
  padding: 12px 0;
  text-indent: 15px;
  border-top: 1px solid #3e373c;
  -moz-transition: all 0.15s ease-in;
  -o-transition: all 0.15s ease-in;
  -webkit-transition: all 0.15s ease-in;
  transition: all 0.15s ease-in;
}
.select-options li:hover {
  color: #FFF;
  background: #d31d00;
}
.select-options li[rel="hide"] {
  display: none;
}

.select-style select:focus {
    outline: none;
}

/* END SELECT STYLE */

select {
    height: 38px;
    border-radius: 0px;
    border: 0px;
    background-color: #FFF;
    border-bottom: 1px solid #AAA;
    font-size: 14px;
    padding: 0px 10px;
    width: 110px;
    display: inline-block;
    vertical-align: top;
}


#header {
    width: 100%;
    background-color: #1d191c;
    padding: 25px 30px 20px;
    height: 70px;
    box-sizing: border-box;
    position: relative;
}

#header:before {
        content: "";
    background: url(/images/ribbon-schweiz.png) 0 0 no-repeat;
    width: 50px;
    height: 100px;
    display: block;
    position: absolute;
    top: -3px;
    left: 30px;
    background-size: contain;
}

#header .header-top {
	padding: 15px;
	border-bottom: 1px solid #EEE;
	transition: all 0.3s linear;
	visibility: visible;
	opacity: 1;
}

#header .header-top:after {
	content: "";
	display: block;
	clear: both;
}

#header .header-top.hide {
	display: none;
	transition: visibility 0s, opacity 0.5s linear;
}

#header .links-top {
	float: right;
}

#header .links-top li {
	display: inline-block;
	margin: 0px 0px 0px 20px;
}

#header .links-top a {
	text-decoration: none;
	color: #999;
	font-weight: 400;
	font-size: 13px;
	text-transform: uppercase;
}

#header .links-top a:hover {
	color: #333;
}

.logo {
    display: inline-block;
    /* margin-right: 50px; */
    height: 100%;
    color: #FFF;
    font-family: 'Poppins', sans-serif;
    font-size: 32px;
    font-weight: 400;
    text-transform: uppercase;
    text-decoration: none;
    width: 390px;
    /* margin: 0 auto; */
    /* text-align: center; */
    /* position: absolute; */
    left: 0px;
    right: 0px;
    margin-left: 60px;

}


.remove-blur {
    filter: blur(0px) !important;
    -webkit-filter: blur(0px) !important;
    -moz-filter: blur(0px) !important;
}


.infoline {
    position: absolute;
    z-index: 1000;
    color: #FFF;
    top: 10px;
}

.infoline label {
    font-size: 11px;
    text-transform: uppercase;
    margin-left: 57px;
}
.infoline .number {
    color: #FFF;
    text-decoration: none;
    font-size: 28px;
    font-weight: 600;
    display: block;
    margin-left: 57px;
}
.infoline .number:before {
    content: "";
    display: block;
    color: #FFF;
    position: absolute;
    width: 70px;
    text-indent: 0;
    height: 70px;
    background: url(/images/infoline.png);
    background-size: 100%;
    top: -7px;
    left: -10px;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Poppins', sans-serif;
}

#navigation {
    transition: all 0.3s linear;
    vertical-align: top;
    display: inline-block;
    margin-top: 0px;
    float: right;
}

#navigation li {
	display: inline-block;
	margin: 0px 20px;
}

#navigation li a {
	text-decoration: none;
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 200;
    color: #CCC;
}

#navigation li a:hover {
	text-decoration: underline;
}





#container {
    background-color: #FFF;
    max-width: 1440px;
    margin: 30px auto;
}


#breadcrumbs {
	background-color: #f9f9f9;
    border-bottom: 1px solid #DDD;
	margin-top: 0px;
	padding: 7px 0px;
	font-size: 12px;
	color: #666;
}

#breadcrumbs a {
	color: #666;
	text-decoration: none;
}

#breadcrumbs a:hover {
	text-decoration: underline;
}

#breadcrumbs ol {
    /* max-width: 960px; */
    margin-left: 30px;
}

#breadcrumbs li {
	display: inline;
    margin: 0px 5px;
}

#breadcrumbs li:not(:last-child):after {
	display: inline;
	content: "›";
	margin-left: 5px;
}


.testata {
    display: none;
}


.intro {
    background: #FFF url(/images/bg-intro.jpg) 0px -450px no-repeat;
    padding: 0px;
    height: 500px;
    background-size: 100%;
    position: relative;
    border-bottom: 1px solid #EEE;
}

.intro .inner {
    text-align: center;
    position: absolute;
    bottom: 0px;
    left: 0;
    right: 0;
    color: #000;
    padding: 50px 0px 20px;

}

.intro h1 {
        font-size: 32px;
        line-height: 34px;
        margin-bottom: 5px;
        font-weight: 600;
}

.intro h2 {
    font-family: 'Arimo', sans-serif;
    font-size: 17px;
    line-height: 24px;
    margin-bottom: 15px;
    font-weight: 300;
    color: #999;
}

.intro p {
    color: #777;
    font-size: 13px;
    line-height: 19px;
}



.main {
    padding: 20px 50px;
    background-color: #f9f9f9;
}

section.info {
    padding: 50px 50px;
    color: #666;
    font-size: 13px;
    line-height: 18px;
    border-top: 1px solid #e6e6e6;
}

section.info h3 {
    font-size: 24px;
    font-weight: 300;
    color: #000;
    margin-bottom: 15px;
}

#left-sidebar {
        width: 300px;
        display: inline-block;
        vertical-align: top;
        box-sizing: border-box;
        /* padding: 0px 0px 0px 30px; */
        font-size: 12px;
        /* background-color: #FFF; */
        margin-right: 30px;
}

.kanton {
    background-color: #222;
    border-radius: 5px;
    box-sizing: border-box;
    padding: 15px 20px;
    margin-top: 0px;
}

.kanton h3 {
        font-size: 20px;
    line-height: 32px;
    margin-bottom: 10px;
    color: #FFF;
}


.kanton ul {
    padding: 0px;
    margin: 0px;
}

.kanton ul li {
    list-style-type: none;
    width: calc(50% - 4px);
    display: inline-block;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding: 2px 0px 9px;
}

.kanton ul li img {
    float: left;
    margin-right: 5px;
}

.kanton a {
    color: #DDD;
    text-decoration: none;
    display: table-cell;
    vertical-align: middle;
    height: 20px;
    float: left;
}

.kanton a:hover {
    text-decoration: underline;
}

section.menu-category {
    width: 100%;
    padding: 15px 20px 10px;
    background-color: #333;
    margin-top: 20px;
    box-sizing: border-box;
    border-radius: 5px;
    color: #FFF;
}

section.menu-category h3 {
    font-size: 24px;
    line-height: 32px;
    margin-bottom: 10px;
}
section.menu-category ul {
    list-style-type: none;
    padding: 0px;
    margin: 0px;
}
section.menu-category ul li {
    border-top: 1px solid rgba(255,255,255,0.2);
    padding: 5px 0px;
    font-size: 16px;
}
section.menu-category ul li a {
    text-decoration: none;
}

section.link-partner {
    margin-top: 20px;
}

section.link-partner h3 {
    background-color: #444;
    color: #FFF;
    font-size: 20px;
    padding: 10px 15px;
    border-radius: 5px 5px 0 0;
}

section.link-partner ul {
    margin: 0px;
    padding: 0px;
}

section.link-partner li {
    list-style-type: none;
    padding: 5px 15px;
}
section.link-partner li:nth-child(odd) {
    background-color: #efefef;
}

section.link-partner h4 {
    font-size: 18px;
}

section.link-partner p {
    line-height: 19px;
    font-size: 13px;
}

/* TAG CLOUD */
.tag-cloud {
    margin: 30px 0px;
}

.tag-cloud h3 {
    font-size: 20px;
    line-height: 32px;
    margin-bottom: 10px;
    color: #000;
}

.tag-cloud ul {
    padding: 0px;
    margin: 0px;
}

.tag-cloud li {
        list-style-type: none;
    display: inline-block;
    margin: 3px 3px;
    background-color: #DDD;
    border-radius: 3px;
    padding: 2px 10px 3px;
    color: #999;
    font-size: 13px;
}

section.listing {
    width: calc(100% - 341px);
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
}

section.listing h2 {
        font-size: 20px;
        padding: 0;
        margin-bottom: 20px;
        line-height: 28px;
}

.listing-seite section.listing h1 {
    font-size: 24px;
    padding: 20px 10px 10px;
    margin: 10px;
}

.fucsia {
    color: #d31d00;
}


.item {
    width: 20%;
    height: 300px;
    /* border-radius: 5px; */
    display: inline-block;
    box-sizing: border-box;
    /* margin-right: -4px; */
    /* margin: 10px; */
    margin-right: -4px;
}

.item-inner {
        height: 100%;
    margin: 10px;
    overflow: hidden;
    position: relative;
    border-radius: 5px;
    border: 1px solid #E0e0e0;
    -webkit-box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.06);
    -moz-box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.06);
    box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.06);
}

.item-inner .image {
    background-size: cover;
    width: 100%;
    height: 250px;
    position: absolute;
    top: 0px;
    left: 0px;
    transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    border-radius: 5px 5px 0px 0px;
}

.item-inner .image:hover {
  transform: scale(1.5);
  -moz-transform: scale(1.5);
  -webkit-transform: scale(1.5);
  -o-transform: scale(1.5);
  -ms-transform: scale(1.5); /* IE 9 */
  -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=1.5, M12=0, M21=0, M22=1.5, SizingMethod='auto expand')"; /* IE8 */
   filter: progid:DXImageTransform.Microsoft.Matrix(M11=1.5, M12=0, M21=0, M22=1.5, SizingMethod='auto expand'); /* IE6 and 7 */
}

.item .info {
    position: absolute;
    bottom: 0px;
    color: #333;
    background-color: rgba(255,255,255,1);
    width: 100%;
    padding: 10px 15px;
    line-height: 18px;
    font-size: 14px;
    box-sizing: border-box;
}

.item .info .qt-fotos {
    position: absolute;
    top: -24px;
    background: rgba(255,255,255,0.9);
    padding: 3px 8px;
    right: 0;
    border-radius: 5px 0px 0px;
}

.item .info h4 {
    font-size: 13px;
    margin-bottom: 0px;
}

.item .info p {
    color: #999;
    font-size: 12px;
}

.item a:hover .info {
    background-color: #d31d00;
    color: #FFF;
}
.item a:hover .info p {
    color: #FFF;
}

.item a:hover .item-inner {
    -webkit-box-shadow: 5px 10px 30px 0px rgba(0,0,0,0.25);
    -moz-box-shadow: 5px 10px 30px 0px rgba(0,0,0,0.25);
    box-shadow: 5px 15px 35px 0px rgba(0,0,0,0.35);
    border: 1px solid #AAA;
}

.tag-online {
    position: absolute;
    z-index: 50;
    color: #FFF;
    background-color: #1dab36;
    padding: 1px 5px 0px;
    font-size: 9px;
    bottom: 70px;
    left: 15px;
    border-radius: 3px;
    border-bottom: 1px solid rgba(0,0,0,0.3);
    line-height: 16px;
}

section#page-description {
    border-top: 1px solid #EEE;
    padding: 50px 60px;
}


/* profil seite */
#container.profil-seite {
    max-width: 1440px;
    margin: 30px auto;
}

/* listing seite */


#container.listing-seite {
    max-width: 1440px;
    margin: 30px auto;
}

section.listing-header {
    padding: 30px 35px 35px;
    border-bottom: 1px solid #EEE;
}

.listing-header h1 {
    font-size: 28px;
    line-height: 36px;
}


#container.listing-seite .main {
    /* padding: 0px !important; */
}

#container.listing-seite section.listing h1 {
    border-top: 0px;
    padding-top: 0px;
    font-size: 32px;
    padding: 20px 0px 10px;
    margin: 0px 10px 20px;
    line-height: 36px;
}

#container.listing-seite section.listing .page-desc h2 {
    font-size: 24px;
    padding: 20px 0px 10px;
    border-top: 1px solid #DDD;
    margin: 10px 20px 10px 10px;
}

#container.listing-seite section.listing .page-desc p {
    padding: 0px 10px 30px 10px;
} 
    

#container.profil-seite .main {
    padding: 20px 20px 30px;
    max-width: 960px;
    margin: auto;
    background-color: #FFF;
}

.profil-seite .sidebar-foto {
    width: 45%;
    display: inline-block;
    vertical-align: top;
}

.profil-seite .sidebar-foto img {
    width: 100%;
}



.gallery .item {
    width: 100px;
    height: 100px;
    background-color: #efefef;
    margin-right: 7px;
    overflow: hidden;
}

.gallery .item .foto {
    height: 100%;
    background-size: 100%;
    display: block;
    /* width: 90px; */
    filter: blur(3px);
    -webkit-filter: blur(3px);
    -moz-filter: blur(3px);
    cursor: pointer;
    
}

.profil-seite .profil-detail {
    width: 55%;
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
    padding-left: 50px;
    margin-left: -4px;
}

.profil-seite .profil-detail h1 {
    font-size: 40px;
    line-height: 48px;
    margin-bottom: 10px;
}

.title-top {
    display: none;
}

.profil-seite dl {
        border-top: 1px solid #DDD;
    border-bottom: 1px solid #DDD;
    margin: 20px 0px 30px;
    padding: 10px 0px;
}

.profil-seite dl dd,
.profil-seite dl dt {
    display: inline-block;
}

.profil-seite dl dd {
    margin-right: 7px;
    color: #999;
    text-transform: uppercase;
    font-size: 10px;
}

.profil-seite dl dt {
    margin-right: 30px;
    font-weight: 900;
    font-size: 14px;
}


    

.profil-seite .tag-online {
    position: relative;
    display: inline-block;
    /* bottom: 70px; */
    left: 0px;
    z-index: 100000;
    bottom: 0px;
    margin-bottom: 10px;
}

.sms-block {
    text-align: center;
}

.sms-block .title {
    font-size: 24px;
    line-height: 34px;
    margin-bottom: 5px;
}

.sms-block .bt,
#get-number .bt,
.bt-call a {
    font-size: 14px;
    font-weight: 400;
    border: 0px;
    padding: 9px 40px 10px;
    border-radius: 0px;
    background-color: #d41e00;
    cursor: pointer;
    display: inline-block;
    margin-left: 5px;
    margin-top: 0px;
    /* border: 2px solid #FFF; */
    color: #FFF;
    vertical-align: top;
    text-decoration: none;
    border-radius: 30px;
}

section.info-tel {
    background-color: #d31d00;
    padding: 20px;
    border-radius: 5px;
    color: #FFF;
    font-size: 24px;
    line-height: 32px;
}

.info-sms {
    font-size: 16px;
    margin: 0 auto;
    /* text-align: center; */
    background-color: #1d191c;
    padding: 10px 10px;
    border-radius: 5px;
    line-height: 28px;
    box-sizing: border-box;
    vertical-align: top;
    text-align: left;
    color: #999;
}

.info-sms h2 {
    font-size: 22px;
    color: #FFF;
    margin-bottom: 10px;
    text-align: center;
    border-bottom: 1px solid rgba(255,255,255,0.2);
    padding: 2px 0px 15px;
    font-weight: 300;
}

.send-sms-info {
    width: 200px;
    display: inline-block;
    background-color: #d31d00;
    padding: 20px 20px;
    color: #FFF;
    border-radius: 5px;
    vertical-align: top;
    text-align: center;
    font-size: 14px;
    line-height: 24px;
    box-sizing: border-box;
}

.send-sms-info strong {
    font-size: 16px;
}

strong.white {
    color: #FFF;
}

.info-tel-contact {
    text-align: center;
    margin-bottom: 30px;
    line-height: 24px;
}

.info-tel-contact-inner {
        margin: 25px 0px 20px;
    font-size: 30px;
    line-height: 40px;
}

span.chiffre {
    font-size: 24px;
}

/* form per prendere il nome e numero di telefono prima di inviare l'SMS */
#get-number {
    position: fixed;
    z-index: 10000;
    background-color: rgba(0,0,0,0.7);
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    margin: 0;
    padding: 20px;
    box-sizing: border-box;
    display: none;
}

#get-number .inner {
    background-color: #FFF;
    margin: 20px;
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
    border-radius: 5px;
    margin: 50px auto;
    top: 0px;
    bottom: 0;
    position: relative;
}

#get-number h3 {
    font-size: 24px;
    line-height: 26px;
    margin-bottom: 25px;
}

#get-number label {
    width: 100%;
    display: block;
    font-weight: 600;
    margin-bottom: 5px;
    font-size: 20px;
}

#get-number input[type="text"] {
    border: 1px solid #DDD;
    padding: 10px 5px;
    font-size: 18px;
    border-radius: 3px;
    border-bottom: 1px solid #CCC;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 20px;
}

#get-number select.mobile-prefix {
    font-size: 18px;
    border: 1px solid #DDD;
    padding: 7px 5px;
    width: 70px;
    display: inline-block;
}

#get-number input[type="text"].mobile-number {
    display: inline-block;
    width: calc(100% - 74px);
    margin-bottom: 0px;
}

#get-number .bt {
    width: 100%;
    border: 0px;
    border-bottom: 2px solid rgba(0,0,0,0.2);
    font-weight: 600;
    padding: 15px;
    margin-top: 25px;
}


#get-number a.bt-close {
    text-align: right;
    margin-top: 20px;
    display: block;
    color: #999;
    font-size: 12px;
}




.note {
    display: inline-block;
    width: calc(100% - 200px);
    vertical-align: top;
    font-size: 15px;
    line-height: 22px;
    margin-left: -5px;
    box-sizing: border-box;
    padding-left: 15px;
    font-size: 12px;
    line-height: 18px;
}

.note strong {
    color: #FFF;
}

.note hr {
    margin: 10px 0px 5px;
    opacity: 0.3;
}

.callback {
    background-color: #efefef;
    margin-top: 30px;
    padding: 15px 30px 15px;
    color: #333;
    border-radius: 5px;
    /* border: 1px solid #e0e0e0; */
}

.callback h2 {
        font-size: 22px;
    color: #000;
    margin-bottom: 10px;
    text-align: center;
    border-bottom: 1px solid rgba(0,0,0,0.1);
    padding: 1px 0px 15px;
    font-weight: 300;
}

.callback p {
    color: #666;
    font-weight: 300;
    font-size: 13px;
    line-height: 18px;
}

.callback p strong {
    color: #000;
}

form#frm-callback,
form#phone-frm-callback,
form#phone-frm-pincode,
form#frm-pincode {
    margin: 25px 0px 10px;
}

#phone-frm-callback h4 {
    font-size: 20px;
    margin-bottom: 10px;
    line-height: 26px;
}

#phone-frm-pincode label span {
    display: inline-block;
    padding-top: 10px;
    margin-right: 10px;
}

#frm-callback .row,
#frm-pincode .row {
    display: inline-block;
}

#frm-callback input[type="text"],
#phone-frm-pincode input[type="text"],
#phone-frm-callback input[type="text"],
#frm-pincode input[type="text"] {
        font-size: 18px;
    padding: 8px 10px;
    border: none;
    border-bottom: 1px solid #AAA;
    border-radius: 0px;
    display: inline-block;
    background-color: #FFF;
}

#phone-frm-callback input[type="text"],
#phone-frm-pincode input[type="text"] {
    background-color: #FAFAFA;
}

#frm-callback input[type="text"],
#phone-frm-callback input[type="text"], 
#phone-frm-pincode input[type="text"] {
    max-width: 140px;
    vertical-align: top;
}

#frm-pincode input[type="text"],
#phone-frm-pincode input[type="text"] {
    max-width: 110px;
    vertical-align: top;
}

#frm-pincode input[type="text"] {
    margin-left: 10px;
}

#frm-callback label {
    font-size: 22px;
    display: inline-block;
    padding-top: 4px;
    vertical-align: middle;
    margin-right: 10px;
}

#frm-callback button,
#phone-frm-callback button,
#frm-pincode button,
#frm-callback input[type="submit"],
#phone-frm-callback input[type="submit"],
#frm-pincode input[type="submit"],
#phone-frm-pincode button.bt {
    font-size: 12px;
    font-weight: 600;
    border: 0px;
    padding: 11px 37px 12px;
    border-radius: 0px;
    background-color: transparent;
    color: #333;
    /* border-bottom: 1px solid rgba(0,0,0,0.2); */
    cursor: pointer;
    display: inline-block;
    margin-left: 5px;
    margin-top: 0px;
    /* border: 2px solid #d31d00; */
    color: #d31d00;
    vertical-align: top;
    background-color: #d31d00;
    color: #FFF;
    border-radius: 20px;
}

#phone-frm-callback button,
#phone-frm-pincode button.bt {
    margin-top: 15px;
    margin-left: 0px;
}

#frm-pincode label span {
    display: inline-block;
    /* vertical-align: middle; */
    height: 40px;
    line-height: 36px;
    /* padding-top: 10px; */
    color: #333;
    margin-right: 5px;
    vertical-align: top;
}

input[name="pin"] {
    width: 129px;
    text-align: center;
}

#frm-pincode input[type="submit"] {
    margin-top: 0px;
}


#frm-callback .jcf-select {
    background-color: #FFF;    
}

#frm-callback .jcf-select .jcf-select-opener {
    background: #fff;
}

.google-map {
    margin-top: 40px;
}

.google-map h3 {
    font-size: 20px;
    margin-bottom: 15px;
    font-weight: 300;
}

#other-profiles {
    background-color: #f9f9f9;
    padding: 30px 0px;
    border-top: 1px solid #EEE;
    color: #000;
}

#other-profiles .tag-online {
    position: absolute;
    display: inline-block;
    bottom: 70px;
    left: 15px;
    z-index: 100000;
    margin-bottom: 0px;
}

#other-profiles h3 {
    font-size: 24px;
    color: #000;
    margin-bottom: 20px;
    font-weight: 400;
}

#other-profiles .inner {
    margin: 0 auto;
    padding: 0px 50px;
}

#other-profiles .item {
    width: 20%;
}

#map {
    width: 100%;
    height: 350px;
}

.generic-page {
    /* margin-top: 0px !important; */
}

.inner.width-auto {
    display: table;
}

.generic-page .inner  {
    max-width: 760px;
    box-sizing: border-box;
    margin: 30px auto;
}

.generic-page h1 {
    font-size: 40px;
    line-height: 54px;
}

.generic-page h3 {
        font-size: 24px;
    line-height: 32px;
    margin-bottom: 10px;
}

.frm {
    margin: 50px 0px;
}

.frm .row {
    margin-bottom: 15px;
}

.frm input[type="text"],
.frm textarea,
.frm select {
        font-size: 18px;
    padding: 8px 10px;
    border: none;
    border-bottom: 1px solid #CCC;
    border-radius: 0px;
    display: inline-block;
    background-color: #fafafa;
    vertical-align: top;
}

.frm input[type="text"] {
    width: 300px;
}

.frm select[name="kanton"] {
}

.frm .select-options {
    width: 400px;
    font-size: 14px;
}

.frm .select-options li {
    padding: 8px 0px;
    width: 50%;
    display: inline-block;
}

.frm .mobile-prefix {
    width: 70px !important;
}

.frm .mobile-number {
    width: calc(297px - 70px) !important;
}

.frm textarea {
    width: 360px;
}

.frm label {
    display: inline-block;
    width: 150px;
    font-size: 18px;
    line-height: 18px;
    vertical-align: top;
    padding-top: 7px;
}

.frm .row-agb label {
        padding-top: 0px;
}

.frm .row-agb span.text {
    display: inline-block;
    width: calc(100% - 200px);
    vertical-align: top;
    font-size: 12px;
    line-height: 18px;
    color: #999;
    margin-top: 0;
}

.frm button {
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    border: 0px;
    padding: 11px 50px 12px;
    border-radius: 0px;
    background-color: #d31d00;
    display: inline-block;
    margin-left: 0px;
    margin-top: 0px;
    /* border: 2px solid #d31d00; */
    color: #d31d00;
    vertical-align: top;
    transition: all 0.20s ease;
    border-radius: 20px;
    color: #FFF;
}

.frm button:hover {
    background-color: #d31d00;
    color: #FFF;
}

#phone-frm-callback label {
        display: inline-block;
    width: 30px;
    font-size: 12px;
    line-height: 18px;
    vertical-align: top;
    padding-top: 2px;
}

#phone-frm-callback .row-agb span.text {
    display: inline-block;
    width: calc(100% - 60px);
    vertical-align: top;
    font-size: 11px;
    line-height: 14px;
    color: #999;
    margin-top: 0;
    padding-top: 3px;
}

#phone-frm-callback .row-agb a {
    color: #d41e00;
    text-decoration: underline;
}

#footer {
    background-color: #1d191c;
    color: #999;
    padding: 30px;
}

#footer .inner {
    max-width: 1440px;
    margin: 0 auto;
}

#footer .inner .b-left {
    max-width: 960px;
    display: inline-block;
    margin-left: 30px;
}

#footer h2, #footer h3 {
    color: #FFF;
    font-size: 18px;
}

#footer h2 {
    font-size: 20px;
    margin-bottom: 10px;
}

#footer p {
    font-size: 12px;
    line-height: 18px;
}

.links-footer {
	margin-bottom: 20px;
}

.links-footer li {
	margin: 0px 10px;
	display: inline-block;
	font-weight: 400;
}

.links-footer li a {
	color: #FFF;
}
.links-footer li a:hover {
	color: rgba(255,255,255,0.5);
}

#footer .note {
	margin-top: 20px;
	color: #999;
	font-size: 14px;
	line-height: 18px;
}

#footer ul.partner-links {
    margin: 0px;
    padding: 0px;
    margin-top: 30px;
}

#footer ul.partner-links li {
    background-color: rgba(255,255,255,0.07);
    display: inline-block;
    padding: 20px;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 5px;
    max-width: 25%;
    vertical-align: top;
    font-size: 14px;
    line-height: 18px;
    margin-right: 10px;
}

#footer ul.partner-links h2  {
    margin-bottom: 5px;
}

#footer .partner-link {    
    margin-top: 20px;
    border-top: 1px solid rgba(255,255,255,0.1);
    padding-top: 10px;
}

#footer .partner-link a {
    font-size: 12px;
    color: #666;
}

.g-recaptcha {
    display: inline-block;
}

#ok {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background-color: #1d9232;
    color: #FFF;
    padding: 30px 30px;
    border-radius: 2px;
    z-index: 100;
}

#errors {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background-color: #FF0000;
    color: #FFF;
    padding: 30px 30px;
    border-radius: 2px;
    z-index: 100;
}

.bt-call {
    float: left;
    width: 50%;
    background-color: #222;
    padding: 10px 0px 10px 5px;
    box-sizing: border-box;
    display: none;
}

.bt-call a {
    padding: 9px 5px;
    font-size: 14px;
    box-sizing: border-box;
    background-color: #d31d00;
    color: #FFF;
}


.bt-call a span {
    font-size: 13px;
    display: block;
    color: rgba(255,255,255,0.6);
}



.bt-sms-mobile {
    background-color: #252525;
    padding: 10px 5px 10px 0px;
    float: left;
    width: 50%;
    box-sizing: border-box;
    display: none;
}

.bt-back {
    display: none;
}

.popup-show-foto {
    position: fixed;
    z-index: 10000000;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
    display: block;
    top: 0px;
    left: 0px;
    display: none;
}

.popup-show-foto-inner {
    background-color: #FFF;
    max-width: 350px;
    left: 0px;
    right: 0px;
    position: absolute;
    margin: auto;
    top: 150px;
    /* bottom: 0px; */
    display: block;
    padding: 40px 40px 30px;
    height: auto;
    box-sizing: border-box;
    border-radius: 5px;
}

.popup-show-foto h4 {
    font-size: 22px;
    line-height: 28px;
    margin-bottom: 5px;
}

.bt-close-popup {
    font-size: 24px;
    position: absolute;
    top: 3px;
    right: 5px;    
}

.bt-close-popup:hover {
    cursor: pointer;
}


.icon-resp-menu,
.icon-close-menu {
    display: none;
}


#newsletter {
    background-color: #444;
    color: #FFF;
    padding: 15px;
    text-align: center;
}

#newsletter label {
    font-size: 18px;
    font-weight: 300;
    vertical-align: top;
    line-height: 34px;
}

#newsletter input[type="email"] {
    border: 0px;
    padding: 6px 10px;
    min-width: 300px;
    margin: 0px 5px 0px 10px;
    background-color: #666;
    border-bottom: 1px solid #888;
        color: #FFF;
    font-size: 18px;
    box-sizing: border-box;
}

#newsletter button.bt {
    border: 0px;
    font-size: 14px;
    padding: 8px 30px 9px;
    vertical-align: top;
    background-color: #d31d00;
    color: #FFF;
    border-radius: 20px;
    cursor: pointer;
}


/* 1366 orizzontale */
@media screen and (max-width: 1366px) {
}

/* 1280 orizzontale */
@media screen and (max-width: 1280px) {
}


/* ipad orizzontale */
@media screen and (max-width: 1024px) {
    
    section.listing h2 {
        font-size: 20px;
        padding: 0;
        margin-bottom: 20px;
        line-height: 26px;
    }
    
    .intro {
        background: #FFF url(/images/bg-intro.jpg) 0px -220px no-repeat;
        padding: 0px;
        height: 500px;
        background-size: 100%;
        position: relative;
        border-bottom: 1px solid #EEE;
    }
    
    .title-top {
        display: none;
    }
    .title-bottom {
        display: block;
    }
    
    .item {
        width: 33.3333%;
        height: 270px;
    }
    
    .item-inner .image {
        height: 220px;
    }
}


/* ipad verticale */
@media screen and (max-width: 768px) {
    
    .icon-resp-menu {
        display: block;
        position: absolute;
        right: 10px;
        top: 9px;
        color: #FFF;
        font-size: 21px;
    }
    
    .icon-close-menu {
        display: block;
        position: absolute;
        top: 10px;
        right: 10px;
        font-size: 24px;
    }
    
    .title-top {
        display: block;
    }
    .title-bottom {
        display: none;
    }
    
    
    .bt-back {
        display: block;
        position: absolute;
        right: 10px;
        top: 6px;
        background-color: #d31d00;
        color: #FFF;
        text-decoration: none;
        padding: 4px 10px;
        font-size: 12px;
        border-radius: 3px;
    }

    #header {
        height: 40px;
        position: fixed;
        width: 100%;
        top: 0px;
        padding: 10px 15px 20px;
        z-index: 1000;
        box-sizing: border-box;
    }
    
    #header:before {
        width: 30px;
        height: 40px;
        left: 10px;
    }
    
    #breadcrumbs {
        margin-top: 50px;
        padding: 7px 0px;
        overflow: hidden;
        display: none;
    }
    
    #breadcrumbs ol {
        margin-left: 10px;
        white-space: nowrap;
    }
    
    .tag-online {
        position: absolute;
        z-index: 50;
        color: #FFF;
        background-color: #1dab36;
        padding: 3px 6px 1px;
        font-size: 9px;
        top: 3px;
        right: 3px;
        border-radius: 3px;
        border-bottom: 1px solid rgba(0,0,0,0.3);
        line-height: 15px;
        bottom: initial;
        left: initial;
    }
    
    section.info {
        padding: 10px 20px 30px;
    }

    .infoline {
        top: 45px;
        display: none;
    }

    .infoline label {
        font-size: 11px;
        text-transform: uppercase;
        margin-left: 50px;
        top: 0px;
        position: absolute;
    }

    .infoline .number {
        margin-left: 50px;
        margin-top: 15px;
        font-size: 20px;
    }

    .infoline .number:before {
        content: "";
        display: block;
        color: #FFF;
        position: absolute;
        width: 60px;
        text-indent: 0;
        height: 60px;
        background: url(/images/infoline.png);
        background-size: 100%;
        top: -10px;
        left: -10px;
    }

    .logo {
        font-size: 20px;
        width: auto;
        top: 15px;
        height: auto;
        margin-left: 30px;
    }

    .title1 {
        font-size: 26px;
        line-height: 32px;
        margin-bottom: 20px;
        right: 0px;
        margin-top: 10px;
    
    }

    .testata {
        display: block;
    }

    .testata img {
        width: 100%;
    }

    .intro {
            background: url(/images/bg-intro.jpg) 0px -100px no-repeat;
    background-size: 100%;
    height: 435px;
    }

    .intro .inner {
        width: 100%;
        padding-left: 0px;
        margin-top: 160px;
        padding: 15px 15px 0px;
        box-sizing: border-box;
        margin-left: 0px;
        margin-right: 0px;
    }
    
    .intro h1 {
            font-size: 20px;
        line-height: 26px;
        margin-bottom: 10px;
    }
    
    .intro h2 {
            font-size: 15px;
    line-height: 20px;
    margin-bottom: 20px;
    }
    
    .intro p {
        font-size: 14px;
        color: #666;
        line-height: 20px;
    }

    .gallery {
        margin-top: 10px !important;
    }
    
    @-webkit-keyframes rotating /* Safari and Chrome */ {
      from {
        -webkit-transform: rotate(25deg);
        -o-transform: rotate(25deg);
        transform: rotate(25deg);
      }
      to {
        -webkit-transform: rotate(335deg);
        -o-transform: rotate(335deg);
        transform: rotate(335deg);
      }
    }
    @keyframes rotating {
      from {
        -ms-transform: rotate(25deg);
        -moz-transform: rotate(25deg);
        -webkit-transform: rotate(25deg);
        -o-transform: rotate(25deg);
        transform: rotate(25deg);
      }
      to {
        -ms-transform: rotate(335deg);
        -moz-transform: rotate(335deg);
        -webkit-transform: rotate(335deg);
        -o-transform: rotate(335deg);
        transform: rotate(335deg);
      }
    }
    .rotating {
      -webkit-animation: rotating 1s linear infinite;
      -moz-animation: rotating 1s linear infinite;
      -ms-animation: rotating 1s linear infinite;
      -o-animation: rotating 1s linear infinite;
      animation: rotating 1s linear infinite;
    }

    #container {
        width: 100%;
        margin: 40px auto 0px;
        background-color: #FFF;
    }
    
    .main {
        padding: 20px 0px;
    }
    
    #container.listing-seite .main {
        padding: 40px 0px 20px !important;
    }
    
    #container.profil-seite  {
        margin: 30px auto 0px;
    }
    
    #navigation {
            background-color: #FFF;
            position: fixed;
            top: 0px;
            height: 100vh;
            padding-top: 40px;
            right: -300px;
    }
    
    #navigation ul {
        list-style: none;
        margin: 10px 0px;
        padding: 0px;
        width: 300px;
        border-bottom: 1px solid #DDD;
    }
    
    #navigation li {
        display: block;
        margin: 0px 0px;
        display: block;
        font-size: 22px;
        border-top: 1px solid #DDD;
        padding: 0px 20px;
    }
    
    #navigation li a {
        text-decoration: none;
        font-size: 16px;
        text-transform: initial;
        font-weight: 200;
        color: #333;
        line-height: 44px;
    }

    #left-sidebar {
        width: 100%;
        display: block;
        padding: 0px;
    }

    .kanton {
        background-color: #333;
        border-radius: 0px;
        box-sizing: border-box;
        padding: 0px 15px;
        margin-top: 0px;
        /* position: fixed; */
        /* top: 40px; */
        z-index: 1000;
        width: 100%;
        /* overflow-y: auto; */
        /* width: 50%; */
        top: 0px;
        position: absolute;
        top: 80px;
        }

    .kanton h3 {
        font-size: 16px;
        line-height: 30px;
        margin-bottom: 0px;
        color: #FFF;
        position: relative;
        cursor: pointer;
        position: fixed;
        top: 40px;
        background-color: #333;
        width: 50%;
        left: 0px;
        padding: 5px 15px;
        box-sizing: border-box;
    }

    .kanton h3.arrow-down:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f107";
        top: 6px;
    }

    .kanton h3.arrow-up:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f106";
        top: 6px;
    }

    .kanton ul {
        display: none;
        margin-top: 10px;
    }

    .kanton ul li {
        list-style-type: none;
        width: calc(50% - 4px);
        display: inline-block;
        border-bottom: 1px solid rgba(0,0,0,0.1);
        padding: 1px 0px 7px;
    }

    .kanton ul li a {
        color: #CCC;
    }



    
    
    section.tag-cloud {
        width: 100%;
        padding: 15px 10px 5px;
        background-color: #555;
        margin-top: 0px;
        box-sizing: border-box;
        border-radius: 0px;
        color: #FFF;
        border-top: rgba(255,255,255,0.2);
        border-bottom: rgba(255,255,255,0.2);
        position: fixed;
        z-index: 100;
        top: 40px;
        width: 100%;
        right: 0px;
    }
    
    section.tag-cloud h3 {
        font-size: 14px;
        line-height: 32px;
        margin-bottom: 2px;
        position: relative;
        color: #FFF;
        position: fixed;
        width: 50%;
        right: 0px;
        background-color: #555;
        top: 40px;
        padding: 4px 15px;
        box-sizing: border-box;
    }
    
    .tag-cloud h3.arrow-down:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f107";
        top: 6px;
    }

    .tag-cloud h3.arrow-up:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f106";
        top: 6px;
    }
    
    section.tag-cloud ul {
        display: none;
        padding-bottom: 10px;
        top: 40px;
        position: absolute;
        background-color: #555;
        left: 0px;
        padding: 15px 10px;
    }
    
    section.tag-cloud ul li {
        padding: 3px 9px;
        
            list-style-type: none;
            display: inline-block;
            background-color: #3e3e3e;
            border-radius: 3px;
            padding: 2px 10px 3px;
            color: #999;
            font-size: 12px;
    }
    
    section.tag-cloud a {
        color: #FFF;    
    }

    section.listing {
            display: block;
        width: 100%;
        background-color: #f9f9f9;
        padding: 0px 5px;
    }
    
    section.listing .item-inner {
        height: 100%;
        margin: 0px 5px 5px;
        overflow: hidden;
        position: relative;
    }

    section.listing h2 {
            font-size: 16px;
    padding: 10px 50px 20px;
    border-top: 0px;
    margin: 0px;
    line-height: 22px;
    color: #000;
    text-align: center;
    }
    
    #container.listing-seite {
        margin: 60px auto 0px;
    }

    .item {
        width: 25%;
        height: 240px;
        display: inline-block;
        box-sizing: border-box;
        margin-right: -4px;
        margin-bottom: 15px;
    }
    
    .item .info {
            position: absolute;
        bottom: 0px;
        color: #333;
        background-color: rgba(255,255,255,1);
        width: 100%;
        padding: 5px 10px;
        line-height: 18px;
        font-size: 12px;
        box-sizing: border-box;
    }
    
    .item .info h4 {
        font-size: 15px;
        margin-bottom: 1px;
    }
    
    #container.profil-seite .main {
        padding: 20px 15px 30px;
    }

    .profil-seite .sidebar-foto {
        width: 100%;
        display: block;
        margin-bottom: 10px;
    }
    .profil-seite dl {
        border-top: 1px solid #DDD;
        border-bottom: 1px solid #DDD;
        margin: 20px 0px;
        padding: 10px 0px;
    }
    .profil-seite .profil-detail {
        width: 100%;
        display: block;
        vertical-align: top;
        box-sizing: border-box;
        padding-left: 0px;
        padding-top: 20px;
    }

    .profil-seite .profil-detail h1 {
        font-size: 32px;
        line-height: 36px;
        margin-bottom: 10px;
        margin-top: 20px;
    }

    .profil-seite dl dd {
        margin-right: 7px;
        color: #999;
        text-transform: uppercase;
        font-size: 12px;
        display: inline-block;
        width: 70px;
    }

    .profil-seite dl dt {
        margin-right: 35px;
        font-weight: 900;
        font-size: 14px;
        display: inline-block;
        width: calc(100% - 78px);
        margin: 0px;
    }

    .sms-block {
        text-align: center;
        /* position: fixed; */
        width: 100%;
        bottom: 0px;
        z-index: 1000000;
        left: 0px;
    }

    .sms-block .info-sms {
        border-radius: 0px;
    }


    .callback {
        margin-top: 30px;
        padding: 15px 20px 15px;
        color: #FFF;
        border-radius: 5px;
    }
    
    .callback p {
        font-size: 13px;
        line-height: 19px;
    }
    
    #frm-callback .row,
    #frm-pincode .row {
        display: block;
    }

    #frm-callback label {
        display: block;
        width: 100%;
        margin-bottom: 10px;
    }
    
    

    #frm-callback select.mobile-prefix {
        padding: 5px 5px !important;
    }

    #frm-pincode input[type="text"] {
        max-width: 100%;
        margin-top: 10px;
    }

    #frm-pincode button {
        margin: 10px auto;
        text-align: center;
        display: inherit;
        width: 100%;
    }

    #frm-pincode input[type="text"] {
        margin-left: 0px;
    }

    #frm-callback input[type="text"] {
            display: inline-block;
    width: calc(100% - 130px);
    max-width: initial;
    }

    #frm-callback select {
        font-size: 20px;
        padding: 7px 5px;
        border: 1px solid #151515;
        border-radius: 3px;
        display: inline-block;
        width: 115px;
    }

    #frm-callback button {
            font-size: 12px;
            font-weight: 600;
            padding: 10px 4px 11px;
            background-color: #252525;
            cursor: pointer;
            display: block;
            margin-left: 0px;
            margin-top: 10px;
            border: 0px;
            color: #FFF;
            vertical-align: top;
            width: 98%;
            border-radius: 30px;
    }

    #container.listing-seite section.listing h1 {
        border-top: 0px;
        padding-top: 0px;
        font-size: 20px;
        padding: 0px 0px 5px;
        margin: 0px 5px 15px;
        line-height: 26px;
    }
    
    #container.listing-seite section.listing .page-desc h2 {
        font-size: 20px;
        padding: 10px 0px 5px;
        border-top: 1px solid rgba(255,255,255,0.2);
        margin: 5px 20px 0px 10px;
        line-height: 24px;
    }
    
    #container.listing-seite section.listing .page-desc p {
        padding: 0px 10px 10px 10px;
        font-size: 14px;
        line-height: 20px;
        color: #999;
        margin-bottom: 20px;
    }

    #other-profiles {
        background-color: #f9f9f9;
        padding: 15px 5px;
    }
    
    #other-profiles .inner {
        margin: 0 auto;
        padding: 0px 0px;
    }

    #other-profiles .item {
        width: 25%;
    }
    
    #other-profiles .item .info h4 {
        font-size: 14px;
        margin-bottom: 5px;
    }
    
    #other-profiles .item .info {
        padding: 5px 10px;
        line-height: 16px;
        font-size: 12px;
    }
    
    #other-profiles .item-inner {
        height: 100%;
        margin: 5px;
        overflow: hidden;
        position: relative;
    }
    
    #other-profiles h3 {
        font-size: 20px;
        line-height: 26px;
        padding: 0px 5px;
        margin-bottom: 10px;
    }
    
    #other-profiles .tag-online {
        bottom: initial;
        left: initial;
    }
    
    .generic-page .inner {
        padding: 30px 20px;
    }



    #footer {
        width: 100%;
        box-sizing: border-box;
        padding: 30px 25px 10px;
    }
    
    #footer h2 {
        font-size: 16px;
        margin-bottom: 5px;
    }
    
    #footer .inner .b-left {
        margin-left: 0px;
    }
    
    #footer p {
        font-size: 12px;
        line-height: 18px;
        margin-bottom: 20px;
    }
    
    #footer ul.partner-links li {
        max-width: 100%;
        margin-bottom: 15px;
    }
    
    .google-map h3 {
        font-size: 16px;
        margin-bottom: 10px;
        font-weight: 300;
    }
    
    section.info h3 {
        font-size: 18px;
        font-weight: 600;
        color: #000;
        margin-bottom: 10px;
        line-height: 24px;
        margin-top: 20px;
    }

}



/* iphone 6 plus */
@media screen and (max-width: 480px) {
    
    #newsletter input[type="email"] {
        margin: 5px 0px 15px !important;
    }
    
    .bt-call,
    .bt-sms-mobile {
        display: block;
    }
    
    
    
    .bt-back {
        display: block;
        position: absolute;
        right: 50px;
        top: 6px;
        background-color: #d31d00;
        color: #FFF;
        text-decoration: none;
        padding: 4px 10px;
        font-size: 12px;
        border-radius: 3px;
    }

    #header {
        height: 40px;
        position: fixed;
        width: 100%;
        top: 0px;
        padding: 10px 15px 20px;
        z-index: 100000;
        box-sizing: border-box;
    }
    
    #header:before {
        width: 30px;
        height: 40px;
        left: 10px;
    }
    
    #breadcrumbs {
        margin-top: 50px;
        padding: 7px 0px;
        overflow: hidden;
        display: none;
    }
    
    #breadcrumbs ol {
        margin-left: 10px;
        white-space: nowrap;
    }
    
    .tag-online {
        position: absolute;
        z-index: 50;
        color: #FFF;
        background-color: #1dab36;
        padding: 3px 6px 1px;
        font-size: 9px;
        top: 3px;
        right: 3px;
        border-radius: 3px;
        border-bottom: 1px solid rgba(0,0,0,0.3);
        line-height: 15px;
        bottom: initial;
        left: initial;
    }
    
    section.info {
        padding: 10px 20px 30px;
    }

    .infoline {
        top: 45px;
        display: none;
    }

    .infoline label {
        font-size: 11px;
        text-transform: uppercase;
        margin-left: 50px;
        top: 0px;
        position: absolute;
    }

    .infoline .number {
        margin-left: 50px;
        margin-top: 15px;
        font-size: 20px;
    }

    .infoline .number:before {
        content: "";
        display: block;
        color: #FFF;
        position: absolute;
        width: 60px;
        text-indent: 0;
        height: 60px;
        background: url(/images/infoline.png);
        background-size: 100%;
        top: -10px;
        left: -10px;
    }

    .logo {
        font-size: 20px;
        width: auto;
        top: 15px;
        height: auto;
        margin-left: 30px;
    }

    .title1 {
        font-size: 24px;
        line-height: 30px;
        margin-bottom: 10px;
        right: 0px;
        margin-top: 5px;
    
    }

    .testata {
        display: block;
    }

    .testata img {
        width: 100%;
    }

    .intro {
        background: url(/images/bg-intro.jpg) -60px -110px no-repeat;
        background-size: 160%;
        height: 450px;
    }

    .intro .inner {
        width: 100%;
        padding-left: 0px;
        margin-top: 160px;
        padding: 15px 15px 0px;
        box-sizing: border-box;
        margin-left: 0px;
        margin-right: 0px;
    }
    
    .intro h1 {
            font-size: 20px;
        line-height: 26px;
        margin-bottom: 10px;
    }
    
    .intro h2 {
            font-size: 15px;
    line-height: 20px;
    margin-bottom: 20px;
    }
    
    .intro p {
        font-size: 14px;
        color: #666;
        line-height: 20px;
    }

    .gallery {
        margin-top: 10px !important;
    }
    
    .gallery .item {
        height: 120px;
    }
    
    @-webkit-keyframes rotating /* Safari and Chrome */ {
      from {
        -webkit-transform: rotate(25deg);
        -o-transform: rotate(25deg);
        transform: rotate(25deg);
      }
      to {
        -webkit-transform: rotate(335deg);
        -o-transform: rotate(335deg);
        transform: rotate(335deg);
      }
    }
    @keyframes rotating {
      from {
        -ms-transform: rotate(25deg);
        -moz-transform: rotate(25deg);
        -webkit-transform: rotate(25deg);
        -o-transform: rotate(25deg);
        transform: rotate(25deg);
      }
      to {
        -ms-transform: rotate(335deg);
        -moz-transform: rotate(335deg);
        -webkit-transform: rotate(335deg);
        -o-transform: rotate(335deg);
        transform: rotate(335deg);
      }
    }
    .rotating {
      -webkit-animation: rotating 1s linear infinite;
      -moz-animation: rotating 1s linear infinite;
      -ms-animation: rotating 1s linear infinite;
      -o-animation: rotating 1s linear infinite;
      animation: rotating 1s linear infinite;
    }

    #container {
        width: 100%;
        margin: 40px auto 0px;
        background-color: #FFF;
    }
    
    .main {
        padding: 20px 0px;
    }
    
    #container.listing-seite .main {
        padding: 40px 0px 20px !important;
    }
    
    #container.profil-seite  {
        margin: 30px auto 0px;
    }
    
    #navigation {
        /* display: none; */
    }

    #left-sidebar {
        width: 100%;
        display: block;
        padding: 0px;
    }

    .kanton {
        background-color: #333;
        border-radius: 0px;
        box-sizing: border-box;
        padding: 0px 15px;
        margin-top: 0px;
        /* position: fixed; */
        /* top: 40px; */
        z-index: 10000;
        width: 100%;
        /* overflow-y: auto; */
        /* width: 50%; */
        top: 0px;
        position: absolute;
        top: 80px;
        }

    .kanton h3 {
        font-size: 16px;
        line-height: 30px;
        margin-bottom: 0px;
        color: #FFF;
        position: relative;
        cursor: pointer;
        position: fixed;
        top: 40px;
        background-color: #333;
        width: 50%;
        left: 0px;
        padding: 5px 15px;
        box-sizing: border-box;
    }

    .kanton h3.arrow-down:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f107";
        top: 6px;
    }

    .kanton h3.arrow-up:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f106";
        top: 6px;
    }

    .kanton ul {
        display: none;
        margin-top: 10px;
    }

    .kanton ul li {
        list-style-type: none;
        width: calc(50% - 4px);
        display: inline-block;
        border-bottom: 1px solid rgba(0,0,0,0.1);
        padding: 1px 0px 7px;
    }

    .kanton ul li a {
        color: #CCC;
    }



    
    
    section.tag-cloud {
        width: 100%;
        padding: 15px 10px 5px;
        background-color: #555;
        margin-top: 0px;
        box-sizing: border-box;
        border-radius: 0px;
        color: #FFF;
        border-top: rgba(255,255,255,0.2);
        border-bottom: rgba(255,255,255,0.2);
        position: fixed;
        z-index: 1000;
        top: 40px;
        width: 100%;
        right: 0px;
    }
    
    section.tag-cloud h3 {
        font-size: 14px;
        line-height: 32px;
        margin-bottom: 2px;
        position: relative;
        color: #FFF;
        position: fixed;
        width: 50%;
        right: 0px;
        background-color: #555;
        top: 40px;
        padding: 4px 15px;
        box-sizing: border-box;
    }
    
    .tag-cloud h3.arrow-down:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f107";
        top: 6px;
    }

    .tag-cloud h3.arrow-up:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 28px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: 10px;
        content: "\f106";
        top: 6px;
    }
    
    section.tag-cloud ul {
        display: none;
        padding-bottom: 10px;
        top: 40px;
        position: absolute;
        background-color: #555;
        left: 0px;
        padding: 15px 10px;
    }
    
    section.tag-cloud ul li {
        padding: 3px 9px;
        
            list-style-type: none;
            display: inline-block;
            background-color: #3e3e3e;
            border-radius: 3px;
            padding: 2px 10px 3px;
            color: #999;
            font-size: 12px;
    }
    
    section.tag-cloud a {
        color: #FFF;    
    }

    section.listing {
            display: block;
        width: 100%;
        background-color: #f9f9f9;
        padding: 0px 5px;
    }
    
    section.listing .item-inner {
        height: 100%;
        margin: 0px 5px 5px;
        overflow: hidden;
        position: relative;
    }

    section.listing h2 {
            font-size: 18px;
        padding: 10px 10px 25px;
        border-top: 0px;
        margin: 0px;
        line-height: 26px;
        color: #000;
    }
    
    #container.listing-seite {
        margin: 60px auto 0px;
    }

    .item {
        width: 50%;
        height: 240px;
        display: inline-block;
        box-sizing: border-box;
        margin-right: -4px;
        margin-bottom: 15px;
    }
    
    .item .info {
            position: absolute;
        bottom: 0px;
        color: #333;
        background-color: rgba(255,255,255,1);
        width: 100%;
        padding: 5px 10px;
        line-height: 18px;
        font-size: 12px;
        box-sizing: border-box;
    }
    
    .item .info h4 {
        font-size: 15px;
        margin-bottom: 1px;
    }
    
    #container.profil-seite .main {
        padding: 20px 15px 30px;
    }

    .profil-seite .sidebar-foto {
        width: 100%;
        display: block;
        margin-bottom: 10px;
    }
    .profil-seite dl {
        border-top: 1px solid #DDD;
        border-bottom: 1px solid #DDD;
        margin: 20px 0px;
        padding: 10px 0px;
    }
    
    .profil-seite .profil-detail {
        width: 100%;
        display: block;
        vertical-align: top;
        box-sizing: border-box;
        padding-left: 0px;
        padding-top: 10px;
    }

    .profil-seite .profil-detail h1 {
        font-size: 32px;
        line-height: 36px;
        margin-bottom: 10px;
        margin-top: 20px;
    }

    .profil-seite dl dd {
        margin-right: 7px;
        color: #999;
        text-transform: uppercase;
        font-size: 12px;
        display: inline-block;
        width: 70px;
    }

    .profil-seite dl dt {
        margin-right: 35px;
        font-weight: 900;
        font-size: 14px;
        display: inline-block;
        width: calc(100% - 78px);
        margin: 0px;
    }

    .sms-block {
        text-align: center;
        position: fixed;
        width: 100%;
        bottom: 0px;
        z-index: 1000000;
        left: 0px;
    }

    .sms-block .info-sms {
        border-radius: 0px;
        display: none;
    }

    .info-sms h2 {
        font-size: 28px;
        color: #FFF;
        margin-bottom: 0px;
        text-align: center;
        border-bottom: 0px;
        padding: 7px 0px 6px 15px;
        max-width: 80%;
        text-align: left;
        position: relative;
    }

    .info-sms h2.arrow-right:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 70px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: -40px;
        content: "\f10b";
        top: 0px;
        /*
        -webkit-animation: rotating 1s linear infinite;
        -moz-animation: rotating 1s linear infinite;
        -ms-animation: rotating 1s linear infinite;
        -o-animation: rotating 1s linear infinite;
        animation: rotating 1s linear infinite;
        */
    }

    .info-sms h2.close-icon:after {
        display: inline-block;
        font: normal normal normal 18px/1 FontAwesome;
        font-size: 40px;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        position: absolute;
        right: -40px;
        content: "\f068";
        top: 13px;
    }



    .info-sms-inner {
        display: none;
        margin-top: 15px;
    }


    .send-sms-info {
        width: 100%;
        display: block;
        background-color: #d31d00;
        padding: 20px 20px;
        color: #FFF;
        border-radius: 5px;
        vertical-align: top;
        text-align: center;
        font-size: 18px;
        box-sizing: border-box;
    }

    .note {
        display: inline-block;
        width: 100%;
        vertical-align: top;
        font-size: 15px;
        line-height: 22px;
        margin-left: 0px;
        box-sizing: border-box;
        padding: 20px 20px 10px;
    }

    .callback {
        margin-top: 30px;
        padding: 15px 20px 15px;
        color: #FFF;
        border-radius: 5px;
    }
    
    .callback p {
        font-size: 13px;
        line-height: 19px;
    }
    
    #frm-callback .row,
    #frm-pincode .row {
        display: block;
    }

    #frm-callback label {
        display: block;
        width: 100%;
        margin-bottom: 10px;
    }
    
    

    #frm-callback select.mobile-prefix {
        padding: 5px 5px !important;
    }

    #frm-pincode input[type="text"] {
        max-width: 100%;
        margin-top: 10px;
    }

    #frm-pincode button {
        margin: 10px auto;
        text-align: center;
        display: inherit;
        width: 100%;
    }

    #frm-pincode input[type="text"] {
        margin-left: 0px;
    }

    #frm-callback input[type="text"] {
            display: inline-block;
    width: calc(100% - 130px);
    max-width: initial;
    }

    #frm-callback select {
        font-size: 20px;
        padding: 7px 5px;
        border: 1px solid #151515;
        border-radius: 3px;
        display: inline-block;
        width: 115px;
    }

    #frm-callback button {
            font-size: 12px;
            font-weight: 600;
            padding: 10px 4px 11px;
            background-color: #252525;
            cursor: pointer;
            display: block;
            margin-left: 0px;
            margin-top: 10px;
            border: 0px;
            color: #FFF;
            vertical-align: top;
            width: 98%;
            border-radius: 30px;
    }
    
    
    .profil-seite .sidebar-foto picture {
        max-height: 60vh;
        overflow: hidden;
        display: block;
        text-align: center;
        background-color: #eee;
    }
    
    .profil-seite .sidebar-foto img {
        width: auto;
        height: 60vh;
    }


    #container.listing-seite section.listing h1 {
        border-top: 0px;
        padding-top: 0px;
        font-size: 20px;
        padding: 0px 0px 5px;
        margin: 0px 5px 15px;
        line-height: 26px;
    }
    
    #container.listing-seite section.listing .page-desc h2 {
        font-size: 20px;
        padding: 10px 0px 5px;
        border-top: 1px solid rgba(255,255,255,0.2);
        margin: 5px 20px 0px 10px;
        line-height: 24px;
    }
    
    #container.listing-seite section.listing .page-desc p {
        padding: 0px 10px 10px 10px;
        font-size: 14px;
        line-height: 20px;
        color: #999;
        margin-bottom: 20px;
    }

    #other-profiles {
        background-color: #f9f9f9;
        padding: 15px 5px;
    }
    
    #other-profiles .inner {
        margin: 0 auto;
        padding: 0px 0px;
    }

    #other-profiles .item {
        width: 50%;
    }
    
    #other-profiles .item .info h4 {
        font-size: 14px;
        margin-bottom: 5px;
    }
    
    #other-profiles .item .info {
        padding: 5px 10px;
        line-height: 16px;
        font-size: 12px;
    }
    
    #other-profiles .item-inner {
        height: 100%;
        margin: 5px;
        overflow: hidden;
        position: relative;
    }
    
    #other-profiles h3 {
        font-size: 20px;
        line-height: 26px;
        padding: 0px 5px;
        margin-bottom: 10px;
    }
    
    #other-profiles .tag-online {
        bottom: initial;
        left: initial;
    }
    
    .generic-page .inner {
        padding: 30px 20px;
    }



    #footer {
        width: 100%;
        box-sizing: border-box;
        padding: 30px 25px 70px;
    }
    
    #footer h2 {
        font-size: 16px;
        margin-bottom: 5px;
    }
    
    #footer .inner .b-left {
        margin-left: 0px;
    }
    
    #footer p {
        font-size: 12px;
        line-height: 18px;
        margin-bottom: 20px;
    }
    
    #footer ul.partner-links li {
        max-width: 100%;
        margin-bottom: 15px;
    }
    
    .google-map h3 {
        font-size: 16px;
        margin-bottom: 10px;
        font-weight: 300;
    }
    
    section.info h3 {
        font-size: 18px;
        font-weight: 600;
        color: #000;
        margin-bottom: 10px;
        line-height: 24px;
        margin-top: 20px;
    }
    
    .sms-block .bt, #get-number .bt, .bt-call a {
            padding: 10px 10px;
            border-radius: 5px;
            margin: 0px;
            width: 95%;
            box-sizing: border-box;
    }
    
    .frm .row {
        margin-bottom: 25px;
    }
    
    .frm label {
        display: block;
        width: 150px;
        font-size: 14px;
        line-height: 18px;
        vertical-align: top;
        padding-top: 7px;
        margin-bottom: 5px;
        color: #999;
    }
    
    .frm textarea, .frm input[type="text"] {
        width: 100%;
        box-sizing: border-box;
    }
    
    .generic-page h1 {
        font-size: 28px;
        line-height: 38px;
        margin-bottom: 30px;
    }

}


/* iphone 8 */
@media screen and (max-width: 414px) {
    
    .intro {
        background: url(/images/bg-intro.jpg) -40px -50px no-repeat;
        background-size: 140%;
        height: 450px;
    }
    
}



@media screen and (max-width: 360px) {
    
    .intro {
        background: url(/images/bg-intro.jpg) -50px -20px no-repeat;
        background-size: 140%;
        height: 450px;
    }
    
    .sms-block .bt, #get-number .bt, .bt-call a {
            padding: 10px 0px;
            border-radius: 5px;
            margin: 0px;
            width: 95%;
    }
    
    .logo {
            font-size: 20px;
        width: auto;
        top: 15px;
        height: auto;
    }
    
    .kanton {
        padding: 0px 20px;
    }
    
    .kanton h3 {
        font-size: 14px;
    }
    
    .intro .inner {
        margin-top: 120px;
    }
    
    .intro h1 {
        font-size: 18px;
        line-height: 22px;
        margin-bottom: 10px;
    }
    
    .intro h2 {
        font-size: 14px;
        line-height: 18px;
        margin-bottom: 16px;
    }
    
    section.listing h2 {
        font-size: 18px;
    line-height: 24px;
    }
    
    .item {
        height: 200px;
    }
    
    .item .info {
        padding: 5px 7px;
    }
    
    .item .info h4 {
            font-size: 14px;
    margin-bottom: 3px; 
    }
    
    .item .info p {
        font-size: 11px;
        line-height: 12px;
    }
    
    .title1 {
        font-size: 24px;
        line-height: 28px;
        margin-bottom: 15px;
    }
    
    
    
    #footer {
        padding: 20px 15px 70px;
    }
}

@media screen and (max-width: 320px) {
    
    .logo {
        font-size: 14px;
    }
    
    
    #newsletter input[type="email"] {
        margin: 5px 0px 10px !important;
        min-width: 270px !important;
    }
    
    

    .intro {
        background: url(/images/bg-intro.jpg) -40px -60px no-repeat;
        background-size: 150%;
        height: 365px;
    }
    
    .intro h1 {
        font-size: 16px;
        line-height: 20px;
        margin-bottom: 10px;
    }
    
    .intro h2 {
        font-size: 12px;
        line-height: 16px;
        margin-bottom: 16px;
        color: #666;
    }
    
    section.listing h2 {
        font-size: 15px;
        line-height: 21px;
        padding: 0px 10px 15px;
    }
    
    .title1 {
        font-size: 18px;
        line-height: 26px;
        margin-bottom: 5px;
    }
    
    .bt-back {
        display: block;
        position: absolute;
        right: 40px;
        top: 8px;
        background-color: #d31d00;
        color: #FFF;
        text-decoration: none;
        padding: 2px 7px;
        font-size: 12px;
        border-radius: 3px;
    }
    
    #newsletter input[type="email"] {
        min-width: 245px !important;
    }

}