/*
Theme Name: Kirjanpito Lehtinen WP theme
Theme URI: 
Author: Aimomieli Oy
Author URI: https://aimomieli.fi
Description: 
Requires at least: 6.9
Tested up to: 6.9
Requires PHP: 5.7
Version: 
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Template: twentytwentyfive
Text Domain: kirjanpito-lehtinen-wp-theme
Tags: 
*/

strong,
b {
	font-weight: 600;
}

/* Logo: max-width 300px */
header .wp-block-image.site-logo img {
	max-width: 300px;
	height: auto;
}

/* Override parent theme: all focus outlines blue (from twentytwentyfive :where(.wp-site-blocks *:focus)) */
:where(.wp-site-blocks *:focus) {
	outline-color: var(--wp--preset--color--blue);
	outline-offset: 2px;
}

/* Logo link: blue focus outline (keyboard Tab and click) */
header .wp-block-image a:focus,
header .wp-block-image a:focus-visible,
header .wp-block-site-logo a:focus,
header .wp-block-site-logo a:focus-visible {
	outline: 2px solid var(--wp--preset--color--blue) !important;
	outline-offset: 2px;
}

a,
footer .wp-block-navigation__container.wp-block-navigation span {
	background-image: linear-gradient(currentColor, currentColor);
	background-position: 0 100%;
	background-repeat: no-repeat;
	background-size: 0% 1px;
	transition: color 0.2s ease, background-size 0.2s ease;
}

p a:hover,
p a:focus-visible,
footer .wp-block-navigation__container.wp-block-navigation span:hover,
footer .wp-block-navigation__container.wp-block-navigation span:focus-visible {
	color: var(--wp--preset--color--gold-dark) !important;
	background-size: 100% 1px;
}

/* Navigation */
header .wp-block-navigation__container.wp-block-navigation a, 
header .wp-block-navigation__container.wp-block-navigation span {
	text-transform: uppercase;
	font-family: var(--wp--preset--font-family--oswald);
	font-weight: 400;
	font-size: var(--wp--preset--font-size--large);
	letter-spacing: 0.025em;
	text-decoration: none;
	color: var(--wp--preset--color--black) !important;
	background-image: linear-gradient(currentColor, currentColor);
	background-position: 0 100%;
	background-repeat: no-repeat;
	background-size: 0% 1px;
	transition: color 0.2s ease, background-size 0.2s ease;
}

header .wp-block-navigation__container.wp-block-navigation span:hover,
header .wp-block-navigation__container.wp-block-navigation span:focus-visible,
header .wp-block-navigation__container.wp-block-navigation .has-child .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-container .wp-block-navigation-item:hover span {
	color: var(--wp--preset--color--gold) !important;
	background-size: 100% 1px; /* expand underline from left to right */
}

header .wp-block-navigation__submenu-icon.wp-block-navigation-submenu__toggle {
	font-size: var(--wp--preset--font-size--large);
}
header .wp-block-navigation .has-child .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-container, header .wp-block-navigation .has-child:not(.open-on-click):hover>.wp-block-navigation__submenu-container, header .wp-block-navigation .has-child:not(.open-on-click):not(.open-on-hover-click):focus-within>.wp-block-navigation__submenu-container {
	min-width: 285px;
}

header .wp-block-navigation .has-child .wp-block-navigation__submenu-container>.wp-block-navigation-item>.wp-block-navigation-item__content {
	padding: .25em 1em;
}

header .wp-block-navigation .has-child .wp-block-navigation__submenu-container>.wp-block-navigation-item:first-child>.wp-block-navigation-item__content {
	padding-top: 1em;
}

header .wp-block-navigation .has-child .wp-block-navigation__submenu-container>.wp-block-navigation-item:last-child>.wp-block-navigation-item__content {
	padding-bottom: 1em;
}

header .wp-block-navigation-item.cta-contact a {
	border: 2px solid var(--wp--preset--color--blue);
	border-radius: 0.25rem;
	background-color: var(--wp--preset--color--blue);
	color: var(--wp--preset--color--white);
	padding: .75rem;
	margin-left: 3rem;
}

