/* fonts, text */
html {
    font: 62.5%/1.5 Verdana, Arial, sans-serif; /* 10/16 */
}

input,
select,
textarea,
button {
    font-family: Verdana, Arial, sans-serif;
}

.h,
h3,
h4,
.more,
.schedule .timetable,
.footer,
.lang {
    font-family: Arial, sans-serif;
}

.page-leadtext .h,
.home .titleheader .h {
    font-size: 6em;
    line-height: 1;
}

.sidebanner-layout2 strong,
.titleheader .h {
    font-size: 3em;
    line-height: 1;
}

#search .custom-search-button,
.nav li a {
    font-size: 2.3em;
    line-height: 1;
}

.text h3,
.news-item .h,
.performance .h,
.schedule .h,
.news .h {
    font-size: 1.7em;
    line-height: 1.2;
}

.sidebanner .more,
.thumbnailtext .more,
.schedule .timetable,
.thumbnailtext-layout2 .more,
.titleheader a {
    font-size: 1.4em;
    line-height: 1.1;
}

.footer,
#search .gsc-resultsbox-visible {
    font-size: 1.2em;
}

.pagination,
.lightbox-content,
.text,
.nav li li,
.performance .info,
.page-leadtext p,
.schedule-sort,
.schedule a,
.lang {
    font-size: 1.1em;
}

.lightbox-content > *,
.lightbox-content .text,
.lightbox-content .info,
h4,
#search .gsc-control-cse,
#search .gsc-search-box,
.nav li li a {
    font-size: 1em;
}

.nav,
.titleheader a,
.footer,
.sidebanner .more,
.page-leadtext p,
.schedule-sort .active,
.schedule a,
.thumbnailtext .more,
.thumbnailtext-layout2 .more,
#search .custom-search-button,
.pagination .current,
.lang {
    font-weight: bold;
}

th {
    text-align: left;
}

.footer {
    text-align: right;
}

.nav a,
.news .h a,
.schedule-sort a,
.titleheader a,
.sidebanner a,
.footer a,
.schedule-sort .active,
.schedule a,
.thumbnailtext .more,
.thumbnailtext-layout2 .more,
.lang a {
    text-decoration: none;
}

.nav li li a:hover,
.news .h a:hover,
.performance a,
.schedule-sort a:hover,
.schedule-sort a,
.schedule a:hover,
.pagination a,
.lang a:hover {
    text-decoration: underline;
}

.nav,
.sidebanner-layout2 strong,
.main .page-leadtext .h,
.titleheader .h,
#search .custom-search-button,
.footer,
.partners .h,
.lang {
    text-transform: uppercase;
}

.nav li .l {
    text-transform: none;
}


/* colors, some backgrounds */
html {
    background: #000 url(background-saxophone.jpg) -600px 0 no-repeat;
}
.theme-guitar {
    background-image: url(background-guitar.jpg);
}
.theme-drums {
    background-image: url(background-drums.jpg);
}
.theme-piano {
    background-image: url(background-piano.jpg);
}
.theme-cello {
    background-image: url(background-cello.jpg);
}

.lightbox-content,
.performance,
.backgroundtext .text,
.backgroundtext .text a,
.page-leadtext,
.page-leadtext a,
#search .gsc-resultsbox-visible {
    color: #000;
}

/* grey */
.footer li {
    border-color: #797979;
}

/* white */
.text img,
.pagination .page,
#search .gsc-resultsbox-visible {
    border-color: #FFF;
}

.performance,
#search .gsc-resultsbox-visible {
    background-color: #FFF;
}

html,
a,
.news .h a:hover,
.schedule-sort a,
.container .more:hover,
.schedule .timetable,
.sidebanner-layout2 strong,
.pagination a:hover,
#search .custom-search-button:hover,
.footer a:hover,
.nav li .l a,
.nav li.active a,
.nav li a:hover {
    color: #FFF;
}

/* light oker */
.page-leadtext {
    background-color: #ACB242;
}

