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; }

input:focus, button:focus, select:focus { outline: none; }

html { font-size: 16px; font-stretch: 100%; }

/* colors */

html.dark
	{
	--text: #d4dbdf;
	--background: #1f292f;
	--background_alt1: #2a3841;
	--background_alt2: #3d4c57;
	--background_alt3: #51616b;
	--background_alt4: #3d4c57;
	--background_alt5: #13171a;
	--lines1: #4b5e69;
	--lines2: #3d4c57;
	--lines3: #5a6f7d;
	--text1: #8a9399;
	--text2: #d3d3d3; 
	--text3: #6a7b85; /* small text */
	--text4: #5d6b73; /* headings */
	--text_hover: #adb7bd;
	--shadow: #1c2125bf;
	--red: #614646;
	--blue: #275775;
	--gray: #363c3f;
	
	}

html.light
	{
	--text: #161616;
	--background: #f5f5f5;
	--background_alt1: #e5e8e9;
	--background_alt2: #2e3133;
	--background_alt3: #d2d7d9;
	--background_alt4: #c5c5c5;
	--background_alt5: #f5f5f5;
	--lines1: #778085;
	--lines2: #778085;
	--lines3: #484848;
	--text1: #2e3133;
	--text2: #f5f5f5; 
	--text3: #2e3133; /* small text */
	--text4: #5d6b73; /* headings */
	--text_hover: #5f6467;
	--shadow: #edededbf;
	--red: #ad5a5a;
	--blue:#5892b5;
	--gray: #a7a7a7;
	}

.off { color: var(--text4); }

.dark::selection { background: var(--blue); color: var(--text);}
.light::selection { background: var(--text); color: var(--background);}

/* fonts */
body { font-family: 'Archivo', Arial, sans-serif; visibility: hidden; }

body.loaded { visibility: visible; }
body { background: var(--background); color: var(--text); text-underline-offset: 4px; }
a { color: var(--text); text-decoration: none; }

h1 { display: none; }

.variables { display: none; }

.font1 { font-size: 46px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 600; line-height: 1.2em; } /* h2 */
.font2 { font-size: 17px; line-height: 1.5em; }
.font3 { font-size: 15px; } /* menu */
.font4 { font-size: 10px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 500; text-transform: uppercase; letter-spacing: 0.75px; }
.font5 { font-size: 26px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 600; line-height: 1.2em; } /* large  */
.font6 { font-size: 14px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 500; }
.font7 { font-size: 19px; line-height: 1.5em; } /* editor page text */

.light .font5, .light .font1 { font-variation-settings:"wght" 700; }

.gray1 { opacity: 0.5 }

.location { padding: 2px 6px; background: var(--background_alt2); color: var(--text2); display: inline-block; text-align: center; line-height: 1.5em; white-space: nowrap; }
.location-id-64 { background: var(--red); } /* velky sal */
.location-id-66 { background: var(--blue); } /* maly sal */
.location-id-67 { background: var(--gray); } /* gallery */

.tags { display: flex; flex-wrap: wrap; gap: 2px 4px; }
.tag { display: inline-block; border: 1px solid var(--lines1); color: var(--text3);padding: 1px 4px; white-space: nowrap; line-height:1.5em }

.buy_button { flex-wrap: nowrap; white-space: nowrap; }
.buy_button img { height: 0.8em; margin-top: -1px; padding-left: 0.5rem; }

.button_text_icon { display: inline-flex; align-items: center; gap: 0.5rem; padding-right: 1.5rem; transition: color 0.2s; }
.button_text_icon img { height: 1.5em; }
.button_text_icon:hover { color: var(--text_hover); }

.compound_button { display: inline-flex; color: var(--text); border: 0; background: var(--background_alt3); cursor: pointer; align-items:center; white-space: nowrap; transition: color 0.2s; }
.compound_button img { height: 2em; padding: 0.3em 0.35em; transition: opacity 0.2s }
.compound_button span { background: var(--background_alt4); line-height: 2em; display: block; padding: 0 0.75em 0 0.7em; }
.compound_button:hover { color: var(--text_hover); }
.compound_button:hover img { opacity: 0.6; }

/* misc page elements */

.frame { max-width: 1280px; width: 100%; margin: auto; overflow: hidden; padding: 0 3rem; }
.section { display: flex; margin: 3rem 0; gap: 2rem; } 
.section.thumbs { padding-top: 3rem; border-top: 1px solid var(--lines2); margin-top: 5rem; }
.section.thumbs img { width: auto; flex: 1; min-width: 0; opacity: 0.9 }

