/*
Theme Name: Aalto Studios
Author: Jon Fabritius
Author URI: https://jon.fabriti.us
Description: A child theme for Twenty Twenty-Four with customizations for Aalto Studios use
Requires at least: 6.5
Tested up to: 6.5
Requires PHP: 7.0
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aaltostudios
Template: twentytwentyfour
*/

	@view-transition {
	  navigation: auto;
	}

	@font-face
	{
		font-family: "Inter";
		src: url( "/wp-content/uploads/fonts/InterVariable.woff2" ) format( "woff2-variations" );
		font-weight: 100 900;
		font-style: normal;
		font-display: block;
	}

	@font-face
	{
		font-family: "Inter";
		src: url( "/wp-content/uploads/fonts/InterVariable-Italic.woff2" ) format( "woff2-variations" );
		font-weight: 100 900;
		font-style: italic;
		font-display: block;
	}

	:root
	{
		--background-card: #fff;
		--border-radius-default: 4px;
		--padding-default: 0.5rem 1rem;

		--aalto-studios-color-active: #f90;
		--aalto-studios-wordmark: url(https://studios.aalto.fi/wp-content/uploads/2024/04/aalto_studios_logotype_black_small.png);

		--aalto-logo: url(https://studios.aalto.fi/wp-content/uploads/2024/04/aaltoLogoBlack.png);

		--magics-logo: url(https://studios.aalto.fi/img/magics_rect_light.png);
	}


	body
	{
		font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;

		--wp--preset--font-size--small: 0.9rem;
		--wp--preset--font-size--medium: 1.1rem;
		--wp--preset--font-size--large: 1.5rem;
		--wp--preset--font-size--x-large: 1.8rem;
		--wp--preset--font-size--xx-large: 3rem;
		--wp--preset--font-family--body: Inter, sans-serif;
		--wp--preset--font-family--heading: Inter;

		--wp--preset--color--contrast: rgb(44,44,44);

		--wp--preset--color--base: rgb(246,246,248) !important;
		--aalto-studios-color-well: rgba(0,0,0,0.05) !important;
		--aalto-studios-color-input-well: rgba(255,255,255,1);
		--aalto-studios-color-shelf: rgba(255,255,255,0.5) !important;

		--aalto-studios-color-high-contrast: #000;
		--aalto-studios-color-low-contrast: #aaa;

		--aalto-studios-color-inverse: #eee;

		--aalto-studios-link-color: #4891df !important;

		--aalto-studios-card-background: rgba(0,0,0,0.03) !important;
		--aalto-studios-card-border-radius: 8px;
	}

	@media (prefers-color-scheme: dark)
	{
		:root
		{
			--aalto-studios-wordmark: url(https://studios.aalto.fi/wp-content/uploads/2024/04/aalto_studios_logotype_white_small.png);
			--aalto-studios-text-decoration: none;

			--aalto-logo: url(https://studios.aalto.fi/wp-content/uploads/2024/04/aaltoLogoWhite.png);

			--magics-logo: url(https://studios.aalto.fi/img/magics_rect_dark.png);
		}

		body
		{
			--wp--preset--color--contrast: #eee;
			--wp--preset--color--contrast-2: #ddd;

			--aalto-studios-link-color: #62a3ea !important;

			--wp--preset--color--base: rgb(52,52,52) !important;
			--aalto-studios-color-well: rgba(251,253,255,0.05) !important;
			--aalto-studios-color-shelf: rgba(0,0,0,0.3) !important;

			--aalto-studios-color-high-contrast: #fff;
			--aalto-studios-color-low-contrast: #888;

			--aalto-studios-color-inverse: #111;

			--aalto-studios-card-background: rgba(0,0,0,0.1) !important;
		}
	}


/* Elements */

	h1
	{
		font-weight: 600 !important;
		color: var(--aalto-studios-color-high-contrast);
	}

/* 	main .has-global-padding:has(.wp-block-post-title) h1
	{
		margin-left: 0;
		border-bottom: 1px solid #ddd;
	} */

	h2,h3,h4,h5
	{
		font-weight: 500;
		color: var(--aalto-studios-color-high-contrast);
		line-height: 1.4;
	}

	h2,h3
	{
		margin-top: 2rem !important;
	}

	h4
	{
		font-size: 1.2rem !important;
	}

	h6
	{
		font-weight: 400;
		line-height: 1.55;
		margin-bottom: 0.5rem !important;
		color: var(--aalto-studios-color-high-contrast);
	}

	a
	{
		color: var(--aalto-studios-link-color) !important;
		text-decoration: var(--aalto-studios-text-decoration);
		line-height: 1.6;
	}

	video,
	.attachment-post-thumbnail
	{
		view-transition-name: none;
		border-radius: 2px;
		box-shadow: 0 4px 8px -3px rgba(0,0,0,0.2);
		max-width: calc(100% + 4rem) !important;
		width: calc(100% + 4rem) !important;
		margin: 0 -2rem 0 -2rem !important;
		opacity: 0;
		transition: .3s opacity ease-in;
	}

	.attachment-post-thumbnail.as-loaded,
	.block-editor-page .attachment-post-thumbnail,
	.wp-block-media-text__media .as-loaded
	{
		transition: .3s opacity ease-in;
		opacity: 1;
	}

	.inStack
	{
		box-shadow: none !important;
	}

	.inStack.stackTop
	{
	}

	video.as-loaded,
	.block-editor-page video
	{
		transition: 2.5s opacity ease-in-out;
		opacity: 1;
	}

	li
	{
		margin-bottom: 0.5rem;
		line-height: 1.4;
	}

	li .attachment-post-thumbnail
	{
		margin: 0 !important;
		width: 100% !important;
	}

	.columns-4 h2
	{
		margin-top: 0 !important;
	}

/* Furniture */

	.default-featured-img
	{
		filter: saturate(0.5);
	}

	.ccfic-text
	{
		float: right;
		color: var(--aalto-studios-color-low-contrast);
		padding: 0.5rem;
		margin: 0;
		font-size: 0.9rem;
	}

	li.has-post-thumbnail .ccfic
	{
		display: none;
	}

/* Header and Navigation */

	header
	{
		position: sticky;
		top: -22px;
		z-index: 9999;
	}

	header > div
	{
		padding-bottom: 0 !important;
	}

	header > div > div
	{
		padding-bottom: 10px !important;
	}

	.wp-block-site-title
	{
		width: 180px;
		height: 24px;
		font-size: 0;
		color: transparent !important;
		background-image: var(--aalto-studios-wordmark);
		background-size: 180px;
		background-repeat: no-repeat;
	}

	.wp-block-site-title a
	{
		width: 180px;
		height: 24px;
		display: inline-block;
		color: transparent !important;
	}

	header nav
	{
		margin-left: -0.25rem !important;
	}

	.navigation-container-inner
	{
		gap: 0.6rem;
	}

	.wp-block-navigation__submenu-icon
	{
		display: none !important;
	}

	.wp-block-navigation .wp-block-navigation-item
	{
		position: static;
	}

	.wp-block-navigation .wp-block-navigation-item > button,
	.wp-block-navigation__responsive-container-content > ul > li > a
	{
		display: inline-block;
		border-radius: 4px;
		margin: 0 0 0 -0.75rem !important;
		padding: 0 1rem !important;
	}

	.wp-block-navigation__container,
	.wp-block-navigation__responsive-container-content
	{
		--navigation-layout-justify: flex-start !important;
		justify-content: start !important;
	}

	.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container
	{
 		left: -3rem;
		right: -3rem;
		padding: 1rem 2rem;
/* 		max-width: 1440px; */
		background-color: var(--wp--preset--color--base) !important;
		border: 0 solid;
		display: block;
		filter: blur(0);
/* 		transition: 0 all ease-in; */
		transition: opacity 0 ease-in, filter 0 ease-in !important;
		box-shadow: 0 4px 6px -2px rgba(0,0,0,0.2);
		z-index: 2;
	}

	button.closing + span + ul
	{
		opacity: 0 !important;
		filter: blur(8px) !important;
/* 		transition: .5s all ease-in !important; */
		transition: opacity .5s ease-in, filter .5s ease-in !important;
		z-index: 1 !important;
	}

	.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li
	{
		display: inline-block;
		width: calc(25% - 3px);
/* 		min-height: 200px; */
		vertical-align: top;
		margin: 0 1px 1px 0;
		border-radius: 4px;
		padding: 0.5rem 0;
	}

	.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:nth-child(5)
	{
		margin-right: 0;
	}

	.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:nth-child(9)
	{
		margin-right: 0;
	}

	.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child
	{
		display: block;
		min-height: 0;
		width: calc(100% - 0.5rem);
	}

	.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child a
	{
		color: var(--wp--preset--color--contrast) !important;
		font-size: 1.3rem;
		font-weight: 500;
		pointer-events: none;
	}

	.wp-block-navigation .has-child .wp-block-navigation__submenu-container > .wp-block-navigation-item > .wp-block-navigation-item__content
	{
		display: inline-block;
	}

	:where(.wp-site-blocks *:focus),
	:where(.wp-site-blocks * button:active)
	{
		outline-style: none !important;
 		background: inherit;
	}

	.hasOpenMenu
	{
		color: var(--aalto-studios-color-active) !important;
	}

	.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li a .wp-block-navigation-item__label
	{
		font-weight: 500;
	}

	.wp-block-navigation-item__description
	{
		display: block !important;
		color: var(--wp--preset--color--contrast) !important;
		font-size: var(--wp--preset--font-size--small);
	}

	a.wp-block-navigation-item__content
	{
/* 		color: var(--wp--preset--color--contrast) !important; */
		text-decoration: none !important;
	}

	.as-contact-menu-item a
	{
		color: var(--wp--preset--color--contrast) !important;
	}

	.as-navigation-content-row
	{
		position: relative;
	}

	.is-menu-open .wp-block-navigation__responsive-close
	{
		background: transparent !important;
	}

	#aaltoLogo
	{
		position: absolute;
		top: 22px;
		right: -3px;
		width: 94px;
		height: 32px;
		background-image: var(--aalto-logo);
		background-repeat: no-repeat;
		background-size: 38px;
		background-position: right top;
		overflow: hidden;
		z-index: 1;
	}

	#aaltoLogo a
	{
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		color: transparent !important;
		font-size: 0;
		border: 0 solid transparent;
	}

	#magicsLogo
	{
		position: absolute;
		top: 14px;
		right: 53px;
		width: 107px;
		height: 46px;
		background-image: var(--magics-logo);
		background-repeat: no-repeat;
		background-size: 86px;
		background-position: right top;
		overflow: hidden;
		z-index: 2;
	}

	#magicsLogo a
	{
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		color: transparent !important;
		font-size: 0;
		border: 0 solid transparent;
	}

	/* .logged-in #magicsLogo
	{
		display: block;
	} */

/* Footer */

	footer h2
	{
		margin-top: 0 !important;
	}

	.as-footer-aalto-logo
	{
		position: relative;
		width: 64px;
		height: 40px;
		background-image: var(--aalto-logo);
		background-repeat: no-repeat;
		background-size: 64px;
		background-position: right top;
		overflow: hidden;
		margin-bottom: 34px !important;
	}

	.as-footer-aalto-logo a
	{
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		color: transparent !important;
		font-size: 0;
		border: 0 solid transparent;
	}

/* Front page tweaks */

	.home figure.wp-block-video
	{
		width: calc(100% + 4rem);
/* 		background-image: url(https://studios.aalto.fi/wp-content/uploads/2024/04/aalto_studios_logotype_white.png); */
		background-image: url(	https://studios.aalto.fi/wp-content/uploads/2025/11/aalto_studios_hero_text.png);
		background-size: contain;
		background-repeat: no-repeat;
		background-position: center center;
		aspect-ratio: 16 / 9;
		overflow: visible
	}


/* Language selector */

	.wpml-language-switcher-navigation-block
	{
	}

	body header .wp-block-navigation .wpml-language-switcher-navigation-block ul.horizontal-list
	{
		gap: 0 !important;
	}

	.wpml-language-switcher-navigation-block.wpml-ls-list
	{
		padding: 0 !important;
		margin-left: -4px !important;
	}

	.wpml-language-switcher-navigation-block .wp-block-navigation-item__label
	{
		text-transform: uppercase;
		padding: 0 0.5rem;
		border-right: 1px solid;
	}

	.wpml-language-switcher-navigation-block li:last-child .wp-block-navigation-item__label
	{
		border-color: transparent !important
	}

	[data-wpml="language-item"]:first-of-type
	{
		margin-top: 0 !important;
	}

	.wpml-language-switcher-navigation-block a
	{
		color: var(--wp--preset--color--contrast) !important;
	}


/* Tables */

	.wp-block-table.is-style-stripes tbody tr:nth-child(2n+1)
	{
		background-color: var(--aalto-studios-color-well) !important;
/* 		border-bottom: 1px solid var(--aalto-studios-color-shelf) !important; */
	}


/* Search results */

	.afmc_person .wp-block-post-date
	{
		display: none;
	}

	.search-results .aalto-person-detail-listing
	{
		margin-bottom: 0.5rem !important;
		margin-top: -1rem !important;
	}


/* Inputs */

	.wp-block-search__inside-wrapper
	{
/* 		max-height: 2.5rem !important; */
	}

	.wp-block-search__inside-wrapper input
	{
		-webkit-appearance: none;
		padding: 0.75rem 0.75rem !important;
		min-height: 44px !important;
		border-radius: 8px !important;
	}

	.wp-block-search button
	{
		border-radius: 8px !important;
	}

	.wp-block-search__inside-wrapper input:focus
	{
		background: var(--aalto-studios-color-input-well) !important;
		box-shadow: 0 3px 4px -1px rgba(0,0,0,0.1);
	}

	.aalto-studios-search-page-inputs
	{
		margin-top: -8px !important;
	}

	main
	{
		opacity: 1;
		filter: blur(0) saturate(1);
/* 		transition: .5s all ease-in !important; */
		transition: opacity .5s ease-in, filter .5s ease-in !important;
		padding-top: 20px;
	}

	main.menuDimmed
	{
		opacity: 0.5;
		filter: blur(8px) saturate(1);
/* 		transition: 1.5s all linear !important; */
		transition: opacity 1.5s ease-in, filter 1.5s ease-in !important;
	}

	main.exitDimmed
	{
		filter: blur(8px) saturate(0);
/* 		transition: 0.5s all linear; */
		transition: opacity .5s ease-in, filter .5s ease-in !important;
	}


/* Main content listings */

	.aalto-studios-main-product-listing li,
	.aalto-studios-search-results li
	{
		min-height: 310px !important;
		background: var(--aalto-studios-card-background) !important;
		border-bottom-left-radius: 8px !important;
		border-bottom-right-radius: 8px !important;
	}


	.aalto-studios-main-product-listing li > figure img,
	.aalto-studios-search-results li > figure img
	{
		border-bottom-left-radius: 0;
		border-bottom-right-radius: 0;
		box-shadow: none;
	}

	.aalto-studios-main-product-listing li > div,
	.aalto-studios-search-results li > div
	{
		padding: 1rem 1rem 1rem 1rem !important;
		z-index: 99999999999999 !important;
	}

	.aalto-studios-main-product-listing li > div:last-child
	{
		margin-top: -1rem !important;
		padding: 2rem 1rem 1.5rem 1rem !important;

	}

	.aalto-studios-main-product-listing li .wp-block-post-date + .wp-block-post-excerpt
	{
		margin-top: 0 !important;
		padding-top: 0 !important;
	}


	.aalto-studios-main-product-listing h4
	{
		flex-basis: min(1rem, 3vw);
	}

	.home .aalto-studios-main-product-listing li
	{
		min-height: 310px !important;
		background: var(--aalto-studios-card-background) !important;
	}

	.wp-block-post-excerpt
	{
		word-break: break-word;
	}

	.aalto-studios-main-product-listing li:hover
	{
/* 		transition: 0.2s all linear;
		box-shadow: 0 0 2px var(--aalto-studios-color-high-contrast); */
/* 		cursor: pointer; */
	}

/* Sidebar */

	.as-default-columns-sidebar
	{
		padding-left: 1.25rem;
		padding-top: 4rem;
	}

	.as-default-columns-sidebar h5
	{
/* 		margin-top: 1.5rem !important; */
	}

	.as-default-columns-sidebar .afmc_person h5
	{
		margin-top: 0!important;
	}

/* Features */

	.aalto-studios-card-empty
	{
		background: var(--aalto-studios-card-background);
		border-radius: var(--aalto-studios-card-border-radius);
		padding: 1.5rem 1.5rem;
	}

/* Frontpage news */

/* Frontpage focus areas */

	.wp-block-mfb-meta-field-block
	{
		display: none;
	}

	.single-afmc_person .entry-content.has-global-padding
	{
		padding-left: 0;
		padding-right: 1rem;
	}

	.aalto-studios-frontpage-focusareas li
	{
		cursor: pointer;
	}

/* Course space bookings page */

	.page-id-13946 #courseFilter
	{
	  font-size: 1.1rem;
	  padding: 0.5rem 0.5rem;
	  margin-bottom: 0.5rem;
	  border: 0.5px solid rgb(128,128,128);
	  border-radius: 12px;
	  background: white !important
	}

	.page-id-13946 #courseFilterResults
	{
	  margin: 0;
	  padding: 1rem;
	  border: 0.5px solid rgb(128,128,128);
	  border-radius: 8px;
	  max-height: 320px;
	  overflow: scroll;
	  opacity:0
	}

	.page-id-13946 #courseFilterResults.shown
	{
	  opacity: 1;
	}

	.page-id-13946 #courseFilterResults h4
	{
		margin-top: 0;
		margin-bottom: 0.5rem;
	}

	.page-id-13946 #courseFilterResults li
	{
	  border-bottom: 0.5px solid rgb(128,128,128);
	  font-size: 1rem;
	  padding: 0.2rem 0.5rem 0.4rem 0;
	  margin: 0;
	  margin-top: 0.2rem !important;
	  cursor: pointer;
	  list-style-type: none;
	  color: var(--aalto-studios-link-color);
	}

	.page-id-13946 #courseFilterResults li:first-child
	{
	  padding-top: 0;
	  margin-top: 0 !important;

	}

	.page-id-13946 #courseFilterResults li:last-child
	{
	  border-bottom: 0.5px solid transparent;
	}

	.page-id-13946 .calendar-container
	{
	  min-height: 750.5px;
/* 	  max-height: 760px; */
	}

	.page-id-13946 #courseCalendarAddresses
	{
		font-size: 1rem;
	}

	.page-id-13946 .copyable
	{
		cursor: copy;
	}

	.page-id-13946 .r34ics-ajax-container.loading::before
	{
		top: 320px !important;
		color: #09f !important;
		background: #09f !important;
	}

	.page-id-13946 .ics-calendar-month-grid .today .day .phone_only
	{
/* 		background: transparent !important; */
		width: 100% !important;
		padding: 0 !important;
		border-radius: 0 !important;
		margin: 0 !important;
/* 		color: var(--aalto-studios-color-high-contrast) !important; */
	}

	.page-id-13946 .ics-calendar-month-grid .today .day .phone_only span
	{
		background: transparent !important;
		width: auto !important;
		height: auto !important;
		padding: 0 !important;
		margin: 0 !important;
		border-radius: 0 !important;
		color: var(--aalto-studios-color-high-contrast) !important;
	}

	.page-id-13946 .ics-calendar-select,
	.page-id-13946 .ics-calendar-select option
	{
		background: #ccc !important;
		border: 1px solid;
		border-radius: 8px;
	}

	@media screen and ( max-width: 600px )
	{

		.home .wp-block-media-text .wp-block-media-text__content
		{
			padding: 1rem 0 1rem 0 !important;
		}

		.aalto-studios-frontpage-focusareas .wp-block-post-featured-image
		{
			display: none;
		}

	}

	@media screen and ( min-width: 601px )
	{
		.home .wp-block-media-text .wp-block-media-text__content:nth-child(even)
		{
			padding-right: 0 !important;
		}

		.home .wp-block-media-text .wp-block-media-text__content:nth-child(odd)
		{
			padding-left: 0 !important;
		}

		.home .wp-block-media-text .wp-block-heading
		{
			padding-top: 0 !important;
			margin-top: 2rem !important;
		}

		.home .wp-block-media-text__content .wp-block-group > h3,
		.home .wp-block-media-text__content .wp-block-group > p
		{
			margin-left: 0.5rem !important;
		}


		.aalto-studios-frontpage-focusareas
		{
			margin-left: -2rem !important;
			margin-right: -2rem !important;
		}

		/* .aalto-studios-frontpage-focusareas .wp-block-post-featured-image
		{
			border: 0 solid;
			position: absolute;
			top: 0;
			right: 0;
			bottom: 0;
			left: 0;
			margin: 0 !important;
			opacity: 0;
		}

		.aalto-studios-frontpage-focusareas .wp-block-post-featured-image:hover
		{
			opacity: 1 !important;
			transition: .5s opacity ease-in;

		}

		.aalto-studios-frontpage-focusareas .wp-block-post-featured-image img
		{
			height: 100%;
			pointer-events: none;
		} */


		.home .wp-block-media-text .aalto-studios-main-product-listing li
		{
			min-height: 0 !important;
			border-radius: 8px;
			position: relative;
		}

		.home .wp-block-post-template-is-layout-grid
		{
			gap: 12px !important;
		}

		.home .wp-block-post-template-is-layout-grid .wp-block-post-title a
		{
			font-size: 1rem !important;
			line-height: 1.4 !important;
		}

		.home.hasResizePortraits .wp-block-media-text__media
		{
			background: transparent;
			text-align: center;
		}

		.home.hasResizePortraits .wp-block-media-text__media
		{
			position: sticky;
			top: 122px;
		}

		.home.hasResizePortraits .wp-block-media-text__
		{

		}

	}

/* Latest Posts Sidebar Block */

	.aalto-studios-card-empty .wp-block-latest-posts li,
	.aalto-studios-sidebar-list li
	{
		margin-bottom: 1rem !important;
	}

	.aalto-studios-card-empty:has(iframe)
	{
		padding: 0;
	}

	.aalto-studios-card-empty:has(iframe).neutral
	{
		padding: 1.5rem 1.5rem;
	}

	.as-external-page-embed
	{
		min-height: 280px;
	}

	.as-external-page-embed blockquote
	{
		display: none !important;
	}

	iframe
	{
		opacity: 1;
	}

	iframe.as-loaded,
	.block-editor-page iframe,
	.editor-styles-wrapper iframe
	{
		opacity: 1 !important;
		transition: .5s opacity ease-in;
	}

	.wp-embedded-content iframe
	{
		background: transparent;
		border-radius: var(--aalto-studios-card-border-radius);
		min-height: 270px;
	}


/* User guides */

/* 	.single-userguide .wp-block-post-featured-image
	{
		display: none;
	} */

/* People listings */

	.aalto-person-detail-listing
	{
		margin-top: 0 !important;
	}

	.aalto-person-detail-listing__col
	{
		margin-top: 0.5rem !important;
	}

	.aalto-person-detail-listing_title,
	.aalto-person-detail-listing_email,
	.aalto-person-detail-listing_phone
	{
		font-size: 0.9rem;
		margin: 0 0 0.1rem 0;
	}

	.aalto-person-detail-listing_title
	{
		font-weight: 600;
	}


/* ICS Calendar */

	.ics-calendar-month-grid
	{
		background-color: var(--aalto-studios-color-shelf) !important;
		margin-left: -2rem !important;
		width: calc(100% + 2rem) !important
	}

	.ics-calendar-month-grid td, .ics-calendar-month-grid th
	{
  		background: transparent !important;
	}

	.ics-calendar-month-grid th
	{
		color: var(--aalto-studios-color-contrast) !important;
	}

	.ics-calendar-month-grid td,
	.ics-calendar-month-grid th
	{
/* 		border: 1px solid var(--aalto-studios-color-low-contrast) !important; */
	}

	section article .ics-calendar-month-grid th.week-number
	{
		background-color: var(--wp--preset--color--base) !important;
		border-top-color: transparent !important;
		border-bottom-color: transparent !important;
		border-left-color: transparent !important;
		width: 2.7em!important;
		padding: 0.1rem !important;
		font-style: oblique;
		color: var(--aalto-studios-color-low-contrast) !important;
	}

	.ics-calendar-month-grid .day
	{
  		font-weight: 700 !important;
  		color: var(--aalto-studios-color-high-contrast) !important;
		background: var(--aalto-studios-color-well) !important;
	}

	.ics-calendar-month-grid .today .day
	{
		background: #09f !important;
		color: white !important;
	}

	.ics-calendar-month-grid .today .day *
	{
		color: #fff !important;
		width: 24px !important;
		height: 24px !important;
		padding: 0.2rem !important;
	}

	.ics-calendar .event
	{
  		color: var(--aalto-studios-color-high-contrast) !important;
		padding: 1rem 0.5rem 1.1rem 0.5rem !important;
	}

	table.ics-calendar-month-grid tbody .events .title,
	table.ics-calendar-month-grid .events .time
	{
		font-size: 0.85rem !important;
	}

	.ics-calendar-month-grid td
	{
		  background: rgb(255,255,255) !important;
	}

	.ics-calendar-month-grid .past,
	.ics-calendar-month-grid .off
	{
		background-color: var(--aalto-studios-color-well) !important;
	}

	.ics-calendar-select
	{
		-webkit-appearance: none !important;
		padding: 0.5rem 0.5rem !important;
	}

	.ics-calendar .event .descloc *
	{
		font-size: 0.85rem !important;
	}

	.ics-calendar .event .descloc .eventdesc,
	.ics-calendar .event .descloc .eventdesc p
	{
		background: transparent !important;
		margin-top: 0 !important;
	}

	@media (prefers-color-scheme: dark)
	{
		.ics-calendar-month-grid td
		{
			  background: rgb(60, 60, 60) !important;
		}

		.ics-calendar-month-grid td,
		.ics-calendar-month-grid th
		{
			border: 1px solid var(--aalto-studios-color-shelf) !important;
		}

		.ics-calendar .event .descloc
		{
			background: #444 !important;
		}
	}

	@media screen and (max-width: 782px)
	{
		.ics-calendar .event .descloc
		{
			background: transparent !important;
		}
	}

/* Table of contents */

	#ez-toc-container
	{
		background: transparent !important;
		border: 0 solid !important;
		border-radius: 0 !important;
		-webkit-box-shadow: none !important;
		box-shadow: none !important;
		display: table !important;
		margin: 0 !important;
		padding: 0 !important;
		position: relative !important;
		width: auto !important;
	}

	.ez-toc-title
	{
		font-size: var(--wp--preset--font-size--medium);
		font-weight: 500;
	}

	.ez-toc-list
	{
		margin-top: 0.5rem !important;
		padding-left: 1rem !important;
	}

	.ez-toc-list,
	.ez-toc-list ul
	{
		list-style: disc !important;
		margin-left: 0.25rem !important;
	}

	.ez-toc-list ul
	{
		padding-left: 0.75rem !important;
	}

	.ez-toc-list li
	{
		font-size: 0.9rem;
		list-style: disc !important;
		overflow: initial !important;
	}

	.ez-toc-list li li
	{
	/* 	padding-left: 0.25rem !important; */
		margin-left: 0.25rem !important;
		list-style: disc !important;
	/* 	overflow: initial !important; */
	}

/* Embedded content */

	.wp-embed
	{
		background: var(--wp--preset--color--base) !important;
		background: transparent !important;

		color: var(--wp--preset--color--contrast) !important;
		border: 0 solid;
	}

	p.wp-embed-heading
	{
		font-size: var(--wp--preset--font-size--medium) !important;
	}

	.wp-embed-footer
	{
		display: none;
	}


/* People filter */

	#personFilter
	{
		-webkit-appearance: none;
		width: 100%;
		padding: 1rem;
		font-size: 1rem;
		border-radius: 24px;
		border: 1px solid var(--aalto-studios-color-high-contrast);
		background-color: var(--wp--preset--color--base) !important;
		color: var(--aalto-studios-color-high-contrast);
/* 		position: sticky;
		top: 120px; */
		z-index: 9999;
	}

	#personFilter::placeholder
	{
		color: var(--aalto-studios-color-high-contrast)
	}

	.as-person .taxonomy-post_tag
	{
		display: none;
	}

	.as-person.match
	{

	}

	li:has(.as-person.no-match)
	{
		display: none;
	}


/* Images and galleries */

	.aalto-studios-downloadable-gallery .wp-element-caption
	{
		text-align: right !important;
		opacity: 0.8;
		-webkit-backdrop-filter: blur(4px);
		backdrop-filter: blur(4px)
	}

	.aalto-studios-downloadable-gallery .wp-element-caption a
	{
		padding: 0.1rem 0.5rem;
		background: var(--wp--preset--color--base) !important;
		border-radius: 12px;
		text-transform: uppercase;
		font-size: 0.7rem !important;
		color: var(--aalto-studios-color-high-contrast) !important;
		font-weight: 700 !important;
	}

	.wp-lightbox-overlay,
	.wp-lightbox-overlay *,
	.wp-lightbox-overlay.zoom.active,
	.wp-lightbox-overlay.zoom.active *,
	.wp-lightbox-overlay.show-closing-animation
	{
		animation: none !important;
		transition: none !important;
	}

	.wp-lightbox-overlay .close-button,
	.wp-lightbox-overlay .close-button svg
	{
		color: #fff !important;
		fill: #fff !important;
		width: 44px !important;
		height: 44px !important;
	}

	.lightbox-image-container,
	.scrim
	{
		background-color: rgba(0,0,0,0.8) !important;
		-webkit-backdrop-filter: blur(8px) !important;
		backdrop-filter: blur(8px) !important;
		opacity: 1 !important;
	}

	.wp-block-media-text__media
	{
		background-color: var(--aalto-studios-card-background);
	}

	.wp-block-media-text__media img
	{
		view-transition-name: none;
		opacity: 0;
		transition: .5s opacity ease-in;
		box-shadow: 0 4px 8px -3px rgba(0,0,0,0.2);
	}

	figure.wp-block-image figcaption,
	.wp-block-image figcaption
	{
		background: var(--wp--preset--color--base) !important;
		color: var(--aalto-studios-color-high-contrast) !important;
	}

	.aalto-studios-rounded-media img
	{
		border-radius: 8px;
	}

/* Print versions */

	@media print
	{
		.single-userguide main > div:has(h1)
		{
			margin-bottom: 1rem !important;
		}

		.single-userguide h1
		{
			font-size: 2.2rem !important;
		}

		.single-userguide header,
		.single-userguide footer,
		.single-userguide .as-default-columns-sidebar
		{
			display: none;
		}

		.single-userguide .as-default-columns-main-content
		{
			width: 100% !important;
			flex-basis: 100% !important;
		}
	}


/* Editor */

	.editor-editor-canvas__post-title-wrapper h1
	{
		max-width: 1280px;
	}

	.editor-styles-wrapper .editor-visual-editor__post-title-wrapper h1
	{
		max-width: auto !important;
		margin-left: 0 !important;
	}

	.as-editThisPostButton
	{
		position: fixed;
		left: 24px;
		bottom: 24px;
		width: 180px;
		text-align: center;
		padding: 12px;
		border-radius: 8px;
		background: #0a3 !important;
		z-index: 999999;
	}

	.as-editThisPostButton a
	{
		color: white !important;
	}

/* Screen size variations */

	@media screen and ( max-width: 1200px ) and (min-width: 601px)
	{
		.wp-block-navigation .wp-block-navigation-item
		{
			font-size: 1rem !important
		}

	}

	@media screen and (max-width: 1123px)
	{
		:root
		{
			--wp--preset--font-size--xx-large: 1.6rem !important;
		}

		body
		{
			--wp--preset--font-size--small: 1.1rem !important;
		}

		header
		{
			top: -16px;
		}

		footer
		{
			margin-top: 3rem !important;
			border-top: 1px solid var(--aalto-studios-color-shelf);
		}

		.entry-content
		{
			margin-top: 0 !important;
		}

		h1
		{
			margin-top: 2.25rem !important;
			font-size: 1.2rem;
		}

		body main h1.has-xx-large-font-size
		{
			font-size: 1.6rem !important;
		}

		h2
		{
			font-size: 1.3rem;
			margin-top: 1rem !important;
		}

		h3
		{
			font-size: 1.2rem;
			margin-top: 0.5rem !important;

		}

		header .wp-block-site-title
		{
			position: absolute;
			top: 22px;
			margin-left: 48px;
		}

		#aaltoLogo
		{
			top: 22px !important;
			left: auto !important;
			right: auto !important;
			width: 41px !important;
			height: 24px !important;
		}

		#magicsLogo
		{
			display: none !important;
		}

		.wp-container-core-group-is-layout-4.wp-container-core-group-is-layout-4
		{
			width: 100% !important;
			flex-direction: row !important;
			justify-content: space-between !important;
		}

		.main-navigation
		{
			justify-content: flex-end !important;
			width: 100%;
			position: absolute;
			margin-top: 32px;
			top: 12px;
			right: 0;
		}

		.wp-container-core-group-is-layout-90752e8f
		{
			flex-direction: initial !important;
		}

		.wp-block-navigation__responsive-container-open:not(.always-shown)
		{
			display: flex !important;
		}

		.wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open)
		{
			display: none !important;
			transition: none !important;
		}

		.wp-block-navigation:not(.has-background) .wp-block-navigation__responsive-container.is-menu-open
		{
			background-color: var(--wp--preset--color--base) !important;
		}

		header nav ul.wp-block-navigation__container
		{
			text-align: right;
			width: 100%;
			margin-top: 2rem;
		}

		header nav ul.wp-block-navigation__submenu-container
		{
			width: 100% !important;
			max-width: 480px !important;
			padding: 0 1.5rem !important;
			/* border: 1px solid var(--aalto-studios-color-low-contrast) !important; */
			border-right: 1px solid var(--aalto-studios-color-active) !important;
			border-radius: 0;
			margin-bottom: 1rem !important;
/* 			margin-left: 1rem !important; */
			box-shadow: none !important;
		}

		header > div
		{
			padding-bottom: 10px !important;
		}

		.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child
		{
			padding: 0 !important;
			color: var(--aalto-studios-color-low-contrast) !important;
		}

		.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child a span
		{
			font-size: 1rem !important;
			color: var(--wp--preset--color--contrast);
		}

		.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li
		{
			width: 100% !important;
			min-height: 0 !important;
		}

		.wp-block-navigation .wp-block-navigation-link .wp-block-navigation-item__label
		{
			display: inline-block !important;
			color: var(--aalto-studios-link-color);
			text-align: left;
			width: 100%;
		}

		.wp-block-navigation .wp-block-navigation-item button.wp-block-navigation-item__content,
		.wp-block-navigation__responsive-container-content > ul > li > a
		{
			margin-right: 0 !important;
			padding-right: 0 !important;
			background-color: transparent !important;
			margin-bottom: 1rem !important;
		}

		.wp-block-navigation__submenu-container
		{
		}

		.wp-block-navigation__container > .wp-block-navigation-item:not(.has-child) > a .wp-block-navigation-item__label
		{
			color: var(--wp--preset--color--contrast) !important;

		}

		.wp-block-navigation__submenu-container .wp-block-navigation-item__content
		{
			min-width: 100%;
		}

		.wp-block-navigation-item__content[aria-expanded="false"] + span + ul
		{
			display: none !important;
		}

		.wp-block-navigation-item__description
		{
	/* 		max-width: 300px; */
			text-align: left;
			font-size: 1rem !important;

		}

	/* 	.wp-block-search__icon-button
		{
			margin-right: 0 !important;
			margin-bottom: 1.1rem;
		} */

		.wpml-language-switcher-navigation-block
		{
			margin-right: -0.5rem;
		}

		.closing + span + .wp-block-navigation__submenu-container
		{
			transition: none !important;
			display: none !important;
		}

		/* People filter */

		#personFilter
		{
			top: 64px;
		}

		/* Sidebar */

		.as-default-columns-sidebar
		{
			padding-left: 0;
			padding-top: 0;
		}


		/* Frontpage news */

		.home .aalto-studios-news-area.aalto-studios-main-product-listing ul
		{
			display: block;
			white-space: nowrap !important;
			overflow: scroll;
			scroll-snap-type: x mandatory;
		}

		.home .aalto-studios-news-area.aalto-studios-main-product-listing li
		{
			display: inline-block !important;
			white-space: initial;
			vertical-align: top !important;
			margin-right: 8px;
			width: 80%;
			min-height: 380px !important;
			scroll-snap-align: center;
		}


		/* Media and Text Block */

		.home .wp-block-media-text.is-stacked-on-mobile
		{
			grid-template-columns: 100% !important;
		}

		.home .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media
		{
			grid-column: 1;
			grid-row: 1;
		}

		.home .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content
		{
			grid-column: 1;
			grid-row: 2;
		}

		.home .wp-block-media-text .wp-block-media-text__content,
		.home .wp-block-media-text .wp-block-media-text__content > div
		{
			padding: 0 !important;
		}

	    .home .wp-block-media-text .aalto-studios-main-product-listing li
		{
			min-height: 0 !important;
		}

		.home .wp-block-media-text h3
		{
			margin-top: 2rem !important;
		}

		.home figure.wp-block-video
		{
			width: calc(100% + 0rem);
		}

		.home video
		{
			width: calc(100% + 4rem) !important;
			margin: 0 0rem 0 -2rem !important;
		}
	}


	@media (min-width: 1124px)
	{
		.wp-block-navigation__responsive-container-open:not(.always-shown)
		{
			display: none !important;
		}

		.wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open)
		{
			display: block !important;
			width: 100%;
			position: relative;
			z-index: auto;
			background-color: inherit;
		}
	}

/* High contrast mode without forced colors */

	@media (prefers-contrast: high) and (forced-colors: none),
		   (prefers-contrast: more) and (forced-colors: none)
		   {
				*
		   		{
				  		color: #000 !important;
				  		background-color: #fff !important
		   		}

		   		* .has-base-background-color
		   		{
				  		color: #000 !important;
				  		background-color: #fff !important
		   		}

		   		body
		   		{
				  		--aalto-studios-card-background: #fff !important;
				  		--wp--preset--color--base: #fff !important;
		   		}

		   		.as-default-columns-main-content .wp-block-post,
		   		.home .wp-block-post
		   		{
				  		border: 1px solid #000;
		   		}

		   		.wp-block-group
		   		{
				  		background-color: transparent !important
		   		}

		   		.as-default-columns-sidebar .wp-block-group
		   		{
			   		border: 1px solid #000;
		   		}

		   		a,
		   		a > span,
		   		nav button,
		   		nav button span
		   		{
				  		color: #06f !important;
				  		text-decoration: underline !important;
		   		}

		   		.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child a,
		   		.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child a span,
		   		nav a span + span
		   		{
				  		color: #000 !important;
				  		text-decoration: none !important;
		   		}

		   		input,
		   		button.wp-block-search__button
		   		{
			   		color: #000 !important;
			   		background-color: #fff !important;
					border: 1px solid #000 !important;
		   		}

			   .wp-block-site-title a,
			   #aaltoLogo a
			   {
				   background: transparent !important;
			   }
		   }

	@media (prefers-contrast: high) and (forced-colors: none) and (prefers-color-scheme: dark),
		   (prefers-contrast: more) and (forced-colors: none) and (prefers-color-scheme: dark)
		   {
				*
				{
   					color: #fff !important;
   					background-color: #000 !important
				}

				* .has-base-background-color
				{
   					color: #fff !important;
   					background-color: #000 !important
				}

				body
				{
   					--aalto-studios-card-background: #000 !important;
   					--wp--preset--color--base: #000 !important;
				}

				.as-default-columns-main-content .wp-block-post,
				.home .wp-block-post
				{
   					border: 1px solid #fff;
				}

				.wp-block-group
				{
   					background-color: transparent !important
				}

				.as-default-columns-sidebar .wp-block-group
				{
					border: 1px solid #fff;
				}

				a,
				a > span,
				nav button,
				nav button span
				{
   					color: #9cf !important;
   					text-decoration: underline !important;
				}

				.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child a,
				.wp-block-navigation.items-justified-right .wp-block-navigation__container .has-child .wp-block-navigation__submenu-container li:first-child a span,
				nav a span + span
				{
   					color: #fff !important;
   					text-decoration: none !important;
				}

				input,
				button.wp-block-search__button
				{
					color: #000 !important;
					background-color: #fff !important;
					border: 1px solid #fff;
				}
		   }

/* Loader */

/* .loader
{
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg,#0001 33%,#0005 50%,#0001 66%) #f2f2f2;
  background-size: 300% 100%;
  animation: l1 1s infinite linear;
}

@keyframes l1
{
  0% {background-position: right}
} */


/* Screens listing views */

body.page-template-wp-custom-template-screens-listing
{
	background: none;
	padding: 0;
	margin: 0;
}

body.page-template-wp-custom-template-screens-listing img
{
	opacity: 1 !important;
}

body.page-template-wp-custom-template-screens-listing #wpadminbar
{
	display: none;
}

body.page-template-wp-custom-template-screens-listing .screens-listing-container
{
	height: 640px;
	margin: 0;
    display: flex;
    align-items: center;
	justify-content: flex-start;

}

body.page-template-wp-custom-template-screens-listing .screens-listing-container *
{
	color: #fff !important
}


/* Now Streaming */

#nowStreamingBox
{
	display: block !important;
}

/* Admin related */

.block-library-html__edit .block-editor-plain-text
{
	max-height: 9999px;
}

.components-resizable-box__container
{
	height: 720px !important;
}

/* Cinema Sheryl Events */

.cinema-sheryl-events *
{
	max-width: 100%;
	height: auto;
}

.cinema-sheryl-events .kinola-event
{
	display: inline-block;
	width: calc(50% - 1rem);
	vertical-align: top;
	margin-bottom: 1rem;

}

.cinema-sheryl-events .kinola-event:nth-child(odd)
{
	margin-right: 1rem !important;

}

.cinema-sheryl-events img
{
	box-shadow: 0 4px 8px -3px rgba(0,0,0,0.4);
	min-height: 252px;
}

.cinema-sheryl-events h3
{
	margin: 8px 0 !important;
	font-size: 1rem !important;
}

.cinema-sheryl-events .kinola-event-date,
.cinema-sheryl-events .kinola-event-title
{
	display: block;
}

.cinema-sheryl-events .kinola-event-tickets
{
	display: none;
}

/* Presentation Overlay */

#ASPresentationOverlay
{
	opacity: 0;
	user-select: none;
	pointer-events: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 0;
	height: 0;
	overflow: hidden;
	transition: background 1.5s ease-in, opacity 1.5s ease-in, backdrop-filter 1.5s ease-in !important;
}

#ASPresentationOverlay.visible
{
	opacity: 1;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	right: 0;
	bottom: 0;
	z-index: 9999999;
	background: rgba(0,0,0,0.5);
	backdrop-filter: blur(12px);
	transition: background 1.5s ease-in, opacity 1.5s ease-in, backdrop-filter 1.5s ease-in !important;
	pointer-events: all;
}

#ASPresentationOverlay iframe
{
	display: none;
}


#ASPresentationOverlay.visible iframe
{
	display: block;
	position: absolute;
	top: 4rem;
	left: 4rem;
	width: calc(100% - 8rem);
	height: calc(100% - 8rem);
	right: 4rem;
	bottom: 4rem;
	border: 0 solid;
}

.presentation-people-cards
{
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 1rem;
	width: 100%;
	box-sizing: border-box;
}

.presentation-person-card
{
	display: flex;
	flex-direction: column;
	width: 100%;
	box-sizing: border-box;
	background: transparent;
}

/* Thumbnail container */
.presentation-person-card-image
{
	width: 100%;
}

/* Thumbnail itself */
.presentation-person-card-thumbnail
{
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

/* Text body area */
.presentation-person-card-body
{
	display: flex;
	flex-direction: column;
}

/* Name */
.presentation-person-card-name
{
	display: none;
	margin: 0;
	font-size: 1.2rem;
	font-weight: 600;
}

/* Job title / position */
.presentation-person-card-title
{
	display: none;
	margin: 0;
	font-size: 1rem;
	color: #555;
}

/* Excerpt container */
.presentation-person-card-excerpt
{
	display: none;
	font-size: 0.95rem;
	line-height: 1.4;
}

/* Email line */
.presentation-person-card-email
{
	display: none;
	margin: 0.5rem 0 0;
	font-size: 0.9rem;
	word-break: break-all;
}

.presentation-person-card-email a
{
	display: none;
	color: inherit;
	text-decoration: underline;
}

/* Temp */

	.otgs-development-site-front-end
	{
		display: none !important;
	}

	.wp-block-video.as-loaded video
	{
		opacity: 1 !important
	}

	nav[aria-label="Main Navigation"]
	{
		min-height: 37px !important
	}

	header
	{
/* 		min-height: 123px; */
	}

	.as-navigation-content-row,
	.as-navigation-content-row .wp-container-core-group-is-layout-90752e8f,
	.as-navigation-content-row .wp-container-core-group-is-layout-bc8e6f51
	{
		display: block;
		width: 100%;
	}

	.as-navigation-content-row
	{
		min-height: 69px;
	}

	.as-navigation-content-row .wp-container-core-group-is-layout-bc8e6f51
	{
		margin-top: 0.5rem;
	}

	.video-survey-box
	{
		--radius: 8px;

/* 		background: linear-gradient(
			220deg,
			rgba( 108, 209, 255, 0.05 ),
			rgba( 139, 92, 246, 0.05 ),
			rgba( 255, 110, 199, 0.05 )
		); */


		position: relative;
		border-radius: var( --radius );
		padding: 1.5rem;
	}

	.video-survey-box::before
	{
		content: '';
		position: absolute;
		inset: 0;
		padding: 3px; /* border thickness */
		border-radius: inherit;
		background: linear-gradient( 135deg, #6cd1ffaa, #8b5cf6aa, #ff6ec7aa );
		/* punch the hole so only the ring remains */
		-webkit-mask:
			linear-gradient( #000 0 0 ) content-box,
			linear-gradient( #000 0 0 );
		-webkit-mask-composite: xor;
		mask:
			linear-gradient( #000 0 0 ) content-box,
			linear-gradient( #000 0 0 );
		mask-composite: exclude;
		pointer-events: none;
	}