html, body, div, p, ul, ol, li, h1, h2, h3, h4, pre, form, p, button, img, a img { border: 0 none; margin: 0; padding: 0; }
ul, li { list-style-type: none; }
* { box-sizing: border-box; }
mark { background: transparent; }
h1, h2, h3, h4 { font-weight: normal; }

body { font-family: 'Archivo', sans-serif; font-variation-settings: "wdth" 100, "wght" 400; font-size: 20px }
h1 { display: none; }

.error { justify-content: space-evenly; padding: 2em 0 }
.error a { text-underline-offset: 3px; }

/* font definitions */

.font2 { font-size: 24px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 900; } /* banner */
.font3 { font-size: 20px; font-variation-settings: "wdth" 90, "wght" 750; } /* program list */
.font4 { font-size: 11px; font-variation-settings: "wdth" 95, "wght" 500; text-transform: uppercase; } /* tags */
.font5, .page_content h2 { font-size: 50px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 800; } /* H2 on program detail + higlight om index*/
.font6, .page_content p, .page_content ul, .page_content ol { font-size: 18px; font-variation-settings: "wdth" 100, "wght" 400; } /* annotation on program detail */
.page_content h3 { font-size: 16px; font-variation-settings: "wdth" 100, "wght" 650; font-weight: normal; } /* annotation on program detail */
.font7, .program .highlights .title { font-size: 30px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 900; } /* ticket slot on program detail + menu */
.font8 { font-size: 15px; font-variation-settings: "wdth" 100, "wght" 500; } /* meta on program detail */
.font8 strong { font-variation-settings: "wdth" 90, "wght" 750; font-weight: normal; }

.logo { height: 45px; margin: 12px 0 10px 0; }

.top { position: fixed; top: 0; left: 50%; width: 100.15%; max-width: 1300px; height: auto; transform:translateX(-50%); z-index: 100; }
.top_inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; margin: 0 30px; border-bottom-width: 4px; border-bottom-style: solid; }
.top .icons { display: flex; align-items: center; }
.top .icons .menu_switch { margin-right: 1.3em; display: flex; align-items: center; }
#color_mode img { opacity: 0.8; height: 1em; display: block; padding: 0 0.75em; cursor: pointer; }
#color_mode:hover { opacity: 0.9; }
.top .icons a { text-decoration: none; display: inline-block; font-variation-settings: "wdth" 90, "wght" 750; padding: 0 0 0 0.3em; transition: opacity 0.1s }
.top .icons a:hover { opacity: 0.9; }

.menu { height: auto; width: 100%; display: flex; align-items: center;  justify-content: center; height: 0px; overflow: hidden; }
.menu li { display: inline-block; padding: 0.2em 0.5em }
.menu li a { text-decoration: none; transition: opacity 0.2s; }
.menu li a:hover { opacity: 0.9; }
.menu_trigger { margin-right: 15px; width: 30px; height: 22px; transition: opacity 0.2s; cursor: pointer; }
.menu_trigger:hover { opacity: 0.75; }
.menu.menu_open { height: auto; padding-bottom: 1em; }