.logo img { height: 2.5rem; opacity: 0.85; display: block; }
.dark .logo { filter: invert(1); }

.dark .ico { opacity: 0.8; transition: opacity 0.2s; filter: invert(1); display: inline-block; }
.light .ico { opacity: 0.8; transition: opacity 0.2s; display: inline-block; }
a .ico:hover { opacity: 0.65; }

.top { padding: 3rem 0; display: grid; grid-template-columns: auto auto 60px; grid-template-rows: auto auto; }
.top a { color: var(--text1); transition: color 0.2s; }
.top a:hover { cursor: pointer; color: var(--text); }
.light .top a { color: var(--lines2); font-weight: 500; }
.light .top a:hover { color: var(--text); }
.top { align-items: center; }
.top .switches { display: flex; flex-wrap: nowrap; align-items: center; gap: 0 0.5rem; justify-self: right; }
.top .switches .ico { height: 1.5em; margin-right: 2px; cursor: pointer; opacity: 0.4;  }
.top .switches .ico:hover { opacity: 0.8 }
.top .language_switch.selected { display: none; }


.menu { display: flex; gap: 0.5rem 1.25rem; flex-wrap: wrap; margin: 0 0.5rem; justify-self: right; }
.menu li { display: inline-block; }
.menu li a { text-decoration: none; }
#menu_trigger { display: none; }

/* hovers */

.buy { transition: color 0.2s; }
.buy:hover img { transition: opacity 0.2s; }
.buy:hover { color: var(--text_hover); }
.buy:hover img { opacity: 0.6!important }

.location { transition: opacity 0.2s; }
a.location:hover { opacity: 0.85; }

.tag { transition: opacity 0.2s; }
.tag:hover { opacity: 0.85; }

/* programme highlight on homepage */

.program_highlight_date { width: 100%; padding: 1.5rem 0 0.8rem 0; margin-bottom: 1.6rem; color: var(--text3); border-bottom: 1px solid var(--lines2); }
.program_highlight { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; padding-bottom: 3rem; gap: 2rem 3rem; }

.program_highlight.one { grid-template-columns: repeat(1, 1fr); }
.program_highlight.one .description { display: flex; gap: 2rem;  }
.program_highlight.one .description .image { width: 50%; }
.program_highlight.two { grid-template-columns: repeat(2, 1fr); }
.program_highlight.two .description .image { }
.program_highlight.three { grid-template-columns: repeat(3, 1fr); }
.program_highlight.three .description .image { flex: 1 }
.program_highlight.four { grid-template-columns: repeat(4, 1fr); }
.program_highlight.four .description .image { flex: 1 }

.program_highlight .line { transition: background 0.125s; }
.program_highlight .line:hover {  }

.program_highlight .program_date { display: flex; align-items: center; gap: 0.8rem; }
.program_highlight .time { line-height: 1em; }

.program_highlight .description { display: grid; grid-template-columns: 100%; grid-template-rows: auto auto; gap: 1rem; }
.program_highlight .description .image { width: 100%; overflow: hidden; box-shadow: 0 0 15px var(--shadow); }
.program_highlight .description .image img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center center; background: var(--background_alt1); }

.program_highlight .title { margin: 0.2rem 0; }
.program_highlight .subtitle { margin: 0.2rem 0; line-height: 1.5em; color: var(--text3); }
.program_highlight .tags { margin: 0.75em 0; }
.program_highlight .buy { display: flex; flex-wrap: nowrap; align-items: center; width: fit-content; gap: 0.5rem; }
.program_highlight .buy_button img { height: 0.8em; margin-top: -1px; }

/* past */
.program_highlight .past .title a, .program_highlight .past .time { color: var(--text3); }
.program_highlight .past .buy { display: none; }
.light .program_highlight .past .title a, 
.light .program_highlight .past .time, 
.light .program_highlight .past .subtitle { color: var(--lines1); }

/* hovers */
.program_highlight .description .image { transition: opacity 0.2s; }
.program_highlight .description .image:hover { opacity: 0.9; }
.program_highlight .title a { transition: color 0.2s; }
.program_highlight .description:not(.past) .title:hover a { color: var(--text_hover); }

/* program filter */

