/*
Theme Name: Dyslexia Hero
Description: Block theme for Dyslexia Hero.
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 7.4
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dyslexia-hero
Tags: full-site-editing, block-patterns, block-styles
*/

/*
 * Navigation links: override core `.wp-block-navigation-item__content.wp-block-navigation-item__content { color: inherit }`
 * (higher specificity than theme.json :where() rules) so default, hover, focus, and active use the palette.
 */

/*
 * Global section rhythm:
 * Add breathing room between top-level content blocks across pages.
 */
main .wp-block-post-content.is-layout-constrained > * + *,
main .wp-block-post-content.is-layout-flow > * + * {
	margin-block-start: var(--wp--preset--spacing--xl, 3rem);
}

.home .entry-content.wp-block-post-content {
	display: contents;
}

.home main .wp-block-post-content.is-layout-constrained > .is-style-dh-hero-strengths,
.home main .wp-block-post-content.is-layout-flow > .is-style-dh-hero-strengths {
	margin-block-start: var(--wp--preset--spacing--l, 2rem);
}

@media (max-width: 781px) {
	main .wp-block-post-content.is-layout-constrained > * + *,
	main .wp-block-post-content.is-layout-flow > * + * {
		margin-block-start: var(--wp--preset--spacing--l, 2rem);
	}

	.home main .wp-block-post-content.is-layout-constrained > .is-style-dh-hero-strengths,
	.home main .wp-block-post-content.is-layout-flow > .is-style-dh-hero-strengths {
		margin-block-start: var(--wp--preset--spacing--m, 1.5rem);
	}
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation-item__content {
	font-weight: 600;
	font-size: 18px;
	text-decoration: none;
	color: var(--wp--preset--color--text, #4a4a4a);
	border-bottom: 2px solid transparent;
	padding-bottom: 0.15em;
	transition: color 0.15s ease, border-color 0.15s ease;
}

/* Give "Home" (first item) breathing room before the remaining links. */
.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation__container > .wp-block-navigation-item:first-child {
	margin-right: var(--wp--preset--spacing--l, 2rem);
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation-item__label {
	color: currentColor;
	font-weight: inherit;
	font-size: inherit;
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation-item__content:hover,
.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation-item__content:focus-visible {
	color: var(--wp--preset--color--primary, #b03070);
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation-item__content:active {
	color: var(--wp--preset--color--primary-strong, #8c2658);
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .current-menu-item .wp-block-navigation-item__content {
	color: var(--wp--preset--color--primary, #b03070);
	font-weight: 700;
	border-bottom-color: var(--wp--preset--color--primary, #b03070);
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .current-menu-item .wp-block-navigation-item__content:hover,
.dh-header-bar .wp-block-navigation.dh-primary-nav .current-menu-item .wp-block-navigation-item__content:focus-visible {
	color: var(--wp--preset--color--primary-strong, #8c2658);
	border-bottom-color: var(--wp--preset--color--primary-strong, #8c2658);
}

/* Larger hamburger / menu toggle on small screens (core overlay navigation). */
.dh-header-bar .wp-block-navigation.dh-primary-nav button.wp-block-navigation__responsive-container-open {
	box-sizing: border-box;
	min-width: 3rem;
	min-height: 3rem;
	padding: 0.5rem;
}

.dh-header-bar .wp-block-navigation.dh-primary-nav button.wp-block-navigation__responsive-container-open svg {
	width: 2.25rem;
	height: 2.25rem;
}

/*
 * Mobile overlay menu: items inherit the desktop nav's right alignment,
 * which pushes them against the screen edge. Center them inside the open overlay.
 */
.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content,
.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
	justify-content: center;
	align-items: center;
	text-align: center;
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
	justify-content: center;
}

.dh-header-bar .wp-block-navigation.dh-primary-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
	font-size: 1.25rem;
}

/*
 * Circular site logo: badge-style ring (heading color), lift + hover + keyboard focus.
 */
.dh-header-bar .wp-block-site-logo.dh-site-logo-circle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100px;
	height: 100px;
	padding: 4px;
	border: 3px solid var(--wp--preset--color--heading, #b03070);
	border-radius: 50%;
	background: #ffffff;
	box-shadow: 0 4px 12px rgba(176, 48, 112, 0.18);
	box-sizing: border-box;
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.dh-header-bar .wp-block-site-logo.dh-site-logo-circle:hover {
	transform: scale(1.04);
	border-color: var(--wp--preset--color--primary-strong, #8c2658);
	box-shadow: 0 6px 18px rgba(176, 48, 112, 0.25);
}

.dh-header-bar .wp-block-site-logo.dh-site-logo-circle:focus-within {
	outline: 3px solid var(--wp--preset--color--accent, #0ea5e9);
	outline-offset: 4px;
}

.dh-header-bar .wp-block-site-logo.dh-site-logo-circle a,
.dh-header-bar .wp-block-site-logo.dh-site-logo-circle .custom-logo-link {
	display: flex;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	overflow: hidden;
}

.dh-header-bar .wp-block-site-logo.dh-site-logo-circle img,
.dh-header-bar .wp-block-site-logo.dh-site-logo-circle .custom-logo {
	width: 100% !important;
	height: 100% !important;
	max-width: 100%;
	border-radius: 50%;
	object-fit: cover;
	display: block;
}

@media (prefers-reduced-motion: reduce) {
	.dh-header-bar .wp-block-site-logo.dh-site-logo-circle {
		transition: border-color 0.2s ease, box-shadow 0.2s ease;
	}

	.dh-header-bar .wp-block-site-logo.dh-site-logo-circle:hover {
		transform: none;
	}
}

@media (max-width: 781px) {
	.dh-header-bar .wp-block-site-logo.dh-site-logo-circle {
		width: 64px;
		height: 64px;
		padding: 3px;
	}
}

.dh-footer-nav.wp-block-navigation .wp-block-navigation-item__content {
	font-weight: 600;
	font-size: var(--wp--preset--font-size--small, 0.95rem);
	text-decoration: none;
	color: var(--wp--preset--color--text, #4a4a4a);
	transition: color 0.15s ease;
}

.dh-footer-shell {
	border-top: 0 !important;
}

.dh-footer-nav.wp-block-navigation .wp-block-navigation-item__label {
	color: currentColor;
}

.dh-footer-nav.wp-block-navigation .wp-block-navigation-item__content:hover,
.dh-footer-nav.wp-block-navigation .wp-block-navigation-item__content:focus-visible {
	color: var(--wp--preset--color--primary, #b03070);
}

.dh-footer-nav.wp-block-navigation .wp-block-navigation-item__content:active {
	color: var(--wp--preset--color--primary-strong, #8c2658);
}

.dh-footer-nav.wp-block-navigation .current-menu-item .wp-block-navigation-item__content {
	color: var(--wp--preset--color--primary, #b03070);
	font-weight: 700;
}

.dh-testimonials .wp-block-columns {
	gap: var(--wp--preset--spacing--m, 1.25rem);
}

.dh-testimonial-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: var(--wp--preset--spacing--m, 1.25rem);
	border: 1px solid var(--wp--preset--color--muted, #d6d0da);
	border-radius: 12px;
	background: var(--wp--preset--color--background, #fff);
	margin-bottom: var(--wp--preset--spacing--m, 1.25rem);
}

.dh-testimonial-text {
	margin: 0 0 var(--wp--preset--spacing--m, 1.25rem) 0;
	display: -webkit-box;
	line-clamp: 6;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 6;
	overflow: hidden;
	text-overflow: ellipsis;
	font-style: italic;
}

.dh-testimonial-meta {
	margin-top: auto;
}

.dh-testimonial-name {
	font-weight: 700;
	margin: 0;
}

.dh-testimonial-stars {
	margin: 0.25rem 0 0 0;
	letter-spacing: 0.12em;
	color: #d4af37;
}

.dh-assessment-page {
	gap: var(--wp--preset--spacing--l, 2rem);
}

.dh-assessment-hero,
.dh-assessment-glance,
.dh-assessment-pricing,
.dh-assessment-card {
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}

.dh-assessment-glance h3,
.dh-assessment-card h3 {
	margin-top: 0;
}

.dh-assessment-glance .wp-block-list,
.dh-assessment-glance .wp-block-list li {
	margin-top: 0;
}

.dh-assessment-steps {
	gap: var(--wp--preset--spacing--m, 1.5rem);
}

.dh-assessment-card {
	height: 100%;
}

.dh-assessment-tests .wp-block-columns {
	gap: var(--wp--preset--spacing--m, 1.5rem);
}

.dh-assessment-test-pill {
	height: 100%;
}

.dh-assessment-faq .wp-block-details summary {
	font-size: var(--wp--preset--font-size--medium, 1.25rem);
	font-weight: 700;
}

.dh-assessment-pricing .wp-block-buttons {
	margin-top: var(--wp--preset--spacing--s, 1rem);
}

@media (max-width: 781px) {
	.dh-assessment-page {
		gap: var(--wp--preset--spacing--m, 1.5rem);
	}
}

.is-style-dh-hero-welcome {
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.78)),
		url('assets/images/dyslexia.webp');
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.home .wp-block-group.alignfull.is-style-dh-hero-welcome {
	max-width: var(--wp--style--global--content-size, 1200px) !important;
	margin-right: auto !important;
	margin-left: auto !important;
}

.dh-home-hero-card {
	background-color: transparent;
	box-shadow: none;
}

.dh-home-hero-card h1,
.dh-home-hero-card h2,
.dh-home-hero-card p {
	text-shadow: 0 1px 2px rgba(255, 255, 255, 0.85);
}

.dh-home-hero-card p {
	font-weight: 700;
	color: var(--wp--preset--color--text, #2d2a32);
}

@media (max-width: 781px) {
	.is-style-dh-hero-welcome {
		padding-top: var(--wp--preset--spacing--xl, 3rem) !important;
		padding-bottom: var(--wp--preset--spacing--xl, 3rem) !important;
	}

	.is-style-dh-hero-welcome .dh-home-hero-card {
		padding-top: var(--wp--preset--spacing--m, 1.5rem) !important;
		padding-right: var(--wp--preset--spacing--m, 1.5rem) !important;
		padding-bottom: var(--wp--preset--spacing--m, 1.5rem) !important;
		padding-left: var(--wp--preset--spacing--m, 1.5rem) !important;
	}

	.is-style-dh-hero-welcome .dh-home-hero-card h1.wp-block-heading {
		font-size: clamp(1.35rem, 4vw + 0.75rem, 1.85rem);
		line-height: 1.22;
		letter-spacing: -0.015em;
	}

	.is-style-dh-hero-welcome .dh-home-hero-card p {
		font-size: var(--wp--preset--font-size--small, 0.95rem);
		font-weight: 600;
		line-height: 1.65;
	}

	.is-style-dh-hero-welcome .dh-home-hero-card .wp-block-buttons {
		flex-wrap: wrap;
		gap: var(--wp--preset--spacing--xs, 0.75rem);
	}

	.is-style-dh-hero-welcome .dh-home-hero-card .wp-block-button .wp-block-button__link {
		font-size: var(--wp--preset--font-size--small, 0.95rem);
	}
}

.dh-home-feature-card,
.dh-testimonial-card {
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}

.dh-home-services .wp-block-columns {
	gap: var(--wp--preset--spacing--m, 1.5rem);
}

.dh-home-feature-card {
	height: 100%;
}

.dh-home-feature-card h2 {
	margin-top: 0;
}

.dh-home-quotes .wp-block-quote {
	margin: 0 0 var(--wp--preset--spacing--s, 1rem) 0;
	padding: var(--wp--preset--spacing--m, 1.5rem);
	border-left: 4px solid var(--wp--preset--color--primary, #b03070);
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.75);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}

.home .dh-home-quotes > .wp-block-heading {
	margin-bottom: var(--wp--preset--spacing--m, 1.5rem);
}

.home .dh-testimonials > .wp-block-heading {
	text-align: left !important;
}

.home .is-style-dh-hero-strengths {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/*
 * Meet Magda page — hero, two-column biography, sidebar highlights, credential list.
 */
.dh-meet-magda-page {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--xl, 3rem);
}

.dh-meet-magda-card {
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}

.dh-meet-magda-heading-icon {
	margin-right: 0.4em;
	font-style: normal;
	vertical-align: -0.06em;
}

.dh-meet-magda-prose > *:first-child {
	margin-top: 0;
}

.dh-meet-magda-highlights {
	height: 100%;
	box-shadow: 0 2px 14px rgba(0, 0, 0, 0.05);
	min-height: 100%;
	display: flex;
	flex-direction: column;
}

.dh-meet-magda-highlights h3 {
	font-size: var(--wp--preset--font-size--medium, 1.125rem);
	color: var(--wp--preset--color--heading, #b03070);
	font-family: "Be Vietnam Pro", ui-sans-serif, system-ui, sans-serif;
}

.dh-meet-magda-highlight-list {
	margin-top: 0;
	margin-bottom: 0;
	padding-inline-start: 1.35rem;
	list-style: disc;
}

.dh-meet-magda-highlight-list li {
	padding-bottom: var(--wp--preset--spacing--xs, 0.75rem);
	line-height: 1.55;
}

.dh-meet-magda-highlight-list li:last-child {
	padding-bottom: 0;
}

.dh-meet-magda-qualifications {
	box-shadow: 0 2px 14px rgba(0, 0, 0, 0.05);
	border-left: 5px solid var(--wp--preset--color--primary, #b03070);
	position: relative;
	overflow: hidden;
}

.dh-meet-magda-qualifications::before {
	content: "";
	position: absolute;
	inset-inline-end: -16%;
	inset-block-start: -35%;
	width: clamp(220px, 52%, 460px);
	height: clamp(220px, 52%, 460px);
	background: radial-gradient(
		circle,
		rgba(176, 48, 112, 0.1) 0%,
		transparent 62%
	);
	pointer-events: none;
	z-index: 0;
	border-radius: 50%;
}

.dh-meet-magda-qualifications > * {
	position: relative;
	z-index: 1;
}

.dh-meet-magda-credentials-list {
	margin-bottom: 0;
	padding-inline-start: 1.35rem;
	list-style: disc;
	column-count: 1;
}

@media (min-width: 782px) {
	.dh-meet-magda-credentials-list {
		column-count: 2;
		column-gap: var(--wp--preset--spacing--xl, 3rem);
	}

	.dh-meet-magda-credentials-list li {
		break-inside: avoid-column;
	}
}

.dh-meet-magda-credentials-list li {
	line-height: 1.58;
	padding-bottom: var(--wp--preset--spacing--xs, 0.75rem);
}

@media (max-width: 781px) {
	.dh-meet-magda-bio-columns .wp-block-column {
		flex-basis: 100% !important;
	}
}

/*
 * Services page — stacked sections and hero.
 */
.dh-services-page {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--l, 2rem);
}

.dh-services-card {
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}

.dh-services-title .wp-block-heading,
.dh-services-card .wp-block-heading:first-child {
	margin-top: 0;
}

.dh-services-title-row .wp-block-heading:first-child {
	margin-top: 0;
}

@media (max-width: 781px) {
	.dh-services-title-columns .wp-block-column {
		flex-basis: 100% !important;
	}
}

/* WhatsApp section: title + icon on one row */
.dh-services-whatsapp-heading-row.is-layout-flex,
.dh-services-whatsapp-heading-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.65rem;
}

.dh-services-whatsapp-heading-row .wp-block-heading {
	margin: 0;
	line-height: 1.25;
}

.dh-services-whatsapp-heading-row .wp-block-social-links {
	margin: 0;
}

/* WhatsApp brand green for Services page icon (overrides primary pink on this block). */
.dh-services-whatsapp-social .wp-block-social-link a {
	color: #25d366;
}

.dh-services-whatsapp-social .wp-block-social-link svg {
	fill: currentColor;
}

/*
 * Contact page — layout and form.
 */
.dh-contact-columns .wp-block-column {
	min-width: 0;
}

@media (max-width: 781px) {
	.dh-contact-columns .wp-block-column {
		flex-basis: 100% !important;
	}
}

.dh-contact-form-card .wp-block-heading {
	margin-top: 0;
}

.dh-contact-form {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--m, 1.25rem);
	margin: 0;
}

.dh-contact-form .dh-contact-field {
	margin: 0;
}

.dh-contact-form .dh-contact-field label {
	display: block;
	font-weight: 700;
	font-size: var(--wp--preset--font-size--small, 0.95rem);
	margin-bottom: 0.35rem;
	color: var(--wp--preset--color--text, #4a4a4a);
}

.dh-contact-form .dh-contact-required {
	color: var(--wp--preset--color--primary, #b03070);
	font-weight: 700;
}

.dh-contact-form input[type="text"],
.dh-contact-form input[type="email"],
.dh-contact-form input[type="tel"],
.dh-contact-form textarea {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 0.65rem 0.75rem;
	border: 1px solid var(--wp--preset--color--muted, #6d6e71);
	border-radius: 10px;
	font-family: var(--wp--preset--font-family--nunito-sans, inherit);
	font-size: var(--wp--preset--font-size--medium, 1rem);
	color: var(--wp--preset--color--text, #4a4a4a);
	background: var(--wp--preset--color--surface, #fff);
}

.dh-contact-form textarea {
	resize: vertical;
	min-height: 8rem;
	line-height: 1.55;
}

.dh-contact-form input:focus-visible,
.dh-contact-form textarea:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #b03070);
	outline-offset: 2px;
	border-color: var(--wp--preset--color--primary, #b03070);
}

.dh-contact-form .dh-contact-field--hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.dh-contact-actions {
	margin-top: 0.25rem;
}

.dh-contact-submit {
	cursor: pointer;
	border: 2px solid var(--wp--preset--color--primary, #b03070);
	border-radius: 10px;
	background: var(--wp--preset--color--primary, #b03070);
	color: #fff;
	font-weight: 700;
	padding: 0.7rem 1.25rem;
	font-family: var(--wp--preset--font-family--nunito-sans, inherit);
	font-size: var(--wp--preset--font-size--small, 0.95rem);
	transition: background 0.15s ease, border-color 0.15s ease;
}

.dh-contact-submit:hover,
.dh-contact-submit:focus-visible {
	background: var(--wp--preset--color--primary-strong, #8c2658);
	border-color: var(--wp--preset--color--primary-strong, #8c2658);
}

.dh-contact-form-notice {
	margin: 0 0 var(--wp--preset--spacing--m, 1.25rem) 0;
	padding: 0.75rem 1rem;
	border-radius: 10px;
	font-size: var(--wp--preset--font-size--small, 0.95rem);
}

.dh-contact-form-success {
	background: rgba(14, 165, 233, 0.12);
	border: 1px solid var(--wp--preset--color--accent-dark, #0369a1);
	color: var(--wp--preset--color--accent-dark, #0369a1);
}

.dh-contact-form-error {
	background: rgba(176, 48, 112, 0.08);
	border: 1px solid var(--wp--preset--color--primary-strong, #8c2658);
	color: var(--wp--preset--color--primary-strong, #8c2658);
}