header .wp-block-navigation-item.cta-contact a:hover {
	border: 2px solid var(--wp--preset--color--black);
	background-color: var(--wp--preset--color--black);
	color: var(--wp--preset--color--gold-white) !important;
	text-decoration: none !important;
	background-image: none !important;
}

header .wp-block-navigation-item.cta-contact a,
header .wp-block-navigation-item.cta-contact span {
	background-image: none !important;
	color: var(--wp--preset--color--white) !important;
}

header .wp-block-navigation-item.cta-contact a:hover span {
	color: var(--wp--preset--color--white) !important;
	text-decoration: none !important;
	background-image: none !important;
}

footer .wp-block-navigation__container.wp-block-navigation {
	gap: .5rem;
}


footer .wp-block-navigation__container.wp-block-navigation a {
	text-decoration: underline;
}

footer .wp-block-navigation__container.wp-block-navigation a:hover {
	text-decoration: none;
}

/* Button: smooth transitions for hover/focus */
.wp-element-button,
.wp-block-button__link {
	position: relative;
	margin-bottom: 1rem;
	border: 1px solid transparent;
	transition:
		transform 0.25s ease,
		background-color 0.25s ease,
		color 0.25s ease,
		border-color 0.25s ease,
		box-shadow 0.25s ease,
		padding-right 0.25s ease;
}

/* Arrow icon (shown on hover) – close to text, vertically centered */
.wp-element-button::after,
.wp-block-button__link::after {
	content: "";
	position: absolute;
	right: 1.25rem;
	top: 50%;
	width: 0.9rem;
	height: 0.9rem;
	transform: translateY(-50%) translateX(6px);
	opacity: 0;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23536cb3' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	transition: opacity 0.25s ease, transform 0.25s ease;
}

/* Outline style: black text, black border, black arrow */
.wp-block-button.is-style-outline .wp-block-button__link,
.wp-block-button.is-style-outline .wp-element-button {
	color: var(--wp--preset--color--black) !important;
	border: 1px solid var(--wp--preset--color--black) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link::after,
.wp-block-button.is-style-outline .wp-element-button::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E");
}

.wp-block-button.is-style-outline .wp-block-button__link:hover::after,
.wp-block-button.is-style-outline .wp-element-button:hover::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E");
}

/* Default for buttons without background/color set: transparent bg, blue text & border */
.wp-block-button__link:not([class*="has-background-color"]):not(.is-style-outline),
.wp-element-button:not([class*="has-background-color"]):not(.is-style-outline) {
	background-color: transparent;
	color: var(--wp--preset--color--blue);
	border: 1px solid var(--wp--preset--color--blue);
}

/* Border colors for filled buttons */
.wp-block-button__link.has-black-background-color,
.wp-element-button.has-black-background-color,
.wp-block-button .wp-block-button__link.has-black-background-color,
.wp-block-button .wp-element-button.has-black-background-color {
	border: 1px solid var(--wp--preset--color--black) !important;
}

.wp-block-button__link.has-gold-background-color,
.wp-element-button.has-gold-background-color,
.wp-block-button .wp-block-button__link.has-gold-background-color,
.wp-block-button .wp-element-button.has-gold-background-color {
	border: 1px solid var(--wp--preset--color--gold) !important;
}

.wp-block-button__link.has-white-background-color,
.wp-element-button.has-white-background-color,
.wp-block-button .wp-block-button__link.has-white-background-color,
.wp-block-button .wp-element-button.has-white-background-color {
	border: 1px solid var(--wp--preset--color--black) !important;
}

/* Button hover: scale and shadow (colors stay the same) */
.wp-element-button:hover,
.wp-block-button__link:hover {
	/*transform: scale(1.05);
	padding-right: 2.5rem;*/
	background-color: var(--wp--preset--color--black) !important;
	color: var(--wp--preset--color--white) !important;
	border-color: var(--wp--preset--color--black) !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}


/* Arrow always visible + bouncing: add class "arrow-always" in Block → Advanced → Additional CSS class(es) */
.wp-block-buttons .wp-block-button.arrow-always .wp-block-button__link {
	padding-right: 2.5rem;
}