.program_filter { background: var(--background_alt1); display: flex; padding: 1.5rem; gap: 1.5rem; margin: 0.5rem 0; justify-content: space-between; }
.program_filter select { border: 1px solid var(--lines3); background: var(--background_alt1); color: var(--text); padding: 0.2rem 0.5rem; width: 12em;  appearance: none; height: 2em;}
.program_filter select option { background: var(--background_alt1); }
.program_filter .button { display: flex; white-space: nowrap; border: none; background: var(--background_alt3); color: var(--text); text-align: center; align-items: center; line-height: 1.5em; }
.program_filter button.button  { padding: 0.2rem 0.5rem; transition: opacity 0.2s; }
.program_filter button:hover img { opacity: 0.5; cursor: pointer; }
.program_filter a.button  { padding: 0.2rem 1rem; transition: color 0.2s; }
.program_filter a.button:hover { color: var(--text_hover); cursor: pointer; }
.program_filter .button img { height: 1.25em }
.program_filter form { display: flex; }
.program_filter .text { background: var(--background_alt1); border: 1px solid var(--lines3); border-right: 0; padding: 0.2rem 0.5rem; color: var(--text); }
.light .program_filter .text { border: 0; background: var(--background_alt4); }
/* select design update */
.select_wrapper { position: relative; }
.select_wrapper::after {  content: "▼"; font-size: 12px; position: absolute; top: 50%; right: 10px; transform: translateY(-50%); pointer-events: none; color:  var(--lines3);}

/* banner */

.banner { background: var(--background_alt1); display: flex; gap: 1.5rem; margin-bottom: 0.5rem; aspect-ratio: 1184/190; }
.banner a { width: 100%; height: 100%; text-decoration: none !important; display: flex; align-items: center; justify-content: center; }
.banner.image_banner img { max-width: 100%; max-height: 80%; width: auto; }
.banner.image_banner_large img { max-width: 100%; max-height: 12rem; width: auto; }
.banner.image_banner_large a { width: 100%; height: 100%; text-decoration: none !important; display: flex; align-items: center; justify-content: center; }
.banner.text_banner { padding: 0; width: 100%; overflow: hidden; background-position: center center; background-size: auto 100%; aspect-ratio: 1184/190; }
.banner.text_banner a span { background: var(--background_alt5); color: var(--text2); text-decoration: none; display: block; line-height: 1.1em; width: 15em; text-align: center; max-height: 4.6em; padding: 0.5em; margin: 0 1.5rem; overflow: hidden; }
.banner.text_banner .banner_text { position: relative; top: 0; z-index: 100 }
.light .banner.text_banner a span { color: var(--text); }

/* programme standard */

.program h2 { margin: 3rem 0 0 0; display: flex; align-items: center; }
.program .close { color: var(--background); background: var(--text3); font-size: 0.75em; border-radius: 50%; height: 1em; width: 1em; padding-bottom: 0.2em; overflow: hidden; display: flex; margin: 0.1em 0 0 1rem; align-items: center; justify-content: center; transition: background 0.2s }
.program .close:hover { background: var(--text1); }
.program_standard .line { align-items: center; border-bottom: 1px solid var(--lines2); padding: 0.8rem 0; transition: background 0.125s; }
.program_standard .line.date { color: var(--text3); padding-top: 2.4rem }
.program_standard .description { display: grid; grid-template-columns: 5rem 5.5rem auto max-content; align-items: center; }
.program_standard .line.date_header .description { border: 0 }
.program_standard .event_data { display: grid; grid-template-columns: auto auto; align-items: center; justify-content: space-between; }
.program_standard .buy { display: grid; grid-template-columns: auto auto; align-items: center; padding-left: 0.75rem; }
.program_standard .title { white-space: nowrap; text-overflow: ellipsis; overflow: hidden; padding-right: 1rem; }
.program_standard .tags { flex-wrap: nowrap; }

/* program loading */

.loader_button { display: flex; margin: 3rem auto; }
.loader_button.loading { animation-name: button_fade; animation-fill-mode: forwards; animation-duration: 0.5s; animation-timing-function: ease-out; }
.program_standard .batch.add { animation-name: fade_in; animation-fill-mode: forwards; animation-duration: 0.5s; }
.loader_message { text-align: center; margin: 4rem 0; color: var(--text3); display: none; }
.dark .spinner { mix-blend-mode: screen; opacity: 0.1; margin: 3rem 0; display:  none; }
.light .spinner { mix-blend-mode: darken; opacity: 0.2; margin: 3rem 0; display:  none; }
@keyframes button_fade { from { margin-top: 3rem; opacity: 1; } to { margin-top: 80vh; opacity: 0; }}
@keyframes fade_in { from { opacity: 0; } to { opacity: 1; }}