/* banner (fixed colors) */
.banner { padding-bottom: 25px; border-bottom-width: 4px; border-bottom-style: solid;  }
.banner_1 .banner_inner { height: 10em; display: flex; background: #dadfdf; text-decoration: none; max-height: 15vw; padding: 0.5em 1em; }
.banner_1 img { display: none; }
.banner_1 .banner_text { line-height: 1.2em; width: 80%; padding: 0.1em; font-size: 2em}
.banner_1 .banner_text div.color1 { color: #222; }
.banner_1 .banner_text div.color2 { color: #666; } 

.banner_2 .banner_inner { height: 10em; display: flex; background: #3c3e40; text-decoration: none; max-height: 15vw; }
.banner_2 img { width: 60%; height: 100%; object-fit: cover; object-position: center center; }
.banner_2 .banner_text { line-height: 1.3em; width: 40%; padding: 0.75em 1em; }
.banner_2 .banner_text div.color1 { color: #fff; }
.banner_2 .banner_text div.color2 { color: #ddd; } 

.banner_3a .banner_inner { height: 10em; display: flex; background: #333; text-decoration: none; max-height: 15vw; }
.banner_3a img { width: 100%; height: 100%; object-fit: cover; object-position: center center; }
.banner_3a .banner_text { line-height: 1.3em; width: 50%; padding: 0.75em 1em; position: absolute; }
.banner_3a .banner_text div.color1 { color: #fff; }
.banner_3a .banner_text div.color2 { color: #ddd; } 

.banner_3b .banner_inner { height: 10em; display: flex; background: #333; text-decoration: none; max-height: 15vw; }
.banner_3b img { width: 100%; height: 100%; object-fit: cover; object-position: center center; }
.banner_3b .banner_text { line-height: 1.3em; width: 40%; padding: 0.75em 1em; position: absolute; }
.banner_3b .banner_text div.color1 { color: #222; }
.banner_3b .banner_text div.color2 { color: #444; } 

.page { width: 100%; max-width: 1300px; margin: auto; margin-top: 100px; }
.page_inner { margin: 0 30px; }

.columns_container { display: flex; }
.column { width: 50%; margin: 0 25px }
.column:first-child { margin-left: 0;  }
.column:last-child { margin-right: 0; }

/* CMS created pages */

.page_content h2 { margin-bottom: 1em; line-height: 1.1em; margin-top: -8px } 
.page_content h3 { line-height: 1.1em; font-size: 1.25em; margin-bottom: 0.75em; } 
.page_content p, .page_content ul, .page_content ol { line-height: 1.5em; margin-bottom: 1em }
.page_content a { text-underline-offset: 3px; }
.page_content .col { width: 50%; padding: 0 25px; overflow: hidden; } 
.page_content .col:first-child { padding-left: 0; }
.page_content .col:last-child { padding-right: 0; }
.page_content .page_text { margin-top: 30px }
.page_content .page_text strong { font-weight: 750; }
.page_content .page_text iframe { width: 100%; margin: 0.75em 0 0 0; background: #000; }
.page_content ol { padding-left: 1em }
.page_content ol li { padding-left: 0.25em; list-style-type: decimal; }
.page_content .col img { width: 100%; height: auto; }

/* program detail */

.program_detail .page_inner { }
.program_detail h2 { margin-bottom: 0.75em; line-height: 1em }
.program_detail p { margin: 0 0 1em 0 }
img.poster { width: 100%; max-height: 400px; height: 30vw; object-fit: cover; object-position: center center; }
.program_detail .meta { line-height: 1.35em; width: 75%; margin-bottom: 0em; }
.program_detail .meta a { text-decoration: none; }
.program_detail .meta a:hover { opacity: 0.9; }

.program_detail .tags { margin: 1em 0 5px 0 }
.program_detail .tag { text-transform: uppercase;  border: 1px solid #aaa; text-decoration: none; padding: 2px 5px; margin: 0.5em 4px 0 0; white-space: nowrap; }
.program_detail .tag:hover { opacity: 0.9; }

.program_detail .annotation { line-height: 1.4em; margin-top: 0.5em; margin-bottom: 1.4em; text-underline-offset: 3px }
.program_detail .info { text-decoration: none; padding: 2px 0.75em; margin: 0.25em 0; display: inline-block; }
.program_detail .info.button:hover { opacity: 0.9; }
.program_detail .textbutton { display: inline-block; padding: 2px 10px; text-decoration:none; border-width: 1px; border-style: solid; }
.program_detail .textbutton:hover { opacity: 0.9; }
.program_detail .ticket_slot { padding: 0.5em 0; margin: 1.5em 0; display: flex; align-items: center; justify-content: space-between; border-top-width: 4px; border-top-style: solid; border-bottom-width: 4px; border-bottom-style: solid;  }
.program_detail .ticket_slot .date, .program_detail .ticket_slot .price { white-space: nowrap; }
.program_detail .ticket_slot .location { margin: 0 0.75em; white-space: nowrap; }
.program_detail .program_link { margin-bottom: 2em  }

.program_detail .past .pay, .program_detail .past .price { display: none; }
.program_detail .ticket_slot.goout-not-found .price, .program_detail .ticket_slot.goout-not-found .pay { display: none; }

.big_button { text-decoration: none; display: inline-block; line-height: 1em; padding: 8px 16px; border-radius: 1px; margin-left: 0.5em; transition: opacity 0.1s }
.big_button:hover { opacity: 0.9 }

/* program detail extras */

.extras { display: flex; width: 100%}
.extras a { margin-right: 1.75em }
.button_text_icon { display: flex; align-items: center; text-decoration: none; margin: 0 0 1em -3px; }
.button_text_icon img { margin-right: 0.4em; height: 1.55em; opacity: 0.8 }
.button_text_icon:hover { opacity: 0.9; }

/* not available button */

.big_button.not-available, .info.button.not-available { opacity: 1 !important }
a.gray.not-available { opacity: 1 !important; }
a.gray.not-available:hover { opacity: 1 !important; }

/* program next */

.program_detail .next { margin: 25px 0 2em 0 }
.program_detail .head { margin-bottom: 0.5em }
.program_detail .next a { text-decoration:none; }
.program_detail .next div { display: flex; white-space: nowrap; align-items: center;}
.program_detail .next .program_line { padding: 0.35em 0; justify-content: space-between; border-top-width: 1px; border-top-style: solid; } 
.program_detail .next .program_line.goout-not-found .price, .program_detail .next .program_line.goout-not-found .pay { visibility:hidden; }
.program_detail .next .program_line:last-child { border-bottom-width: 1px; border-bottom-style: solid; }
.program_detail .next .date { width: 6em}
.program_detail .next .time {  }
.program_detail .next .datetime { width:100%; }
.program_detail .next .location { margin: 0 1em }
.program_detail .next .price { margin: 0 1em 0 0; width: 3em }

/* videoplayer */

#video_player { position: fixed; left: 0; top: 0; background: #222; width: 100%; height: 100vh; z-index: 110; display: none; }
#video_player iframe { width: 80vw; height: 80vh; position: absolute; left: 50%; top: 50%; transform: translate3d(-50%, -50%, 0px); }
#video_player #youtube_frame { display: none; }
#video_player_close, #video_player_logo { filter: invert(1); height: 1.5em; }
#video_player_close { position: fixed; right: 1em; top: 1em; cursor: pointer; }
#video_player_logo { position: fixed; left: 1em; top: 1em; }

/* extra program */

.extra_program { padding: 25px 0 0 0; margin-top: 25px; border-top-width: 4px; border-top-style: solid; }
.extra_program .program_list { display: flex; justify-content: space-between; padding-top:  0.2em}
.extra_program .slot { width:18.5%; overflow: hidden; }
.extra_program .date { border-bottom-width:1px; border-bottom-style: solid; padding-bottom: 0.5em; margin-bottom: 0.4em }
.extra_program .slot .meta { width: 90%; margin-top: 0.25em; line-height: 1.3em }
.extra_program img { width: 100%; height: 12vw; max-height: 140px; object-fit: cover; object-position: center center; margin-bottom: 0.25em}
.extra_program a { text-decoration: none; }

/* program on homepage */

.program {  }
.program .filter { border-bottom-width: 4px; border-bottom-style: solid; padding: 0.5em 0; display: flex; align-items: center; }
.program .filter .button { padding: 2px 1em; background:red }
.program .program_slot { display: flex; width: 100%; flex-wrap: wrap; border-bottom-width: 1px; border-bottom-style: solid; }
.program .program_slot:last-child { border-bottom: 0 }
.program .line { width: 100%; display: flex; align-items: center; }
.program .date { width: 20%; display: flex; padding: 10px 0; }
.program .filter .spacer { width: 20% }
.program .filter .filter_content { width: 80%; display: flex; justify-content: space-between; align-items: center; }

.program .description { width: 80%; padding: 10px 0; display: flex; justify-content: space-between; border-bottom-width: 1px; border-bottom-style: solid; }
.program a { color: inherit; text-decoration: none; transition: opacity 0.1s }
.program a:hover { opacity: 0.75; }
.program .line:last-child .description { border: none; }
.program .line:not(:first-child) .date { visibility: hidden; }
.program .event_data { display: flex; width: 100%; justify-content: space-between; align-items: center; } 
.program .title { display: -webkit-box; -webkit-box-orient: vertical;  -webkit-line-clamp: 1; overflow: hidden; }
.program .time { width: 3em; min-width: 3em }
.program .price { white-space: nowrap; display: flex; align-items: center; min-width: 4em; flex-direction: row-reverse; }
.program .tags { display: flex; align-items: center; flex-direction: row-reverse; }
.program .tags .tag { margin: 2px 3px 2px 1px; align-items: center; border: none; padding: 2px 5px; white-space: nowrap; border-width: 1px; border-style: solid; }
.program .line.goout-not-found .price { visibility: hidden; }

.not-available { cursor:default; }
.program .program_slot.hidden { display: none; }
.program.program_is_open .program_slot.hidden { display: flex; }

.program_break .description { border-bottom: 0; margin-top: 22px }
.program_break a { display: flex; align-items: center; padding: 5px 15px; cursor: pointer;}
.program_break img { height: 1.1em; filter: invert(1); padding-left: 0.5em }
.program_break a:hover { opacity: 0.9; }

.weekday { margin-right: 0.3em }	

/* main events */

.program .program_slot.highlights { border-bottom-width: 4px; border-bottom-style: solid; margin-bottom: 0.5em; padding: 0.75em 0; }
.program .highlights .line { flex-wrap: wrap; display: flex; width: 50%; align-items: flex-start; }
.program .highlights .line:nth-child(odd) { border-right-width: 1px; border-right-style: solid; }
.program .highlights .line:nth-child(odd) .description { margin-right: 1em; }
.program .highlights .line:nth-child(even) .description { margin-left: 1em; }
.program .highlights .line:first-child .date { width: 100%; }
.program .highlights .line:not(:first-child) .date { display: none; }
.program .highlights .line .description { width: 100%; align-items: flex-start; padding: 0.75em 0; border: 0px; border-top-width: 1px; border-top-style: solid; }
.program .highlights .line:nth-child(-n+2) .description { border: 0 }
.program .highlights .image { width: 30%; }
.program .highlights .image img { width: 100%; height: 9vw; max-height: 115px; object-fit: cover; object-position: center center; display: block; }
.program .highlights .image a:hover { opacity: 0.95; }
.program .highlights .title { width: 100%; display: flex; margin-top: 0.1em;  line-height: 1.1em; }
.program .highlights .title a { display: -webkit-box; -webkit-box-orient: vertical;  -webkit-line-clamp: 2; overflow: hidden; }
.program .highlights .event_data { flex-wrap: wrap; align-content: center; width: 50%; height: 100%; display: flex; align-content: flex-start; }
.program .highlights .time, .program .highlights .title { font-size: 30px; }
.highlight_head.date { border-bottom-width: 1px; border-bottom-style: solid; width: 100%}
.program .highlights .price { margin-top: 0.5em }
.program .highlights .tags { margin: 0.5em 0; flex-direction: initial;  }
.program .highlights .tags .tag { margin-top: 0.35em }

/* section info on homepage */

.section_info { width: 100%; max-width: 1300px; margin: auto; margin-top: 25px;  }
.section_info_inner { margin: 0 30px; display: flex; padding-top: 25px; justify-content: space-between; border-top-width: 4px; border-top-style: solid; }
.section_info .col { width: 18% }
.section_info .col1 { width: 30%; }
.section_info .col2 { width: 70%; }
.section_info img { width: 100%; height: 100%; display:block; object-fit: cover;}
.section_info h2 { margin-bottom: 0.5em; max-width: 20em; line-height: 1em }
.section_info p { margin-bottom: 0.5em; line-height: 1.25 }
.section_info .text { column-count: 2; column-gap: 2em }

/* footer */

.footer { width: 100%; max-width: 1300px; margin: auto; margin-top: 30px; margin-bottom: 6em }
.footer_inner { margin: 0 30px; padding: 20px 0 0 0; display: flex; justify-content: space-between; line-height: 1.4em; border-top-width: 4px; border-top-style: solid; }
.footer .col { width: 15%; padding: 0 1em; border-right-width: 1px; border-right-style: solid; border-bottom-width: 0px; border-bottom-style: solid; }
.footer .col:first-child { padding-left: 0; }
.footer .col:last-child { border: none; padding-right: 0 }
.footer .col1 { width: 30%; }
.footer .logo { height: 25px; margin: 0 0 0 1px }
.footer a { text-decoration: none; text-underline-offset: 3px; }
.footer a:hover { text-decoration: underline; }
.footer p { margin-bottom: 1.4em }

/* logos (fixed colors) */

.logos { display: flex; width: 100%; padding: 0.5em; justify-content: space-evenly; }
.logos img { width: 4.5em; height: 3em; margin: 1em; object-fit: contain; object-position: center center; filter: grayscale(1) invert(1); mix-blend-mode: screen; }

/* anim */ 

.banner { opacity: 0; animation: fade-in; animation-iteration-count: 1; animation-duration: 0.2s; animation-delay: 0s; animation-fill-mode: forwards; }

.program .program_slot:first-child,
.program_detail .col1 { opacity: 0; animation: fade-in; animation-iteration-count: 1; animation-duration: 0.2s; animation-delay: 0.2s; animation-fill-mode: forwards; }

.program .program_slot:not(:first-child),
.program_detail .col2,
.extra_program { opacity: 0; animation: fade-in; animation-iteration-count: 1; animation-duration: 0.2s; animation-delay: 0.3s; animation-fill-mode: forwards; }

@keyframes fade-in
	{ 
	0% { opacity: 0; } 
	100% { opacity: 1; } 
	}


/* flex */

@media only screen and (max-width: 1200px) {
body { font-size: 18px; }
.font2 { font-size: 2vw; }
.banner_1 .font2 { font-size: 3.25vw; }
.font3 { font-size: 18px; }
.font4 { font-size: 9px; }
.program .program_slot:first-child .date,
.program .program_slot:first-child .time,
.program .program_slot:first-child .title,
.font5, .page_content h2 { font-size: 40px; } 
.font6, .page_content p, .page_content ul, .page_content ol { font-size: 16px; }
.program .highlights .time, .program .highlights .title,
.font7 { font-size: 25px; }
.font8 { font-size: 12px; }
.program_detail .ticket_slot { padding: 0.65em 0 }
.program .description, .program .date { padding: 7px 0 }
.program .highlights .image { margin-right: 0.5em }
.program .program_slot:first-child .description, .program .program_slot:first-child .date { padding: 8px 0 }
}

@media only screen and (max-width: 940px) {
.font5, .page_content h2 { font-size: 35px; } 
.program .date { width: 12%; min-width: 80px; }
.program .description { width: 88% }
.footer_inner { flex-wrap: wrap; }
.footer .col { width: 50%; margin: 0 0 1em 0; padding: 0 1em 0 0; border-bottom-width: 1px; }
.footer .col:last-child li { display: inline-block; margin-right: 0.5em }
.program_detail .columns_container { display: block; }
.program_detail .column { width:100%;  margin: 0; }
.program_detail .next { display: none; }
.program_detail img.poster { height: 50vw; }
.program_detail h2 { margin-top: 0.3em }
.program .highlights .image {  width: 100%; margin: 0; }
.program .highlights .image img { height: 22vw; max-height: initial; }
.program .highlight_head.date { width: 100%; min-width: initial; } 
.program .highlights .description { flex-wrap: wrap; align-content: flex-start; }
.program .highlights .title { width: 95%; margin-top: 0.25em }
.program .highlights .event_data { width: 80%; height: auto; }
.program .highlights .price { width: auto; min-width: initial; margin-top: 0.6em }
.page_content .col img { width: 50%; }
#menu { font-size: 1em;  }
#menu a { white-space: nowrap; }
.logo { height: 35px } 
.menu_trigger { width: 20px; height: 15px; }
.page { margin-top: 85px; }
.banner { padding-bottom: 20px }
.page_content .columns_container { flex-wrap:wrap; }
.page_content .col { width: 100%; margin: 0; padding: 0 0 1.5em 0 }
.footer .col { border-right: 0 !important }
.logos { font-size: 90% }
}

@media only screen and (max-width: 780px) {
.program .tags .series { display: none; }
#menu { display: block; text-align: center; }
#menu li { width: 100%; padding: 0.1em 0 }
}