/*
Theme Name: Klar
Author: Joel Cantero Priego
Author URI: https://joelcantero.com/
Description: Klar is a minimal WordPress block theme built for designers and creative professionals who value clarity, elegance, and creative freedom.
Requires at least: 7.0
Tested up to: 7.0
Requires PHP: 7.4
Version: 1.0.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: klar
Domain Path: /languages
Tags: block-patterns, block-styles, custom-colors, custom-logo, editor-style, full-site-editing, one-column, two-columns, style-variations, translation-ready, wide-blocks
*/

/*
Klar WordPress Theme, Copyright 2026 Joel Cantero Priego
Klar is distributed under the terms of the GNU GPL.
*/

/* Defaults
---------------------------------------- */

html {
	scroll-behavior: smooth;
}

a,
button,
.wp-element-button {
	transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}

input,
textarea {
	transition: filter 0.2s ease-in-out;
}

b,
strong {
	font-weight: 600;
}

/* -- Forms -- */

input,
select,
textarea {
	box-sizing: border-box;
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
	line-height: var(--wp--custom--line-height--medium);
	width: 100%;
}

input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]):not([type="image"]),
textarea,
select {
	border-radius: 9999px;
	background-color: var(--wp--preset--color--base);
}

input:not([type="submit"]):focus,
textarea:focus {
	border-color: var(--wp--preset--color--primary);
	outline: 1px solid var(--wp--preset--color--primary);
}

input[type="checkbox"],
input[type="image"],
input[type="radio"] {
	width: auto;
}

::placeholder {
	color: inherit;
	font-size: var(--wp--preset--font-size--x-small);
	opacity: 0.5;
}

/* Blocks
---------------------------------------- */

/* -- List -- */

.wp-block-list li + li {
	margin-top: 0.8rem;
}

/* -- Canco navigation -- */

.lg-canco-navigation {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 1rem;
	flex-wrap: wrap;
}

.lg-canco-navigation a {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	text-decoration: none;
	max-width: 40%;
}

.lg-canco-navigation__culte {
	max-width: none !important;
	align-self: center;
}

.lg-canco-navigation__label {
	font-size: var(--wp--preset--font-size--x-small, 0.75rem);
	opacity: 0.6;
}

.lg-canco-navigation__title {
	font-weight: 600;
}

.lg-canco-navigation__prev--empty,
.lg-canco-navigation__next--empty {
	visibility: hidden;
	width: 40%;
}

/* -- Navigation -- */

.wp-block-navigation__responsive-container.is-menu-open {
	padding: var(--wp--preset--spacing--30);
	background-color: var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--base) !important;
	justify-content: center;
	align-items: center;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	width: 100%;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-pages-list__item {
	align-items: center !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	text-align: center !important;
	width: 100% !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
	color: var(--wp--preset--color--base) !important;
	display: flex !important;
	justify-content: center !important;
	text-align: center !important;
	width: 100% !important;
}

/* Top-level items: both <a> and <button> variants */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item > .wp-block-navigation-item__content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item > a {
	font-size: var(--wp--preset--font-size--medium) !important;
	font-weight: 600 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
	text-align: center !important;
}

/* Submenu items */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container a {
	font-size: var(--wp--preset--font-size--x-small) !important;
	font-weight: 400 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	opacity: 0.75;
	justify-content: center !important;
	text-align: center !important;
}

/* Submenu container: centre items */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container {
	position: static !important;
	background: transparent !important;
	box-shadow: none !important;
	border: none !important;
	min-width: 0 !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	width: 100% !important;
}

/* Hide hover underline and submenu toggle button in mobile menu */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a::after {
	display: none !important;
}

.wp-block-navigation__responsive-container.is-menu-open button.wp-block-navigation-item__action {
	display: none !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
	color: var(--wp--preset--color--base) !important;
	display: flex !important;
	justify-content: center !important;
	margin-inline: auto !important;
	position: relative !important;
	top: auto !important;
	right: auto !important;
	left: auto !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close {
	display: flex !important;
	justify-content: center !important;
	align-items: center !important;
	width: 100% !important;
	position: relative !important;
	top: auto !important;
	right: auto !important;
	left: auto !important;
	inset: auto !important;
	padding: var(--wp--preset--spacing--20) 0 !important;
}

/* Remove focus outline inside mobile menu */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a:focus,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a:focus-visible {
	outline: none !important;
	box-shadow: none !important;
}

.wp-block-navigation-item a {
	position: relative;
}

.wp-block-navigation-item a::after {
	background-color: currentcolor;
	bottom: 0;
	content: '';
	height: 1px;
	left: 0;
	position: absolute;
	transition: width 0.5s ease;
	width: 0;
}

.wp-block-navigation-item a:hover::after {
	width: 100%;
}

/* -- Navigation Submenu -- */

.wp-block-navigation__submenu-container {
	min-width: 150px !important;
	padding: 10px !important;
}

.wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	padding: 10px 10px !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container {
	padding: 5px 10px 0 !important;
}

/* Utility
---------------------------------------- */

/* -- Overflow -- */

.is-style-overflow-hidden {
	overflow: hidden;
}

/* Position */

.is-style-position-fixed {
  position: fixed;
}

.is-style-position-relative {
  position: relative;
}

/* Z-index */

.is-style-negative-zindex {
  z-index: -99;
}

.is-style-positive-zindex {
  z-index: 99;
}


/* Media Queries
---------------------------------------- */

@media only screen and (min-width: 600px) {

	/* -- Header -- */

	.has-motion .site-header {
		position: sticky;
		top: 0;
		transition: transform 0.5s ease;
		z-index: 1000;
	}
	
	.has-motion body.scroll-down .site-header {
		transform: translateY(-100%);
	}
	
	.has-motion body.scroll-up .site-header {
		transform: translateY(0);
	}

}

/* Font smoothing and selection */
html {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
}

::selection {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
}

/* Button styles */
.wp-block-search__button {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.wp-block-button__link,
.wp-block-search__button {
	position: relative;
	overflow: hidden;
	transition: color 0.3s ease, background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.wp-block-button__link::before,
.wp-block-search__button::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 100%;
	background: color-mix(in srgb, currentColor 12%, transparent);
	transition: all 1s ease;
	pointer-events: none;
	z-index: 1;
}

.wp-block-button__link:hover::before,
.wp-block-search__button:hover::before {
	width: 100%;
}

/* Entry header cover: reduce overlay when featured image is present */
.entry-header-cover[style*="background-image"] > .wp-block-cover__background,
.entry-header-cover:has(> img.wp-block-cover__image-background) > .wp-block-cover__background {
	opacity: 0.9 !important;
}

@media only screen and (max-width: 600px) {

	/* -- Utility -- */

	.is-style-hidden-mobile {
		display: none !important;
	}

}

@media only screen and (max-width: 782px) {

	/* -- Columns -- */

	.wp-block-columns.is-style-column-reverse {
		flex-direction: column-reverse;
	}

}