/* hovers */
.program_standard .title a { transition: color 0.2s; }
.program_standard .title:hover a { color: var(--text_hover); }

/* program detail */

.program_data { display: grid; width: 100%; margin: 0 0 3rem 0; gap: 0 4rem; border-top: 1px solid var(--lines2); padding-top: 2rem; grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; }
.program_data .poster { grid-column: 1; grid-row: 1; }
.program_data .section1 { grid-column: 1; grid-row: 2; }
.program_data .section2 { grid-column: 2; grid-row: span 3 }
.program_data .poster { margin-bottom: 2rem; }

.program_data img.poster { width: 100%; background: var(--background_alt1); box-shadow: 0 0 15px var(--shadow); object-fit: cover; object-position: center center;}
.program_data h2 { margin-bottom: 2rem }
.program_data .meta { margin-bottom: 1rem }
.program_data .ticket_slot { display: grid; grid-template-columns: auto auto; margin-bottom: 3rem; padding: 0.8rem 0; gap: 2rem; border: 1px solid var(--lines2); border-width: 1px 0; justify-content: space-between; align-items: center; }
.program_data .price { display: flex; align-items:center; gap: 1rem }
.program_data .tags { margin: 0.8rem 0 }
.program_data .extras { display: flex; gap: 1rem; justify-content: flex-start; }
.program_data .annotation { margin: 1.5rem 0 3rem 0; }
.program_data .annotation p { margin-bottom: 1em; }
.program_data .annotation p a { color: var(--text1) !important; text-decoration: underline; text-decoration-thickness: from-font; }

/* past */
.program_data .ticket_slot.past { color: var(--text3); }
.program_data .ticket_slot.past .buy { display: none; }
.program_data .program_line.past .datetime { color: var(--text3); }
.program_data .program_line.past .price { display: none; }

/* upcomming screnings */
.program_data .section1 { margin-top: 0.5rem; }
.program_data .section1 .head { margin-bottom: 0.8rem; color: var(--text3);}
.program_data .section1 .program_line { display: grid; grid-template-columns: auto 10.5rem; align-items: center; justify-content: space-between; border-top: 1px solid var(--lines2); padding: 0.5rem 0 }
.program_data .section1 .program_line:last-child { border-bottom: 1px solid var(--lines2); }
.program_data .section1 .program_line .shop { display: flex; align-items: center; flex-wrap: nowrap; justify-content: flex-end;}
.program_data .section1 .datetime { display: flex; flex-wrap: nowrap; gap: 0.5rem; align-items: center; }
.program_data .section1 .datetime .date { width: 4.5em }
.program_data .section1 .datetime .time { width: 3em }
.program_data .section1 .buy { font-size: 1em; }
.program_data .section1 .url { height: 1.2em; display: block; margin-right: 1rem; }
/* hover */
.program_data .section1 a { transition: color 0.2s }
.program_data .section1 a:hover { color: var(--text_hover); }

/* videoplayer */
#video_player { position: fixed; left: 0; top: 0; background:var(--background); 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 { height: 1.5rem; }
#video_player_close { position: fixed; right: 2rem; top: 2rem; cursor: pointer; }
#video_player_logo { position: fixed; left: 2rem; top: 2rem; }

/* extra programs */
.program_detail .calendar_button { margin: auto; display: flex; width: max-content; }
.extra_program { border-top: 1px solid var(--lines2); padding-top: 2rem; margin-top: 3rem; }
.extra_program .head { color: var(--text3); margin-bottom: 1.5rem; }
.extra_program .program_list { display: grid;  grid-template-columns: repeat(4, 1fr); gap: 2rem; width: 100%; }
.extra_program .program_list .line { width: 100%; }
.extra_program .program_list .line img { width: 100%; object-fit: cover; background: var(--background_alt1); }
.extra_program .date { padding: 0.6rem 0 0.4rem 0; }
.extra_program .meta { color: var(--text3); margin-top: 0.4rem; }

/* hover */
.extra_program .line img { box-shadow: 0 0 15px var(--shadow); transition: opacity 0.2s }
.extra_program .line:hover img { opacity: 0.9; }
.extra_program .line .title { transition: color 0.2s }
.extra_program .line:hover .title { color: var(--text_hover); }