.text h3,
.lightbox-content a,
.text a,
.news .h,
.news .h a,
.news-item .h,
.schedule-sort,
.titleheader  a,
.performance a,
.sidebanner a,
.pagination a,
.footer a,
.thumbnailtext .more,
.schedule .timetable,
.nav li a {
    color: #ACB242;
}

/* dark oker */
.lang a {
    color: #5E6320;
}

/* light blue */
.news .dt,
.news-item .dt,
.nav li li a {
    border-color: #18B1E9;
}

.news .dt,
.news-item .dt,
.partners .h,
.performance-date {
    color: #18B1E9;
}

/* very light blue */
#search .custom-search-button {
    color: #A4EAFD;
}

body {
    background: url(willemstad.jpg) 0 100% repeat-x;
}

.footer {
    background: url(footer_deco.png) 0 20px no-repeat;
}


/* other non-layout */
#search .gsc-resultsbox-visible {
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    -o-box-shadow: 0 0 20px rgba(0,0,0,1);
    -moz-box-shadow: 0 0 20px rgba(0,0,0,1);
    -webkit-box-shadow: 0 0 20px rgba(0,0,0,1);
    box-shadow: 0 0 20px rgba(0,0,0,1);
}

/* base elements layout */
* {
    margin: 0;
    padding: 0;
}

h4 {
    margin-bottom: -10px;
}

ul,
ol {
    margin-left: 2em;
}

fieldset,
input,
select,
button,
textarea {
    border: none;
}

table {
    border-collapse: collapse;
}

th, td {
    padding: 0 1em 0.2em 0;
}

img {
    border: none;
    max-width: 100%;
    height: auto;
}

.hr {
    height: 2px;
    background: url(colored_line.gif);
}

.hr hr {
    display: none;
}

.text img {
    display: block;
    border-style: solid;
    border-width: 3px;
}

.text p {
    margin: 10px 0;
}

.fl {
    clear: left;
    float: left;
    margin: 0 60px 20px 0;
}

.fr {
    clear: right;
    float: right;
    margin: 0 0 20px 60px;
}
.flb {
    clear: left;
    float: left;
    margin: 0 60px 20px 0;
    border-style: solid;
    border-width: 4px;
}

.frb {
    clear: right;
    float: right;
    margin: 0 0 20px 60px;
    border-style: solid;
    border-width: 4px;
}



.text .image:first-child {
    margin-top: 38px;
}


/* common layout */
.news-item:after,
.titleheader:after,
.pagination:after,
.thumbnail:after,
.photoalbum:after,
.thumbnailtext:after,
.freetext:after,
.thumbnailtext-layout2:after,
.saleslocation:after,
.schedule-sort:after,
.schedule:after,
.performance:after,
.nav  .l:after {
    clear: both;
    display: block;
    visibility: hidden;
    height: 0;
    content: ".";
}

.skip,
.nav .h,
.lang .h {
    position: absolute;
    top: -9999em;
    left: -9999em;
}

.l {
    margin-left: 0;
    list-style: none;
}

