/*
Theme Name: Aurinkolintu Exercise 2026
Theme URI: https://aurinkolintu.com/
Author: 
Description: Aurinkolintu with reboot from BS5 and couple icons.
Version: 3
Text Domain: aurinkolintu
*/
:root {
	--secondary-color: oklch(84.612% 0.14192 85.694);
	--secondary-color-blue: oklch(from var(--secondary-color) 40% c 255);
	--secondary-color-alfa: oklch(from var(--secondary-color) l c h / 0.5);
	/* --third-color: oklch(from var(--secondary-color) 80% c 69); */
	--primary-color: var(--body-color);
	/*38.284% 0.10148 252.415*/
	--color-white: rgb(255 255 255 / 0.9);
	--color-white-70: rgb(255 255 255 / 0.7);
	--color-dark: rgb(0 0 0 / 0.75);
	--color-dark-25: rgb(0 0 0 / 0.25);
	--color-dark-50: rgb(0 0 0 / 0.5);
	--color-gray-10: rgb(170 170 170 / 0.1);
	--font-size-h1: clamp(1.375rem, 1.375rem + 1.5vw, 2.25rem);
	--font-size-h2: clamp(1.325rem, 1.325rem + 0.9vw, 2rem);
	--font-size-h3: clamp(1.3rem, 1.3rem + 0.6vw, 1.75rem);
	--font-size-h4: clamp(1.275rem, 1.275rem + 0.3vw, 1.5rem);
	--font-size-h5: 1.25rem;
	--font-size-h6: 1rem;
	--title-font-weight: 400;

	--box-shadow-sm: .15rem .25rem .5rem var(--body-color-10);
	--box-shadow-lg: .5rem 1rem 1rem var(--body-color-50);
	--box-shadow-button-hover: .15rem .25rem .25rem var(--body-color-10);

	--max-container-width: 100ch;
}

@view-transition {
	navigation: auto;
}

body {
	font-family: "Avenir Next", var(--body-font-family);
	overflow-wrap: break-word;
	word-wrap: break-word;
	hyphens: auto;

	position: relative;
	min-block-size: 100svh;

	display: grid;
	grid-template-rows: auto 1fr auto;

	background: var(--body-bg);

	transition: all ease .5s;
}

button,
.no-hyphen,
.navmenu {
	overflow-wrap: normal;
	word-wrap: normal;
	hyphens: none;
}

img,
figure,
iframe {
	max-width: 100%;
	height: auto;
}

a:link,
a:visited {
	position: relative;
	color: var(--color-dark);
	text-decoration: none;
	font-weight: 500;
	box-shadow: inset 0 -0.08em var(--secondary-color), inset 0 -0.2em transparent;
	transition: all .15s ease-in;
}

a:hover,
a:active {
	color: var(--primary-color);
	text-decoration: none;
	box-shadow: inset 0 -0.2em var(--secondary-color), inset 0 -0.2em var(--color-white);
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
	font-weight: var(--title-font-weight);
	text-transform: uppercase;
	overflow-wrap: normal;
	word-wrap: normal;
	hyphens: none;
	text-wrap: balance;

	& a {
		font-weight: 400;
		box-shadow: none;
	}
}

h1,
.h1 {
	font-size: var(--font-size-h1);
	letter-spacing: -0.05rem;
	text-wrap: balance;

	nav & {
		margin: 0;
	}
}

h2,
.h2 {
	font-size: var(--font-size-h2);
	letter-spacing: -0.05rem;
}

h3,
.h3 {
	font-size: var(--font-size-h3);
	letter-spacing: -0.05rem;
}

h4,
.h4 {
	font-size: var(--font-size-h4);
}

h5,
.h5 {
	font-size: var(--font-size-h5);
}

h6,
.h6 {
	font-size: var(--font-size-h6);
}

a.btn,
.wp-element-button,
button,
input[type="submit"],
:root .forminator-ui#forminator-module-7103.forminator-design--flat .forminator-button-submit {
	padding: .5rem 2ch;
	background-color: var(--secondary-color);
	color: var(--color-dark);
	text-transform: uppercase;
	font-weight: 500;
	border: .15rem solid transparent;
	border-radius: .25rem;
	transition: all .15s ease-in;
}