/* page from editor */

.editor_page { border-top: 1px solid var(--lines2); padding-top: 2rem; }
.page_content { margin: 3rem auto 5rem auto; max-width: 800px; width: 100%; }
.page_content h2 { font-size: 46px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 600; line-height: 1.2em; margin: 1em 0; }
.page_content h3 { font-size: 26px; font-family: 'Hanken Grotesk', Arial, sans-serif; font-variation-settings:"wght" 600; line-height: 1.2em; margin: 0.5em 0; }
.page_content p, .page_content ul, .page_content ol { margin-bottom: 1em; }
.page_content a { text-decoration: underline; text-decoration-thickness: from-font; transition: color 0.2s }
.page_content a:hover { color: var(--text_hover); }
.page_content ul li { list-style-type: disc; margin-left: 1.25em; }
.page_content ul li li { list-style-type: circle; }
.page_content ol li { list-style-type: decimal; margin-left: 1.25em; }
.page_content strong { font-weight: 600; }
.page_content img { width: auto; max-width: 100%; height: auto; max-height: 35em; margin: 2rem 0; display: block; background: var(--background_alt1); }
.page_content hr { border: 0; height: 1px; background: var(--background_alt3); margin: 1.5em 0; }

.page_content .gallery p { display: flex; flex-wrap: wrap; gap: 1rem; margin: 3rem 0; }
.page_content .gallery img { width: 16rem; height: 9rem; object-fit: cover; margin: 0 !important; cursor: zoom-in; transition: opacity 0.2s; }
.page_content .gallery .selected { position: fixed; left: 0; top: 0; background: var(--background); width: 100vw; height: 100vh; top: 50%; transform: translateY(-50%); object-fit: contain; padding: 1rem; cursor: zoom-out; opacity: 1 !important; z-index: 100; }
.page_content .gallery img:hover { opacity: 0.9; }
.gallery_background.gallery_open { position: fixed; left: 0; top: 0; background: var(--background); width: 100vw; height: 100vh; z-index: 10; }

.page_content .button { display: inline-block; }
.page_content .button a {  background: var(--background_alt4); border-left: 1em solid var(--background_alt3); padding: 0.25em 1em; margin: 0.5em 1em 0.5em  0; display: inline-block; line-height: 1.75em; white-space: nowrap; color: var(--text); text-decoration: none; letter-spacing: 0.5px; transition: opacity 0.2s; }
.page_content .button a:hover { opacity: 0.8; }

/* footer */

.footer { display: flex; gap: 2rem; margin: 3rem 0; padding-top: 3rem; border-top: 1px solid var(--lines2); line-height: 1.25em; }
.footer .col { flex: 1; }
.footer p { margin-bottom: 1.4em }
.footer a { text-decoration: underline; text-decoration-color: var(--lines2); }
.footer p, .footer a { color: var(--text3); transition: color 0.125s }
.footer a:hover { color: var(--text_hover); }
.footer .logo img { height: 2em; }

.logos { display: flex; width: 100%; padding: 2rem 0.5em; justify-content: space-evenly; display: flex;  flex-wrap: wrap; background: var(--background_alt1); }
.logos img { width: 7rem; height: 3rem; margin: 1em; object-fit: contain; object-position: center center; filter: grayscale(1); mix-blend-mode: darken;  opacity: 0.75; transition: opacity 0.2s }
.dark .logos img { filter: grayscale(1) invert(1); mix-blend-mode: screen; }
.logos img:hover { opacity: 1; }

/* responsivity */

@media only screen and (max-width: 1270px) { 
.program_filter { flex-wrap: wrap; gap: 1rem; justify-content: center; }
.banner.text_banner {  }
.banner.text_banner a span { font-size: 2vw; }
}

@media only screen and (max-width: 1200px) { 
.program_highlight { gap: 2rem 2rem; }
}

@media only screen and (max-width: 1120px) { 
html { font-size: 14px; }
.font5 { font-size: 20px; }
.location, .tag { line-height: 1.4em; }
.program_standard .description { grid-template-columns: 5rem 6.5rem auto max-content; }
.footer { flex-wrap: wrap; }
.footer { display: grid; grid-template-columns: repeat(2, 1fr); grid-row: 2; gap: 0 2.5rem; }
.footer .col:first-child { display: none; }
}