.photoalbum .thumbnail,
.nav .top,
.footer li,
.lang li {
    display: -moz-inline-box; /* FF2 */
    -moz-box-orient: vertical; /* FF2 */
    display: inline-block;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

.photoalbum,
.nav .l,
.footer .l,
.lang .l {
    margin-right: -1px; /* counter rounding errors and link outlines */
    letter-spacing: -0.35em; /* negative letter- and word-spacing help remove the whitespace between inline-blocks */
    word-spacing: -0.5em; /* opera needs this */
}

.photoalbum .thumbnail,
.nav .l li,
.nav li .l,
.footer li,
.lang li {
    letter-spacing: normal;
    word-spacing: normal;
    vertical-align: top;
}


/* specific layout */
html {
    height: 100%;
}

body {
    min-height: 100%;
}

.more {
    padding-right: 20px;
    background: url(arrow-tiny.png) 100% 0.35em no-repeat;
}

.schedule .timetable {
    padding-right: 20px;
    display: inline;
    background: url(arrow-tiny.png) 100% 0.35em no-repeat;
}


.container {
    position: relative;
    margin: 0 auto;
    padding: 18px 0 0;
    min-height: 100%;
    max-width: 985px;
}

.hr,
.main > .text,
.contenttype {
    margin: 25px 0;
}


.performance {
    padding: 12px;
}
.performance  .thumbnail {
    float: left;
    padding: 0 25px 0 0;
}
.performance .info {
    padding: 13px 13px 0 0;
}
.performance p {
    margin: 10px 0;
}

.page-leadtext {
    margin-bottom: 30px;
    padding: 10px 100px 16px 20px;
}
.page-leadtext .h {
    margin-bottom: -8px;
}
.page-leadtext  p {
    margin: 10px 0 0;
}

.news-item,
.freetext,
.schedule,
.thumbnailtext-layout2,
.photoalbum {
    padding: 20px;
    background: #422E1F url(brown_gradient.jpg) 100% 0 repeat-y;
}

.schedule-sort {
    position: relative;
    float: right;
    margin: -10px 0 0 0;
}
.schedule {
    clear: both;
}
.schedule .one-of-two {
    float: left;
    width: 320px;
}
.schedule .second {
    float: right;
}
.schedule a {
    display: block;
    margin-top: 10px;
    padding-left: 20px;
    background: url(arrow-tiny.png) 0 0.4em no-repeat;
}
.schedule .timetable {
    padding-left: 0;
    display: inline-block;
    margin: 3px 0 8px;
}
.schedule .performance-date {
    margin-left: 20px;
}

/* titleheader blocks */
.titleheader {
    position: relative;
    margin: 35px 0 -20px 0;
}
.titleheader .h {
    margin-right: 300px;
}
.titleheader a {
    position: absolute;
    right: 0;
    bottom: 2px;
}

.pagination {
    margin: -15px 0 25px 0;
    text-align: right;
}
.pagination .page {
    margin-left: 5px;
    border-style: solid;
    border-width: 0 0 0 1px;
    padding-left: 8px;
}
.pagination .page:first-child {
    border: none;
}

.sidebanner img {
    display: block;
}

.sidebanner-layout2 strong {
    display: block;
    padding-right: 35px;
    background: url(arrow-large.gif) 100% 100% no-repeat;
}

.sidebanner-layout2  .image {
    display: block;
    margin: 3px 0;
    border-style: solid;
    border-width: 1px;
    border-color: #422E1F;
    padding: 7px;
}


.saleslocation table {
    float: left;
    width: 348px;
    background: #476778;
}
.saleslocation th,
.saleslocation td {
    padding: 4px 16px;
}
.saleslocation .even {
    background: #7A722E;
}
.saleslocation .first {
    margin-right: 8px;
}

.photoalbum .thumbnail {
    margin-bottom: 20px;
    width: 33%;
    text-align: center;
    vertical-align: middle;
}
.photoalbum .thumbnail img {
    border: 3px;
    border-style: solid;
    border-color: #FFF;
}


/* backgroundtext blocks */
.backgroundtext {
    position: relative;
    overflow: hidden;
    padding: 20px;
}

.backgroundtext img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    border: 0;
}

.backgroundtext .text {
    position: relative;
    padding: 16px;
    overflow: hidden;
    width: 48%;
    background: url(backgroundtext_overlay.png);
}


/* thumbnailtext blocks */
.thumbnailtext {
    position: relative;
}

.thumbnailtext-layout2 {
    overflow: hidden;
}

.thumbnailtext img {
    float: left;
    margin-right: 20px;
    max-width: 50%;
}

.thumbnailtext-layout2 img {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 200px;
}

.thumbnailtext-layout2 .text {
    padding-left: 210px;
}

.thumbnailtext .more {
    float: right;
    margin-top: 10px;
}

