/* Unique Mind Counselling — theme styles.
   Tokens injected as :root vars from Assets::css_vars(). */

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
body {
	margin: 0;
	background: var(--umc-surface-bright);
	color: var(--umc-on-surface);
	font-family: var(--umc-font-body);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--umc-secondary); text-decoration: none; transition: color .3s; }
a:hover { color: var(--umc-primary); }
h1, h2, h3, h4 {
	font-family: var(--umc-font-display);
	color: var(--umc-primary);
	font-weight: 500;
	line-height: 1.3;
	margin: 0 0 1rem;
}
h2 { font-size: 32px; }
h3 { font-size: 24px; line-height: 1.4; }
h4 { font-size: 20px; }
p { margin: 0 0 1rem; color: var(--umc-on-surface-variant); }

.screen-reader-text {
	clip: rect(1px,1px,1px,1px); position: absolute !important;
	height: 1px; width: 1px; overflow: hidden;
}
.umc-skip-link {
	position: absolute; left: -9999px; top: 0; z-index: 100;
	background: var(--umc-primary); color: #fff; padding: .75rem 1.25rem;
}
.umc-skip-link:focus { left: 0; color: #fff; }
:focus-visible { outline: 2px solid var(--umc-secondary); outline-offset: 2px; }

.material-symbols-outlined { font-variation-settings: 'FILL' 0, 'wght' 200, 'GRAD' 0, 'opsz' 24; vertical-align: middle; }
.icon-fill { font-variation-settings: 'FILL' 1, 'wght' 200; }

/* ---------- Layout ---------- */
.umc-container { max-width: var(--umc-container); margin: 0 auto; padding-left: 20px; padding-right: 20px; }
.umc-container--narrow { max-width: 800px; }
.umc-container--cta { max-width: 1000px; }
@media (min-width: 768px) {
	.umc-container { padding-left: 64px; padding-right: 64px; }
}
.umc-section { padding-top: 120px; padding-bottom: 120px; }
.umc-section--sm { padding-top: 64px; padding-bottom: 64px; }
.umc-section--container { background: var(--umc-surface-container); }
.umc-section--low { background: var(--umc-surface-low); }
@media (max-width: 767px) {
	.umc-section { padding-top: 72px; padding-bottom: 72px; }
}
.umc-center { text-align: center; }
.umc-main { padding-top: 88px; }

.umc-grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 768px) {
	.umc-grid--2 { grid-template-columns: repeat(2, 1fr); }
	.umc-grid--3 { grid-template-columns: repeat(3, 1fr); }
	.umc-grid--4 { grid-template-columns: repeat(4, 1fr); }
}
.umc-split { display: grid; gap: 48px; grid-template-columns: 1fr; align-items: center; }
@media (min-width: 1024px) { .umc-split { grid-template-columns: 1fr 1fr; gap: 24px; } }

/* ---------- Typography helpers ---------- */
.umc-display {
	font-family: var(--umc-font-display);
	font-size: 36px; font-weight: 600; line-height: 1.2; letter-spacing: -0.01em;
}
@media (min-width: 768px) { .umc-display { font-size: 48px; } }
.umc-lead { font-size: 18px; line-height: 1.7; }
.umc-eyebrow {
	display: block; font-size: 14px; font-weight: 600; letter-spacing: .12em;
	text-transform: uppercase; color: var(--umc-secondary); margin-bottom: 1.25rem;
}
.umc-section__head { text-align: center; max-width: 640px; margin: 0 auto 4rem; }
.umc-section__more { text-align: center; margin-top: 3rem; }
.umc-note { font-size: 14px; background: var(--umc-surface-low); border-left: 3px solid var(--umc-primary-container); padding: .75rem 1rem; border-radius: 0 var(--umc-radius-xl) var(--umc-radius-xl) 0; }