a.btn:where(:hover, :focus),
.wp-element-button:where(:hover, :focus),
button:where(:hover, :focus),
input[type="submit"]:where(:hover, :focus),
:root .forminator-ui#forminator-module-7103.forminator-design--flat .forminator-button-submit:is(:hover, :focus) {
	background-color: var(--secondary-color);
	color: var(--color-dark);
	outline: .15rem solid var(--primary-color);
}

a.btn:active,
.wp-element-button:active,
button:active,
input[type="submit"]:active,
:root .forminator-ui#forminator-module-7103.forminator-design--flat .forminator-button-submit:active {
	border-top: .15rem solid var(--color-dark-50);
	border-right: .15rem solid var(--color-dark-25);
	border-bottom: .15rem solid var(--color-dark-25);
	border-left: .15rem solid var(--color-dark-50);
	outline: none;
}

.screen-reader-text,
.visually-hidden,
.recaptcha-invisible {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip-path: rect(0 0 0 0);
	white-space: nowrap;
	border: 0
}

.skip-link {
	background-color: var(--secondary-color);
	color: var(--body-bg);
	transform: translateY(-100%);
	transition: all ease .5s;

	&:where(:focus, :focus-within, :focus-visible) {
		z-index: 10100;
		box-sizing: border-box;
		display: block;
		width: 100%;
		height: 2rem;
		padding: .15rem .25rem;
		margin: 0;
		clip-path: none;
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}
}

.d-block {
	display: block;
}

.list-unstyled {
	list-style: none;
	margin-inline: 0;
	padding: 0;

	&:has(.icons) li {
		& a {
			box-shadow: none;
		}
	}
}

.no-text-transform {
	text-transform: none;
}

b,
strong {
	font-weight: 500;
}

ul {
	padding-left: 1.1rem;
	list-style-type: circle;
}

header {
	position: fixed;
	inset: 0 0 auto;
	z-index: 1030;
	max-width: var(--max-container-width);
	margin-inline: auto;
	background-color: var(--body-bg);
	border-bottom: .15rem solid var(--secondary-color);

	@media (width > 1024px) {
		margin-inline: 0;
	}
}

.navbar {
	padding: 0 1rem;
	text-align: center;

	& .navbar-brand {
		display: block;
		max-width: calc(100% - 2rem);
		height: 3rem;
		margin: .5rem auto;
		padding-bottom: 0 !important;
		box-shadow: none;

		& svg {
			width: 100%;
			height: 100%;
			object-fit: contain;
			object-position: 0 0;
			fill: var(--color-dark);
			transition: all .25s ease;
		}

		&:where(:active, :focus) svg {
			fill: var(--primary-color);
		}

		@media (hover: hover) {
			&:hover svg {
				fill: var(--primary-color);
			}
		}
	}

	& .navmenu {
		margin: 0 auto;
		padding: 0 0 .25rem;
		list-style: none;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: center;
		gap: .15cqi;
		line-height: 1;

		& a {
			padding: .25rem .15rem;
			font-size: .75rem;
			text-transform: uppercase;
			color: var(--color-dark);
			box-shadow: none;

			&:where(:hover, :active, :focus) {
				color: var(--secondary-color-blue);
			}

			@media (width > 414px) {
				font-size: .875rem;
			}
		}
	}
}

@media (width > 768px) {
	.navbar {
		display: flex;
		padding: 0 1.5rem;

		& .navbar-brand {
			box-sizing: content-box;
			max-width: 12ch;
			margin: 0;
			padding: .5rem 1ch 0;
			line-height: 1;
		}

		& .navmenu {
			margin: 0 0 0 auto;
			padding: 0;

			& li {
				align-self: flex-end;
				transform: translateY(-5px);
			}
		}
	}
}

main {
	display: grid;
	grid-template-rows: repeat(1, 1fr);
	grid-template-columns: repeat(12, 1fr);
	justify-items: start;
	gap: 1.5rem;
	max-width: var(--max-container-width);
	min-height: 100svh;
	margin-inline: auto;
	padding: 6rem 1rem 1.5rem;

	@media (width > 768px) {
		padding-inline: 1.5rem;
	}

	@media (width > 1024px) {
		margin-inline: 0;
	}


	&>* {
		/* max-width: 65ch; */
		margin-inline: auto;
		padding-block: 1.5rem;
		grid-column: 1/-1;
	}

	&>.container {
		@media (width > 768px) {
			grid-column: 5/-1;
			order: 2;
			width: 100%;
			padding-right: 1.5rem;
		}
	}

	&>aside {
		@media (width > 768px) {
			grid-column: 1/5;
			order: 1;
		}
	}
}

