/*
Theme Name: Multistarter
Theme URI: https://coursde.org
Author: The Lab XL
Author URI: https://coursde.org
Description: A lightweight, GDPR-compliant block theme for WordPress multisite. Zero JavaScript, bundled fonts, WooCommerce support, and 6 style variations. Built for blogs, shops, portfolios, and business sites.
Version: 1.0.1
Requires at least: 6.7
Tested up to: 6.7
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: multistarter
Tags: block-patterns, block-styles, custom-colors, custom-logo, custom-menu, editor-style, featured-images, full-site-editing, one-column, two-columns, three-columns, wide-blocks, translation-ready
*/

/* Progressive enhancement — only things theme.json can't handle */

/* Smooth scrolling for anchor links */
html {
	scroll-behavior: smooth;
}

/* Better image defaults */
img {
	height: auto;
	max-width: 100%;
}

/* Selection color using theme palette */
::selection {
	background-color: var(--wp--preset--color--accent-3);
	color: var(--wp--preset--color--contrast);
}

/* Outline button style — theme.json only handles filled */
.wp-block-button.is-style-outline .wp-block-button__link {
	background-color: transparent;
	border: 2px solid var(--wp--preset--color--accent);
	color: var(--wp--preset--color--accent);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--base);
}

/* Table styling */
.wp-block-table table {
	border-collapse: collapse;
	width: 100%;
}

.wp-block-table td,
.wp-block-table th {
	border: 1px solid var(--wp--preset--color--contrast-3);
	padding: 0.5em 0.75em;
}

.wp-block-table thead {
	border-bottom: 2px solid var(--wp--preset--color--contrast);
}

/* Mobile hamburger menu button — bigger and easier to tap */
.wp-block-navigation__responsive-container-open {
	padding: 0.5em;
}

.wp-block-navigation__responsive-container-open svg {
	width: 32px;
	height: 32px;
}

/* Responsive navigation overlay */
.wp-block-navigation__responsive-container.is-menu-open {
	background-color: var(--wp--preset--color--base);
	color: var(--wp--preset--color--contrast);
}

/* Details/accordion block — used for FAQ pattern */
.wp-block-details summary {
	cursor: pointer;
	font-weight: 600;
	padding: 0.75em 0;
	list-style: none;
}

.wp-block-details summary::before {
	content: "+";
	display: inline-block;
	width: 1.5em;
	font-weight: 400;
	transition: transform 0.2s ease;
}

.wp-block-details[open] summary::before {
	content: "−";
}

.wp-block-details > :not(summary) {
	padding-bottom: 0.75em;
}

/* Separator with text */
.wp-block-separator.is-style-wide {
	border-bottom-width: 1px;
}

/* Cover block text readability */
.wp-block-cover .wp-block-cover__inner-container {
	max-width: var(--wp--style--global--wide-size);
}

/* Comment form */
.comment-respond .comment-form label {
	display: block;
	margin-bottom: 0.25em;
	font-weight: 500;
}

.comment-respond .comment-form input[type="text"],
.comment-respond .comment-form input[type="email"],
.comment-respond .comment-form input[type="url"],
.comment-respond .comment-form textarea {
	width: 100%;
	padding: 0.5em 0.75em;
	border: 1px solid var(--wp--preset--color--contrast-3);
	border-radius: 4px;
	font-family: inherit;
	font-size: inherit;
}

.comment-respond .comment-form input:focus,
.comment-respond .comment-form textarea:focus {
	border-color: var(--wp--preset--color--accent);
	outline: 2px solid var(--wp--preset--color--accent);
	outline-offset: -2px;
}

/* ── Hover effects ── */

/* Buttons — filled: strong brightness shift + lift */
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
	transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
	filter: brightness(1.2);
}

/* Outline buttons — fill on hover */
.wp-block-button.is-style-outline .wp-block-button__link {
	transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}

/* Navigation links — color transition + underline slides in on hover */
.wp-block-navigation a.wp-block-navigation-item__content {
	transition: color 0.2s ease;
	position: relative;
	text-decoration: none;
}

.wp-block-navigation a.wp-block-navigation-item__content::after {
	content: "";
	position: absolute;
	bottom: -4px;
	left: 50%;
	width: 0;
	height: 3px;
	background-color: var(--wp--preset--color--accent);
	border-radius: 2px;
	transition: width 0.2s ease, left 0.2s ease;
}

.wp-block-navigation a.wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--accent);
}

.wp-block-navigation a.wp-block-navigation-item__content:hover::after {
	width: 100%;
	left: 0;
}

/* Active/current page navigation link */
.wp-block-navigation .current-menu-item > a.wp-block-navigation-item__content,
.wp-block-navigation .current_page_item > a.wp-block-navigation-item__content {
	color: var(--wp--preset--color--accent);
	font-weight: 600;
}

.wp-block-navigation .current-menu-item > a.wp-block-navigation-item__content::after,
.wp-block-navigation .current_page_item > a.wp-block-navigation-item__content::after {
	width: 100%;
	left: 0;
}

/* Headings with links — accent color on hover */
.wp-block-heading a {
	transition: color 0.2s ease;
}

.wp-block-heading a:hover {
	color: var(--wp--preset--color--accent);
}

/* Social links — scale + opacity */
.wp-block-social-link {
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.wp-block-social-link:hover {
	transform: scale(1.15);
	opacity: 0.75;
}

/* ── Mobile responsive fixes ── */
/* Logo sizing — height-driven so portrait & landscape logos look consistent */
.wp-block-site-logo img.custom-logo {
	width: auto !important;
	height: auto !important;
	min-height: 80px;
	max-height: 100px;
	max-width: 250px;
	object-fit: contain;
}

@media (max-width: 600px) {
	/* Mobile logo — width-driven, 50% of screen */
	.wp-block-site-logo img.custom-logo {
		min-height: unset;
		max-height: unset;
		max-width: 50vw;
		width: 50vw !important;
	}

	/* Center the header flex row on mobile instead of space-between */
	.is-content-justification-space-between.is-layout-flex {
		justify-content: center !important;
		gap: 1.5rem !important;
	}

	/* Center the right-side nav group too */
	.is-content-justification-right.is-layout-flex {
		justify-content: center !important;
	}
}

/* Mobile menu overlay — centered, bigger, more readable links */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
	font-size: 1.5rem;
	padding: 0.6em 0;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	padding-top: 2rem;
	gap: 0.25rem;
	align-items: center !important;
	justify-content: flex-start !important;
}

/* Override right-justification inside the overlay */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item {
	justify-content: center;
	text-align: center;
}

/* Print styles */
@media print {
	.wp-block-navigation,
	.wp-block-template-part[data-area="header"],
	.wp-block-template-part[data-area="footer"] {
		display: none !important;
	}
}