/* ---------- Buttons ---------- */
.umc-btn {
	display: inline-flex; align-items: center; gap: .5rem;
	font-family: var(--umc-font-body); font-size: 14px; font-weight: 600; letter-spacing: .05em;
	padding: 1rem 2rem; border-radius: 9999px; border: 0; cursor: pointer;
	transition: all .3s cubic-bezier(.4,0,.2,1); text-decoration: none;
}
.umc-btn--primary { background: var(--umc-primary-container); color: var(--umc-on-primary); }
.umc-btn--primary:hover { box-shadow: 0 10px 25px rgba(45,49,48,.15); transform: translateY(-2px); color: #fff; }
.umc-btn--outline { background: transparent; border: 1px solid var(--umc-secondary); color: var(--umc-secondary); }
.umc-btn--outline:hover { background: rgba(55,102,102,.05); }

/* ---------- Nav ---------- */
.umc-nav {
	position: fixed; top: 0; left: 0; right: 0; z-index: 40;
	background: rgba(250,249,246,.85); backdrop-filter: blur(12px);
	box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.umc-nav__inner { display: flex; align-items: center; justify-content: space-between; padding-top: 1rem; padding-bottom: 1rem; }
.umc-nav__brand { font-family: var(--umc-font-display); font-size: 24px; font-weight: 500; color: var(--umc-primary); }
.umc-nav__links { display: none; align-items: center; gap: 2rem; }
.umc-nav__menu { display: flex; align-items: center; gap: 2rem; list-style: none; margin: 0; padding: 0; }
.umc-nav__menu a { font-size: 14px; font-weight: 600; letter-spacing: .05em; color: var(--umc-on-surface-variant); padding-bottom: 4px; }
.umc-nav__menu a:hover { color: var(--umc-primary); }
.umc-nav__menu .current-menu-item > a,
.umc-nav__menu .current_page_item > a { color: var(--umc-primary); border-bottom: 2px solid var(--umc-primary); }
.umc-nav__toggle { display: inline-flex; background: none; border: 0; color: var(--umc-primary); padding: .5rem; cursor: pointer; }
@media (min-width: 1024px) {
	.umc-nav__links { display: flex; }
	.umc-nav__toggle { display: none; }
}
@media (max-width: 1023px) {
	.umc-nav__links.is-open {
		display: flex; flex-direction: column; align-items: flex-start;
		position: absolute; top: 100%; left: 0; right: 0;
		background: var(--umc-surface-lowest); padding: 1.5rem 20px 2rem;
		box-shadow: 0 15px 35px rgba(45,49,48,.08); gap: 1rem;
	}
	.umc-nav__links.is-open .umc-nav__menu { flex-direction: column; align-items: flex-start; gap: 1rem; }
}

/* ---------- Hero ---------- */
.umc-hero { padding-top: 48px; }
@media (min-width: 768px) { .umc-hero { padding-top: 80px; } }
.umc-hero__grid { display: grid; gap: 48px; grid-template-columns: 1fr; align-items: center; }
@media (min-width: 1024px) { .umc-hero__grid { grid-template-columns: 1fr 1fr; gap: 24px; } }
.umc-hero__copy { max-width: 36rem; }
.umc-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.umc-hero__media, .umc-split__media img, .umc-service-hero__media img, .umc-post-hero img {
	border-radius: var(--umc-radius-2xl); overflow: hidden;
	box-shadow: 0 20px 40px rgba(45,49,48,.08);
}
.umc-hero__media img { width: 100%; height: 500px; object-fit: cover; border-radius: var(--umc-radius-2xl); }
@media (min-width: 1024px) { .umc-hero__media img { height: 600px; } }
.umc-split__media img { width: 100%; height: 400px; object-fit: cover; }
@media (min-width: 1024px) { .umc-split__media img { height: 500px; } }

/* ---------- Cards ---------- */
.umc-card {
	background: var(--umc-surface-lowest);
	border-radius: var(--umc-radius-2xl);
	padding: 2rem;
	box-shadow: 0 1px 2px rgba(0,0,0,.04);
	transition: all .4s ease;
	position: relative;
}
@media (min-width: 768px) { .umc-card--service { padding: 3rem; } }
.umc-card:hover { transform: translateY(-4px); box-shadow: 0 15px 35px rgba(45,49,48,.08); }
.umc-card__icon { font-size: 36px !important; color: var(--umc-secondary); display: block; margin-bottom: 1.5rem; }
.umc-card__title { margin-bottom: 1rem; }
.umc-card__title a { color: var(--umc-primary); }
.umc-card__text { margin-bottom: 2rem; }
.umc-card__link {
	font-size: 14px; font-weight: 600; letter-spacing: .05em;
	display: inline-flex; align-items: center; gap: .5rem; color: var(--umc-secondary);
}
.umc-card__link:hover { color: var(--umc-primary); }
.umc-card__date { font-size: 12px; letter-spacing: .05em; text-transform: uppercase; margin: 1rem 0 .5rem; }
.umc-card__media { display: block; margin: -2rem -2rem 0; border-radius: var(--umc-radius-2xl) var(--umc-radius-2xl) 0 0; overflow: hidden; }
.umc-card__media img { width: 100%; height: 200px; object-fit: cover; }
.umc-card--step { text-align: left; }
.umc-card--step__num {
	font-family: var(--umc-font-display); font-size: 40px; font-weight: 600;
	color: var(--umc-primary-container); display: block; margin-bottom: .75rem;
}

/* ---------- Bento / features / tiles ---------- */
.umc-bento { display: grid; gap: 48px; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .umc-bento { grid-template-columns: 1fr 2fr; gap: 24px; } }
.umc-feature { display: flex; gap: 1rem; align-items: flex-start; margin-bottom: 2rem; }
.umc-feature__icon {
	width: 48px; height: 48px; border-radius: 9999px; flex-shrink: 0;
	background: var(--umc-surface-container); display: inline-flex; align-items: center; justify-content: center;
	color: var(--umc-secondary);
}
.umc-tile {
	background: var(--umc-surface-lowest); border: 1px solid rgba(227,226,223,.5);
	border-radius: var(--umc-radius-xl); min-height: 160px; padding: 1.5rem;
	display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center;
	transition: all .4s ease;
}
.umc-tile:hover { transform: translateY(-4px); box-shadow: 0 15px 35px rgba(45,49,48,.08); }
.umc-tile__icon { font-size: 32px !important; color: var(--umc-secondary); margin-bottom: .75rem; }
.umc-tile span:last-child { font-size: 14px; font-weight: 600; letter-spacing: .05em; color: var(--umc-primary); }
.umc-grid--tiles { grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .umc-grid--tiles { grid-template-columns: repeat(3, 1fr); } }

/* ---------- Tags ---------- */
.umc-areas { border-top: 1px solid rgba(227,226,223,.3); border-bottom: 1px solid rgba(227,226,223,.3); background: var(--umc-surface); }
.umc-areas__inner { text-align: center; }
.umc-areas__link { margin-top: 1.5rem; font-size: 14px; font-weight: 600; }
.umc-tags { display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; }
.umc-split .umc-tags, .umc-meta-chips { justify-content: flex-start; }
.umc-tag {
	display: inline-flex; align-items: center; gap: .35rem;
	padding: .5rem 1.5rem; border-radius: 9999px;
	background: var(--umc-primary-fixed); color: var(--umc-on-primary-fixed);
	font-size: 14px; font-weight: 600; letter-spacing: .02em;
}
.umc-tag .material-symbols-outlined { font-size: 18px !important; }
.umc-tag--solid { background: var(--umc-primary-container); color: #fff; }
.umc-meta-chips { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1.5rem 0; }

/* ---------- Accordion ---------- */
.umc-accordion { display: flex; flex-direction: column; gap: 1rem; margin-top: 3rem; }
.umc-accordion__item {
	border: 1px solid var(--umc-surface-variant); border-radius: var(--umc-radius-xl);
	background: var(--umc-surface-lowest); overflow: hidden;
}
.umc-accordion__toggle {
	width: 100%; display: flex; justify-content: space-between; align-items: center;
	padding: 1.5rem; background: none; border: 0; cursor: pointer; text-align: left;
	font-family: var(--umc-font-display); font-size: 20px; color: var(--umc-primary);
}
.umc-accordion__toggle .material-symbols-outlined { color: var(--umc-secondary); transition: transform .3s; }
.umc-accordion__toggle[aria-expanded="true"] .material-symbols-outlined { transform: rotate(180deg); }
.umc-accordion__body { padding: 0 1.5rem 1.5rem; }

/* ---------- CTA banner ---------- */
.umc-cta {
	background: var(--umc-surface-container); border-radius: 2rem;
	padding: 3rem 1.5rem; text-align: center; position: relative; overflow: hidden;
}
@media (min-width: 768px) { .umc-cta { padding: 5rem; } }
.umc-cta::before, .umc-cta::after {
	content: ""; position: absolute; border-radius: 50%; pointer-events: none; filter: blur(48px);
}
.umc-cta::before { width: 260px; height: 260px; top: 0; right: 0; transform: translate(50%,-50%); background: rgba(74,101,79,.06); }
.umc-cta::after { width: 200px; height: 200px; bottom: 0; left: 0; transform: translate(-50%,50%); background: rgba(139,78,61,.06); }
.umc-cta > * { position: relative; z-index: 1; }
.umc-cta .umc-lead { max-width: 640px; margin-left: auto; margin-right: auto; margin-bottom: 2.5rem; }

/* ---------- Checklist / prose ---------- */
.umc-checklist { list-style: none; padding: 0; margin: 0; }
.umc-checklist li { display: flex; gap: .6rem; align-items: flex-start; margin-bottom: .85rem; color: var(--umc-on-surface-variant); }
.umc-checklist .material-symbols-outlined { color: var(--umc-primary-container); font-size: 22px !important; margin-top: 2px; }
.umc-prose ul { padding-left: 1.25rem; color: var(--umc-on-surface-variant); }
.umc-prose li { margin-bottom: .4rem; }
.umc-prose h2, .umc-prose h3 { margin-top: 2.25rem; }

/* ---------- Service hero ---------- */
.umc-page-hero { padding-bottom: 48px; }
.umc-service-hero__grid { display: grid; gap: 48px; grid-template-columns: 1fr; align-items: center; }
@media (min-width: 1024px) { .umc-service-hero__grid { grid-template-columns: 3fr 2fr; gap: 24px; } }
.umc-service-hero__media img { width: 100%; height: 420px; object-fit: cover; }
.umc-service-hero__icon {
	height: 320px; border-radius: var(--umc-radius-2xl);
	background: var(--umc-surface-container); display: flex; align-items: center; justify-content: center;
}
.umc-service-hero__icon .material-symbols-outlined { font-size: 110px !important; color: var(--umc-primary-container); }

/* ---------- Forms / modal ---------- */
.umc-form__row { margin-bottom: 1rem; }
.umc-form label { display: block; font-size: 14px; font-weight: 600; letter-spacing: .03em; margin-bottom: .35rem; color: var(--umc-on-surface); }
.umc-form input[type="text"], .umc-form input[type="email"], .umc-form input[type="tel"],
.umc-form select, .umc-form textarea {
	width: 100%; padding: .7rem .9rem; font: inherit;
	border: 1px solid var(--umc-outline-variant); border-radius: .375rem;
	background: var(--umc-surface-lowest); color: var(--umc-on-surface);
}
.umc-form input:focus, .umc-form select:focus, .umc-form textarea:focus {
	border-color: var(--umc-primary); outline: 2px solid transparent; box-shadow: 0 0 0 2px rgba(74,101,79,.25);
}
.umc-form__row--consent label { display: flex; gap: .6rem; font-weight: 400; font-size: 13px; align-items: flex-start; }
.umc-form__row--consent input { margin-top: 3px; }
.umc-form__hp { position: absolute; left: -9999px; opacity: 0; height: 0; overflow: hidden; }
.umc-form__status { min-height: 1.4em; font-size: 14px; font-weight: 600; }
.umc-form__status.is-error { color: #93000a; }
.umc-form__status.is-success { color: var(--umc-primary); }

.umc-modal[hidden] { display: none; }
.umc-modal { position: fixed; inset: 0; z-index: 50; display: flex; align-items: center; justify-content: center; padding: 1rem; }
.umc-modal__backdrop { position: absolute; inset: 0; background: rgba(47,49,47,.4); backdrop-filter: blur(4px); }
.umc-modal__panel {
	position: relative; width: 100%; max-width: 560px; max-height: 90vh; overflow-y: auto;
	background: var(--umc-surface-lowest); border-radius: var(--umc-radius-2xl);
	padding: 1.5rem; box-shadow: 0 25px 50px rgba(0,0,0,.15);
	animation: umcModalIn .3s cubic-bezier(.25,1,.5,1);
}
@keyframes umcModalIn { from { opacity: 0; transform: translateY(16px) scale(.97); } to { opacity: 1; transform: none; } }
.umc-modal__head { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--umc-surface-variant); padding-bottom: 1rem; margin-bottom: 1.25rem; }
.umc-modal__head h3 { margin: 0; }
.umc-modal__x { background: none; border: 0; cursor: pointer; color: var(--umc-on-surface-variant); }
.umc-modal__x:hover { color: var(--umc-primary); }
body.umc-modal-open { overflow: hidden; }

/* ---------- Contact ---------- */
.umc-contact-card { background: var(--umc-surface-lowest); border-radius: var(--umc-radius-2xl); padding: 2rem; box-shadow: 0 1px 2px rgba(0,0,0,.04); position: relative; }
.umc-contact-info ul { list-style: none; margin: 0 0 1.5rem; padding: 0; }
.umc-contact-info li { display: flex; gap: .6rem; align-items: center; margin-bottom: .75rem; color: var(--umc-on-surface-variant); }
.umc-contact-info .material-symbols-outlined { color: var(--umc-secondary); }
.umc-map { height: 320px; border-radius: var(--umc-radius-2xl); overflow: hidden; background: var(--umc-surface-container); }

/* ---------- Footer ---------- */
.umc-footer { background: var(--umc-surface-container); margin-top: 0; }
.umc-footer__grid { display: grid; gap: 24px; grid-template-columns: 1fr; padding-top: 64px; padding-bottom: 32px; }
@media (min-width: 768px) { .umc-footer__grid { grid-template-columns: 2fr 1fr 1fr; } }
.umc-footer__brand { font-size: 24px; margin-bottom: 1rem; }
.umc-footer h4 { font-family: var(--umc-font-body); font-size: 16px; font-weight: 700; }
.umc-footer__menu { list-style: none; margin: 0; padding: 0; }
.umc-footer__menu li { margin-bottom: .75rem; }
.umc-footer__menu a { color: var(--umc-on-surface-variant); display: inline-block; transition: transform .3s, color .3s; }
.umc-footer__menu a:hover { color: var(--umc-primary); transform: translateX(4px); }
.umc-footer__bottom { border-top: 1px solid rgba(227,226,223,.4); padding-top: 2rem; padding-bottom: 2rem; }
.umc-footer__bottom p { font-size: 14px; margin: 0; }

/* ---------- Pagination ---------- */
.umc-pagination { margin-top: 3rem; text-align: center; }
.umc-pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 40px; height: 40px; padding: 0 .75rem; margin: 0 .2rem;
	border-radius: 9999px; font-weight: 600; font-size: 14px;
	color: var(--umc-on-surface-variant); background: var(--umc-surface-lowest);
}
.umc-pagination .page-numbers.current { background: var(--umc-primary-container); color: #fff; }

/* ---------- Reveal animations ---------- */
@media (prefers-reduced-motion: no-preference) {
	.reveal-up { opacity: 0; transform: translateY(40px); transition: opacity 1s cubic-bezier(.25,1,.5,1), transform 1s cubic-bezier(.25,1,.5,1); }
	.reveal-scale { opacity: 0; transform: scale(.95); transition: opacity 1.2s cubic-bezier(.25,1,.5,1), transform 1.2s cubic-bezier(.25,1,.5,1); }
	.is-revealed { opacity: 1 !important; transform: translate(0) scale(1) !important; }
	.delay-100 { transition-delay: .1s; } .delay-200 { transition-delay: .2s; }
	.delay-300 { transition-delay: .3s; } .delay-400 { transition-delay: .4s; }
}
@media (prefers-reduced-motion: reduce) {
	.reveal-up, .reveal-scale { opacity: 1; transform: none; }
}