article {
	& .date {
		margin: -.5rem 0 1rem;
		font-size: .875rem;
	}

	& table {
		width: 100%;
		font-size: inherit;
	}

	& th {
		padding: .25rem 0;
	}

	& td {
		padding: 1rem 2ch;
	}
}

.aside {
	text-align: center;
	font-size: .875rem;
	text-wrap: balance;

	& ul,
	& p {
		margin-bottom: 1.5rem;
	}

	& .opening-times {
		line-height: 1;
	}

	& a {
		padding-block: .25rem;
	}
}

@supports (position: sticky) {
	@media (width > 920px) {
		.aside {
			position: sticky;
			top: 6rem;
			align-self: flex-start;
		}
	}
}

figure:not(.wp-block-table),
picture {
	margin: 1.5rem auto;
	padding: 0.5rem;
	background: var(--color-white);
	box-shadow: var(--box-shadow-sm);
	transition: all 1s cubic-bezier(0, 0, 0.3, 1);
}

figure figcaption,
.wp-block-image figcaption {
	margin: .5rem 0 0;
	text-align: center;
	font-size: 90%;
	opacity: .9;
}

figure.wp-block-table {
	margin: 0 0 2rem;
	border: none;

	& table {
		width: 100%;
	}

	& figcaption {
		margin: 1rem 0;
		text-align: right;
	}
}


.wp-block-table {
	& thead {
		border-bottom: .15rem solid var(--secondary-color-alfa) !important;
	}

	& th {
		line-height: 1.2;
		font-size: 110%;
		font-weight: 500;
	}

	& td {
		vertical-align: top;
		font-size: .875rem;
		line-height: 1.4;

		& strong {
			font-size: 1rem;
			line-height: 1.2;
		}
	}

	&.is-style-stripes {
		border-bottom: none !important;

		tbody tr:nth-child(odd) {
			background-color: var(--color-gray-10) !important;
		}
	}

	& td:last-child {
		white-space: nowrap;
	}
}

/* ICONS */
a.icons,
a[href*="facebook.com"] {
	position: relative;
	display: inline-block;
	/* min-width: 1.2rem;
	min-height: 1.2rem; */
}

a[href*="facebook.com"] {
	width: 1.6rem;
	height: 1.6rem;
}

a.icons span,
a[href*="facebook.com"] span {
	position: absolute;
	text-indent: -9999px;
	overflow: hidden;
}

a.icons::before,
.wp-element-button[href*="ajanvaraus"]::before,
a[href*="facebook.com"]::before {
	content: '';
	position: absolute;
	top: .5rem;
	left: 0;
	width: 1rem;
	height: 1rem;
	background-color: var(--color-dark);
	transition: all .15s ease;
}

a.btn,
.wp-element-button[href*="ajanvaraus"] {
	font-size: .875rem;
	color: var(--color-dark);
	box-shadow: none;

	&::before {
		left: .25rem;
		background-color: var(--color-dark);
	}
}

a.icons {
	padding-left: 1.4rem;

	aside &::before {
		top: .4rem;
	}

	aside &.btn::before {
		top: .5rem;
	}
}

.wp-element-button[href*="ajanvaraus"],
a.icons.btn {
	padding-left: 1.6rem;
}

aside .btn {
	padding: .5rem 2ch;
}

a[href*="facebook.com"]::before {
	width: 1.5rem;
	height: 1.5rem;
	inset: 0;
	background-color: var(--secondary-color-blue);

	@media (width > 768px) {
		inset: .5rem 0 0;
	}
}

a.icons:where(:hover, :active, :focus-within)::before {
	background-color: var(--primary-color);
}

.wp-element-button[href*="ajanvaraus"]:where(:hover, :active, :focus-within)::before,
a.icons.btn:where(:hover, :active, :focus-within)::before {
	background-color: var(--primary-color);
}