.wp-block-buttons .wp-block-button.arrow-always .wp-block-button__link::after {
	opacity: 1 !important;
	transform: translateY(-50%) translateX(0);
	animation: arrow-bounce 1.4s ease infinite;
	/* White arrow so it shows on blue (and other dark) button backgrounds */
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E");
}

/* arrow-always: keep arrow visible on hover (override all button type hover rules) */
.wp-block-buttons .wp-block-button.arrow-always .wp-block-button__link:hover::after,
.wp-block-buttons .wp-block-button.arrow-always .wp-element-button:hover::after {
	opacity: 1 !important;
	transform: translateY(-50%) translateX(0);
	animation: arrow-bounce 1.4s ease infinite;
	/* Keep white arrow on hover (same as default) */
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E") !important;
}

.wp-element-button:active,
.wp-block-button__link:active {
	transform: scale(0.98);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

/* Media & Text: SVG slide-in animation (runs when block enters viewport via .in-view class) */
@keyframes media-text-svg-slide-from-left {
	from {
		opacity: 0;
		transform: translateX(-80px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes media-text-svg-slide-from-right {
	from {
		opacity: 0;
		transform: translateX(80px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}


@keyframes arrow-bounce {
	0%, 100% { transform: translateY(-50%) translateX(0); }
	25% { transform: translateY(-50%) translateX(4px); }
	50% { transform: translateY(-50%) translateX(0); }
	75% { transform: translateY(-50%) translateX(4px); }
}

/* Initial state: SVG hidden until in viewport */
.wp-block-media-text:not(.has-media-on-the-right) .wp-block-media-text__media:has(img[src*=".svg"]) img {
	opacity: 0;
	transform: translateX(-80px);
}

.wp-block-media-text.has-media-on-the-right .wp-block-media-text__media:has(img[src*=".svg"]) img {
	opacity: 0;
	transform: translateX(80px);
}

/* When in viewport: run slide-in animation */
.wp-block-media-text.in-view:not(.has-media-on-the-right) .wp-block-media-text__media:has(img[src*=".svg"]) img {
	animation: media-text-svg-slide-from-left 0.8s ease forwards;
}

.wp-block-media-text.in-view.has-media-on-the-right .wp-block-media-text__media:has(img[src*=".svg"]) img {
	animation: media-text-svg-slide-from-right 0.8s ease forwards;
}


/* Media & Text: align image toward text (closer to content) */
.wp-block-media-text .wp-block-media-text__media {
	display: flex;
	align-items: flex-start;
}

/* Media on left (image + text): align image to the right, next to text */
.wp-block-media-text:not(.has-media-on-the-right) .wp-block-media-text__media {
	justify-content: flex-end;
	align-items: flex-start;
}

/* Media on right (text + image): align image to the left, next to text */
.wp-block-media-text.has-media-on-the-right .wp-block-media-text__media {
	justify-content: flex-start;
	align-items: flex-start;
}

/*
.wp-block-media-text .wp-block-media-text__content {
	padding: 0 0 0 8%;
}
*/

.wp-block-media-text .wp-block-media-text__content .wp-block-heading {
	margin-top: 0;
}

/* Responsive: ensure small-content columns don't overflow on narrow screens */
@media (max-width: 782px) {

	.wp-block-media-text:not(.has-media-on-the-right) .wp-block-media-text__media {
		justify-content: center;
		align-items: center;
	}

	.wp-block-media-text.has-media-on-the-right .wp-block-media-text__media {
		justify-content: center;
		align-items: center;
	}

	.wp-block-media-text .wp-block-media-text__content .wp-block-heading,
	.wp-block-media-text .wp-block-media-text__content p {
		text-align: center;
	}
}

/* Media & Text: when image is SVG, cap size (alignment from rules above) */
.services-page .wp-block-media-text .wp-block-media-text__media:has(img[src*=".svg"]) img {
	max-width: 250px;
	max-height: 250px;
	width: auto;
	height: auto;
}

.wp-block-group.alignfull.map.is-layout-constrained,
.wp-block-group.alignfull.map.is-layout-constrained iframe {
	margin: 0 auto;
	width: 100%;
	max-width: 100%;
}

.wp-block-columns.small-content .wp-block-media-text .wp-block-media-text__media:has(img[src*=".svg"]) img {
	max-width: 150px;
	max-height: 150px;
	width: auto;
	height: auto;
}

footer {
	margin-top: 0;
	border-top: 2px solid transparent;
	border-bottom: 8px solid transparent;
	border-image: linear-gradient(
	  to right,
	  var(--wp--preset--color--blue),
	  var(--wp--preset--color--gold)
	) 1;
	/*background-color: #FAF9F6;*/
}

footer p.copyright {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .75rem;
	margin-bottom: .25rem;
}
footer .aimomieli-badge a {
	background-image: none;
}
footer .aimomieli-badge a,
footer .aimomieli-badge a:hover,
footer .aimomieli-badge a:focus-visible {
    text-decoration: none;
}
footer .aimomieli-badge a svg {
	height: 11px;
	display: inline-block;
	vertical-align: text-bottom;
	opacity: 0.2;
	transform-origin: center;
	transform: translateY(-2px) scale(1);
	transition:
		opacity 0.2s ease,
		transform 0.2s ease;
}
footer .aimomieli-badge a:hover svg,
footer .aimomieli-badge a:focus-visible svg {
	opacity: 1;
	transform: translateY(-3px) scale(1.2);
}

/* Footer badge tooltip */
.aimomieli-badge [data-tooltip] {
	position: relative;
	cursor: pointer;
}
  
/* Tooltip bubble (initially hidden) */
.aimomieli-badge [data-tooltip]::after {
	content: attr(data-tooltip);
	position: absolute;
	left: 50%;
	bottom: 100%;
	transform: translate(-50%, 6px);
	margin-bottom: 0.5rem;
	padding: 0.4rem 0.6rem;
	max-width: 220px;
	border-radius: 4px;

	background-color: var(--wp--preset--color--black, #000);
	color: #fff;
	font-size: 0.75rem;
	line-height: 1.3;
	text-align: center;
	white-space: nowrap;

	opacity: 0;
	pointer-events: none;
	transition: opacity 0.18s ease, transform 0.18s ease;
	z-index: 20;
}

/* Tooltip arrow */
.aimomieli-badge [data-tooltip]::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 100%;
	transform: translateX(-50%);
	border-width: 6px;
	border-style: solid;
	border-color: var(--wp--preset--color--black, #000) transparent transparent transparent;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.18s ease;
	z-index: 19;
}
  
/* Show on hover / focus */
.aimomieli-badge [data-tooltip]:hover::after,
.aimomieli-badge [data-tooltip]:focus-visible::after,
.aimomieli-badge [data-tooltip]:hover::before,
.aimomieli-badge [data-tooltip]:focus-visible::before {
	opacity: 1;
	transform: translate(-50%, 0);
}

/* Mobile navigation layout */
@media (max-width: 782px) {
	.wp-block-navigation__container.is-responsive li ul {
		margin: 0 !important;
		padding: 0 !important;
	}
	.wp-block-navigation__container.is-responsive li ul li {
		margin: 0 !important;
		padding: 0 !important;
	}
	.wp-block-navigation__container.is-responsive li ul li a {
		/*margin: 0 !important;
		padding: 0 !important;*/
		padding-bottom: 0.5rem !important;
	}

	.wp-block-navigation__container.is-responsive li ul li span {
		font-size: .85em;
	}

	footer .wp-block-group.alignfull.is-content-justification-space-between {
		align-items: center;
		justify-content: center;
	}

	footer .wp-block-group.alignfull.is-content-justification-space-between nav ul {
		align-items: center;
		justify-content: center;
		text-align: center;
	}
	header .wp-block-navigation-item.cta-contact a {
		margin-left: 0 !important;
		padding: .75rem !important;
	}
  }

  /* Gravity Forms */
 /* Gravity Forms (legacy markup) */
#gform_wrapper_1.gform_wrapper {
	/* Override GF theme vars (GF sets these inline too) */
	--gf-color-primary: var(--wp--preset--color--blue);
	--gf-color-primary-contrast: var(--wp--preset--color--white);
	--gf-radius: 0.25rem;
	--gf-ctrl-border-color: color-mix(in srgb, var(--wp--preset--color--contrast) 35%, transparent);
	margin-bottom: 2rem;
}

#gform_wrapper_1.gform_wrapper,
#gform_wrapper_1.gform_wrapper input,
#gform_wrapper_1.gform_wrapper textarea,
#gform_wrapper_1.gform_wrapper select,
#gform_wrapper_1.gform_wrapper button {
	font-family: var(--wp--preset--font-family--primary);
}

#gform_wrapper_1.gform_wrapper .gform-body {
	margin-top: 1rem;
}

#gform_wrapper_1.gform_wrapper .gfield {
	margin-bottom: 1rem;
}

#gform_wrapper_1.gform_wrapper .gfield_label {
	display: block;
	font-family: var(--wp--preset--font-family--heading);
	letter-spacing: 0.02em;
	text-transform: uppercase;
	font-size: 0.95rem;
	margin-bottom: 0.35rem;
	color: var(--wp--preset--color--contrast);
}

#gform_wrapper_1.gform_wrapper input[type="text"],
#gform_wrapper_1.gform_wrapper input[type="email"],
#gform_wrapper_1.gform_wrapper input[type="tel"],
#gform_wrapper_1.gform_wrapper textarea,
#gform_wrapper_1.gform_wrapper select {
	width: 100%;
	background: var(--wp--preset--color--white);
	color: var(--wp--preset--color--contrast);

	border: 1px solid var(--gf-ctrl-border-color);
	border-radius: var(--gf-radius);

	padding: 0.85rem 1rem;
	line-height: 1.2;

	transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

#gform_wrapper_1.gform_wrapper textarea {
	min-height: 10rem;
	resize: vertical;
}

#gform_wrapper_1.gform_wrapper input:focus,
#gform_wrapper_1.gform_wrapper textarea:focus,
#gform_wrapper_1.gform_wrapper select:focus {
	outline: 2px solid var(--wp--preset--color--blue);
	outline-offset: 2px;
	border-color: var(--wp--preset--color--blue);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--wp--preset--color--blue) 18%, transparent);
}