.thumbnailtext-layout2 .more {
    margin-right: -10px;
    margin-bottom: -10px;
}

/* ct news */
.news .item {
    position: relative;
    margin: 3px 0;
    padding: 15px 10px 15px 210px;
    overflow: hidden;
    background: #422E1F url(brown_gradient.jpg) 250px 0 repeat-y;
}
.news.no-thumbnail {
    padding-left: 20px;
}
.news .h {
    margin-bottom: 10px;
}
.news img {
    position: absolute;
    bottom: 0;
    left: 0;
    max-width: 200px;
}
.news .text {
    padding-right: 10px;
}
.news .dt,
.news-item .dt {
    margin-right: 8px;
    border-style: solid;
    border-width: 0 1px 0 0;
    padding-right: 8px;
}

.news-item .dt {
    float: left;
}

.news-item .text {
    margin-top: 10px;
}

/* navigation */
.nav {
    padding-bottom: 22px;
    background: url(colored_line.gif) 0 100% repeat-x;
}

.nav .top {
    padding-left: 24px;
    background: url(nav_dot.gif) 9px 50% no-repeat;
}
.nav .top:first-child {
    padding-left: 0;
    background: none;
}

.nav li .l {
    display: none;
}

.lang li {
    margin-right: 12px;
}

/* Google custom search hacking */
#search .gsc-search-box,
#search th,
#search td {
    margin: 0;
    padding: 0;
}

#search .gsc-branding {
    display: none;
}

#search input.gsc-input {
    border: none;
    height: 19px;
    background: url(input_text.png) no-repeat;
}

#search .custom-search-button {
    display: block;
    padding: 0 29px 0 6px;
    background: url(arrow-small.gif) 100% 50% no-repeat;
    cursor: pointer;
}

#search .gsc-tabsArea,
#search .gsc-resultsHeader {
    display: none;
}

.footer {
    clear: both;
    padding: 60px 0 170px;
}

.footer li {
    margin-left: 15px;
    border-style: solid;
    border-width: 0 0 0 1px;
    padding-left: 15px;
}

.footer li:first-child {
    border: none;
}

.lightbox {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background: url(semi-transparent-black.png);
    text-align: center;
}
.lightbox-prev,
.lightbox-next {
    position: absolute;
    top: -40px;
    width: 50%;
    height: 100%;
    overflow: hidden;
    text-indent: -9999em;
    cursor: pointer;
    opacity: .6;
}
.lightbox-prev:hover,
.lightbox-next:hover {
    opacity: 1;
}
.lightbox-prev {
    left: 0px;
    background: url(lightbox-prev.gif) 0 110px no-repeat;
}
.lightbox-next {
    right: 0px;
    background: url(lightbox-next.gif) 100% 110px no-repeat;
}
.lightbox > span {
	display: -moz-inline-box;
	-moz-box-orient: vertical;
	display: inline-block;
	width: 1px;
	height: 100%;
	vertical-align: middle;
}

.lightbox .lightbox-box {
    position: relative;
    margin: 10px 0;
    padding: 10px 0 30px;
	max-width: 90%;
	height: auto;
    background: #FFF url(colored_line.gif) repeat-x;
    text-align: left;
}

.lightbox-content {
    padding: 20px;
    overflow: auto;
}

.lightbox-content img {
    max-width: none;
}

.lightbox .contenttype {
    margin: 0;
    padding: 0;
}