@media only screen and (max-width: 980px) { 
#menu { display: none; }
#menu_trigger { display: inline-block; }
#menu.menu_open { display: block; }
.menu { width: 100%;  grid-column: 1; grid-row: 2; display: block; margin: 1rem 0 0 0; }
.menu li { display: list-item; padding: 0.25em 0;  }
.switches { grid-column: 3; }
.program_data { gap: 0 2.5rem; }
.page_content .gallery img { width: 14rem; height: 7.8rem; }
}

@media only screen and (max-width: 920px) { 
.font4 { font-size: 9px; }

.program_highlight.three, .program_highlight.four { grid-template-columns: repeat(2, 1fr); }
.program_highlight { gap: 2.5rem 2.5rem; }
.program_standard .event_data { grid-template-columns: 100%; grid-template-rows: auto auto }
.program_standard .event_data .tags { margin: 0.4rem 0 0.4rem 0; display: flex; flex-wrap: wrap; }
.tags { gap: 3px; }
.font7 { font-size: 17px; }

/* reconfig program detail page */
.program_data  { grid-template-columns: 100%; }
.program_data .poster { grid-column: 1; grid-row: 1; }
.program_data .section1 { grid-column: 1; grid-row: 3; }
.program_data .section2 { grid-column: 1; grid-row: 2 }
.extra_program .program_list { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
.extra_program .program_list a:nth-child(n+7) { display: none; }

/* regroup program to 2 lines */
.program_standard .description { grid-template-columns: 5em auto auto; grid-template-rows: auto auto; align-items: start; gap: 0rem 0.5rem; }
.program_standard .time { grid-column: 1; grid-row: 1; }
.program_standard .location_slot { grid-column: 1; grid-row: 2; align-self: flex-end; }
.program_standard .event_data { grid-column: 2; grid-row: span 2; grid-template-rows: auto auto; }
.program_standard .event_data .title { margin-bottom: 0.125em; white-space: wrap; }
.program_standard .event_data .title a { display: block; }
.program_standard .event_data .tags { margin: 2px 0 0 0; grid-row: 2; align-self: flex-end; }
.program_standard .buy { grid-column: 3; grid-row: 1; justify-content: flex-end; }
.program_standard .line { padding: 0.6em 0 1em 0;  }
.program_standard .line.date { padding: 2em 0 0.7em 0 }
 .tag, .location { height: 1.8em; }
}

/* mobile styleheet */

.mobile .frame { padding: 1.5rem }
.mobile .top { padding: 0 0 1rem 0 }
.mobile .logo img { height: 2em }
.mobile .banner { padding: 0.5rem; }

.mobile .program_highlight { gap: 1.5rem; }
.mobile .top .switches { margin-top: -4px; }

.mobile .font1 { font-size: 26px; } 
.mobile .font2 { font-size: 15px; }
.mobile .font3 { font-size: 15px; }
.mobile .font4 { font-size: 7px; }
.mobile .font5 { font-size: 16px; } 
.mobile .font6 { font-size: 13px; }
.mobile .font7 { font-size: 16px; } 
.mobile .font6 { font-size: 13px; }
.mobile .page_content h2 { font-size: 26px; }

.mobile .program_standard .description { grid-template-columns: 4.25em auto auto; }
.mobile .program_standard .event_data .title { margin-bottom: 0.3rem; }
.mobile .program_standard .time { margin-bottom: 0.25rem; }

.mobile .program_highlight .subtitle { line-height: 1.2em;  }
.mobile .program_highlight .program_date { gap: 0 0.5em }
.mobile .program_highlight .tags { margin: 1.25em 0;}
.mobile .program_highlight.three, 
.mobile .program_highlight.four { grid-template-columns: repeat(2, 1fr); }

.mobile .program_filter .text { width: 60vw; padding: 0.2rem 0.5rem }
.mobile .program_filter select { width: 80vw; }

.mobile .section { gap: 1rem; }

.mobile .program_data .poster { margin-bottom: 1.5rem; }
.mobile .program_data h2 { margin-bottom: 0.2rem; }
.mobile .program_data .ticket_slot, .mobile .program_data .annotation, .mobile .program_data { margin-bottom: 1.5rem; }
.mobile .extra_program .program_list { gap: 1.5rem; }

.mobile .footer { grid-template-columns: 100%; margin: 1.5rem 0; padding: 1.5rem 0 }

.mobile .page_content .gallery img:not(.selected) { width: 48%; height: 7em; }

}
 