#gform_wrapper_1.gform_wrapper .gfield_required {
	color: var(--wp--preset--color--gold);
}

/* Submit button */
#gform_wrapper_1.gform_wrapper .gform_footer {
	margin-top: 1.25rem;
}

#gform_wrapper_1.gform_wrapper .gform_button.button,
#gform_wrapper_1.gform_wrapper input[type="submit"].gform_button {
	background: var(--wp--preset--color--blue);
	color: var(--wp--preset--color--white);

	border: 2px solid var(--wp--preset--color--blue);
	border-radius: .25rem;

	padding: 0.9rem 1.4rem;
	font-family: var(--wp--preset--font-family--heading);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;

	cursor: pointer;
	transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease;
}

#gform_wrapper_1.gform_wrapper .gform_button.button:hover,
#gform_wrapper_1.gform_wrapper input[type="submit"].gform_button:hover {
	background-color: color-mix(in srgb, var(--wp--preset--color--blue) 82%, black 18%);
	border-color: color-mix(in srgb, var(--wp--preset--color--blue) 82%, black 18%);
	transform: scale(1.03);
}

/* Optional: help text / descriptions */
#gform_wrapper_1.gform_wrapper .gfield_description {
	font-size: 0.9rem;
	color: color-mix(in srgb, var(--wp--preset--color--contrast) 70%, transparent);
	margin-top: 0.35rem;
}

@media (min-width: 782px) {
	/* Sticky header */
	/* Sticky, auto-hiding header */
	header.wp-block-template-part {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		z-index: 50;
		transform: translateY(0);
		transition: transform 0.25s ease;
		background-color: rgba(255, 255, 255, 0.95);
	}

	/* Page content padding so it doesn't go under the fixed header */
	main {
		padding-top: 120px; /* adjust to your header height */
	}

	/* Hidden state when scrolling down */
	header.wp-block-template-part.header--hidden {
		transform: translateY(-100%);
	}
}