.lightbox-close {
    position: absolute;
    right: 12px;
    bottom: 12px;
    padding-right: 20px;
    background: url(close.gif) 100% 0 no-repeat;
    color: #999100;
    font-weight: bold;
    text-transform: uppercase;
    cursor: pointer;
}
.contactform {
    margin-bottom: 20px;
    padding: 20px;
    background: #422E1F url(brown_gradient.jpg) 100% 0 repeat-y;
}
.contactform  .error input,
.contactform  .error textarea { 
    border: 1px solid #ed1c23;
}
.contactform tr {
    vertical-align: top;
}
.contactform .h {
    color: #ACB242;
    font-size: 1.7em;
}
.contactform td {
    padding-bottom: 5px;
}
.contactform input,
.contactform textarea {
    border : 1px solid #422e1f;
    background-color: #fff;
    color: #000;
    padding: 2px 2px 1px;
}
.contactform .group input {
    background-color: transparent;
}
.contactform #contactform_submit {
    padding-right: 20px;
    color:#ACB242;
    font-weight:bold;
    font-size:1.4em;
    display: block;
    background:url("arrow-tiny.png") no-repeat scroll 100% 0.6em transparent;
    padding-right:20px;
    border: none;
    float: right;
}
.contactform #contactform_submit:hover {
    color:#FFF;
    cursor: pointer;
}
.contactform ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.contactform li {
    padding: 0;
    display: inline-block;
    margin: 0 0 0 2px;
}
.contactform ul input,
.contactform ul label
 {
    border: none;
    float: left;
}
.contactform ul input {
    margin-right: 7px;
}
.contactform textarea {
    overflow: hidden;
}

@media all and (min-width: 38em) {

    .logo {
        float: right;
        margin-right: -4px;
        width: 257px;
        height: 140px;
        background: url(logo.png);
        text-indent: -9999em;
    }
    
    .container {
        padding-bottom: 1px;
    }
    
    .main {
        float: left;
        padding: 152px 0 0;
        width: 704px;
        min-height: 500px;
    }
    
    .home .main {
        padding-top: 112px;
    }
    
    .hover-thumb {
        position: absolute;
        margin: -50px 0 0 20px;
        background: #2C1F15;
    }
    .hover-thumb span {
        position: relative;
        display: block;
        top: -4px;
        left: -4px;
        border: #422E1F solid 1px;
        padding: 7px;
        background: #000;
    }
    .hover-thumb img {
        display: block;
        width: auto;
        height: 75px;
    }
    
    .side {
        float: right;
        /*top: 195px;*/
        margin: 35px 0 0;
        width: 253px;
    }
    
    .nav {
        position: absolute;
        top: 0;
        right: 281px;
        left: 0;
        height: 109px;
    }
    
    .nav .l {
        position: absolute;
        right: 217px;
        bottom: 18px;
        left: 0;
    }
    
    .nav a {
        display: block;
    }
    
    .nav li {
        position: relative;
    }
    
    .nav li:hover .l {
        display: block;
    }
    
    .nav li .l {
        position: absolute;
        top: 100%;
        right: auto;
        bottom: auto;
        left: 17px;
        margin: -1px 0 0;
        padding-top: 19px;
    }
    
    .nav li li,
    .nav li li a {
        display: block;
    }
    
    .nav li li {
        padding: 0 7px;
        background: url(subnav.png);
    }
    
    .nav li li:first-child {
        padding-top: 6px;
    }
    
    .nav li li a {
        position: relative;
        top: -3px;
        border-style: dotted;
        border-width: 1px 0 0;
        padding: 5px 0 6px 20px;
        min-width: 140px;
        background: url(arrow-tiny.png) 0 7px no-repeat;
    }
    
    .nav li li:first-child a {
        border: none;
    }
    
    .lang {
        position: absolute;
        top: 15px;
        right: 281px;
        left: 0;
    }
    
    #search {
        position: absolute;
        top: 87px;
        right: 281px;
        width: 207px;
    }
    
    #search .gsc-clear-button {
        position: absolute;
    }
    
    #search div.gsc-clear-button {
        z-index: 1;
        top: 60px;
        right: -72px;
    }
    
    #search .gsc-wrapper {
        position: absolute;
        top: 100%;
        left: 0;
        margin-top: 25px;
        margin-left: -300px;
        width: 600px;
    }
    
    #search .gsc-resultsbox-visible {
        border-style: solid;
        border-width: 20px;
    }

}