a[href*="facebook.com"]::before {
	mask: url(css/icons/facebook.svg) no-repeat 50% 50%;

}

a[href*="facebook.com"]:where(:hover, :active, :focus-within)::before {
	background-color: var(--secondary-color);
}

.wp-element-button[href*="ajanvaraus"]::before,
a.icons.icon-calendar2-check::before {
	mask: url('css/icons/calendar2-check.svg') no-repeat 50% 50%;
}

a.icons.icon-geo-alt::before {
	mask: url('css/icons/geo-alt.svg') no-repeat 50% 50%;
}

a.icons.icon-telephone::before {
	mask: url('css/icons/telephone.svg') no-repeat 50% 50%;
}

a.icons.icon-envelope::before {
	mask: url('css/icons/envelope.svg') no-repeat 50% 50%;
}


.wp-block-media-text {
	margin-bottom: 1rem;
}

.wp-block-media-text__content {
	padding-top: 1rem;
}

/* Form */
input,
textarea {
	padding: 1rem !important;
	background-color: var(--color-white) !important;
	color: var(--primary-color);
	background-clip: padding-box;
	border: 1px solid var(--secondary-color-alfa) !important;
	border-radius: 0.25rem;
	transition: all ease .15s;
}

input.search-submit {
	padding: 1rem 1ch;
	background-color: var(--secondary-color) !important;
	color: var(--color-dark) !important;
}

label {
	font-size: 1rem !important;
	font-weight: 500 !important;
}

.forminator-input-with-prefix {
	padding: 0 !important;
	background-color: transparent !important;
}

.forminator-ui.forminator-custom-form[data-design=flat] .forminator-input-with-suffix .forminator-suffix {
	right: 2rem !important;
}

.forminator-ui.forminator-custom-form:not(.forminator-size--small)[data-grid=open] .forminator-row-inside:not(:last-child),
.forminator-ui.forminator-custom-form:not(.forminator-size--small)[data-grid=open] .forminator-row:not(:last-child) {
	margin-bottom: 1rem !important;
}

.forminator-label,
.forminator-checkbox-label,
.forminator-radio-label {
	color: currentColor !important;
	font-size: 1rem !important;
	font-weight: 400 !important;
}


.bg-img {
	/* max-width: var(--max-container-width); */
	margin-inline: auto;
	padding-inline: 1.5rem;
	padding-bottom: 1.5rem;
	text-align: center;


	@media (width > 1024px) {
		position: fixed;
		inset: 0 0 0 auto;
		z-index: -1;
		width: calc(100vw - var(--max-container-width));
		max-width: none;
		height: 100%;
		padding: 0;
		text-align: right;
		border: none;
	}

	& img {
		border: .5rem solid var(--color-white);
		box-shadow: var(--box-shadow-sm);
		background-color: rgb(255 255 255 / .25);
		border-radius: .25rem;

		@media (width > 1024px) {
			width: 100%;
			height: 100%;
			object-fit: cover;
			object-position: 100% 0;
			border: none;
			border-radius: 0;
			transition: all ease-in-out 1s;

			@media (width < 1320px) {
				object-position: 70% 0;
			}
		}
	}
}

.footer {
	position: fixed;
	inset: auto 0 0;
	width: 100%;
	max-width: var(--max-container-width);
	height: .25rem;
	margin-inline: auto;
	background-color: var(--secondary-color);
	border-radius: .15rem;

	@media (width > 1024px) {
		margin-inline: 0;
	}
}

/* PLUGINS */
html:root .wp-gr {
	padding-top: 3rem !important;
	font-size: .875rem;

	& .wp-google-name {
		display: inline !important;
		width: min-content !important;
		line-height: 1;
		font-weight: 500 !important;
	}

	& .wp-google-text {
		line-height: 1 !important;
		padding-left: 0 !important;
		font-style: italic;
		color: var(--color-dark-70) !important;

		&::before {
			content: '”';
		}
	}

	& a {
		box-shadow: none;
	}

	& .wp-google-time,
	& .grw-img-wrap {
		display: none;
	}

	& .rpi-stars {
		display: none !important;
	}

	& .wp-google-url {
		font-size: .875rem;
		text-align: right !important;
	}
}