/*
Theme Name: JSR Beresford
Theme URI: https://beresfordelectric.ca/
Description: Child theme for the JSR Beresford rebuild.
Author: Heather Pratt
Template: generatepress
Version: 0.1.0
Text Domain: jsr-beresford
*/

@font-face {
	font-family: "Kollektif";
	font-style: normal;
	font-weight: 400 800;
	font-display: swap;
	src:
		local("Kollektif"),
		url("assets/fonts/kollektif-webfont.woff2") format("woff2"),
		url("assets/fonts/kollektif-webfont.woff") format("woff");
}

:root {
	--jsr-font-heading: "Kollektif", "Avenir Next", Avenir, Montserrat, Arial, sans-serif;
	--jsr-font-body: "Gidole", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	--jsr-color-teal-700: #33897d;
	--jsr-color-teal-300: #9fcdc3;
	--jsr-color-teal-200: #c3dfd9;
	--jsr-color-coral-600: #e26a5e;
	--jsr-color-coral-300: #ecb2a2;
	--jsr-color-coral-200: #eecbbc;
	--jsr-color-gold-400: #fcd664;
	--jsr-color-cream-300: #f2e6bf;
	--jsr-color-cream-100: #f9f3df;
	--jsr-color-slate-800: #3b4752;
	--jsr-color-gray-500: #a9abab;
	--jsr-color-gray-200: #d6d8d9;
	--jsr-color-gray-100: #ebebed;

	--jsr-color-background: #ffffff;
	--jsr-color-surface: #ffffff;
	--jsr-color-surface-soft: var(--jsr-color-gray-100);
	--jsr-color-text: var(--jsr-color-slate-800);
	--jsr-color-text-muted: #5d6972;
	--jsr-color-border: var(--jsr-color-gray-200);
	--jsr-divider: 3px solid rgb(59 71 82 / 42%);
	--jsr-divider-light: 3px solid rgb(255 255 255 / 38%);
	--jsr-color-primary: var(--jsr-color-teal-700);
	--jsr-color-primary-soft: var(--jsr-color-teal-200);
	--jsr-color-accent: var(--jsr-color-coral-600);
	--jsr-color-accent-soft: var(--jsr-color-coral-200);
	--jsr-color-highlight: var(--jsr-color-gold-400);

	--jsr-radius-sm: 0.375rem;
	--jsr-radius-md: 0.5rem;
	--jsr-shadow-soft: 0 0.75rem 2rem rgb(59 71 82 / 8%);
	--jsr-shadow-menu: 0 1.25rem 3rem rgb(59 71 82 / 14%);
	--jsr-content-width: 72rem;
	--jsr-reading-width: 46rem;
	--jsr-motion-fast: 160ms ease;
	--jsr-motion-medium: 260ms cubic-bezier(0.22, 1, 0.36, 1);
	--jsr-motion-spring: 380ms cubic-bezier(0.34, 1.56, 0.64, 1);
	--jsr-header-h: clamp(6.2rem, 8.8vw, 7.7rem);
}

body {
	background: var(--jsr-color-background);
	color: var(--jsr-color-text);
	font-family: var(--jsr-font-body);
	font-size: 1rem;
	line-height: 1.65;
}

/* GP page-level containers — sections own their own internal padding */
.site,
.site-content,
#primary,
.site-main,
.inside-article,
.grid-container,
.container {
	margin: 0 !important;
	max-width: 100% !important;
	padding: 0 !important;
	width: 100%;
}

/* GP separate-containers mode adds margin/padding to .site-main and .inside-article
   — kill these globally since our templates own all layout */
.separate-containers .site-main,
.separate-containers .inside-article,
.right-sidebar .site-main,
.left-sidebar .site-main {
	margin: 0 !important;
	padding: 0 !important;
}

/* GP adds margin-bottom: 20px to every direct child of .site-main — kills section-to-section flow */
.site-main > * {
	margin-bottom: 0 !important;
}

/* Home page: pull hero up behind the sticky header so photo bleeds through */
.home .home-hero {
	margin-top: calc(-1 * var(--jsr-header-h));
}

.home .home-hero__content {
	padding-top: calc(var(--jsr-header-h) + clamp(2.5rem, 6vw, 5rem));
}

/* Home page: frosted glass so hero photo bleeds through the header */
.home .jsr-site-header {
	background: rgb(30 40 48 / 52%);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom-color: rgb(255 255 255 / 14%);
	box-shadow: none;
}

.home .jsr-site-header__logo img {
	opacity: 1;
}

h1,
h2,
h3,
h4,
h5,
h6,
.main-title,
.site-branding,
.button,
button,
input[type="button"],
input[type="submit"] {
	font-family: var(--jsr-font-heading);
	letter-spacing: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--jsr-color-slate-800);
	font-weight: 700;
	line-height: 1.12;
}

a {
	color: var(--jsr-color-primary);
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
}

a:hover,
a:focus {
	color: var(--jsr-color-accent);
}

/* Keyboard focus indicator — teal-700 passes 3:1 on both light and dark backgrounds. */
:focus-visible {
	outline: 2px solid var(--jsr-color-teal-700);
	outline-offset: 3px;
}

/* Hamburglar is on a dark header — use teal-300 for higher contrast against slate. */
.jsr-hamburglar:focus-visible {
	outline: 2px solid var(--jsr-color-teal-300);
	outline-offset: 4px;
}

::selection {
	background: var(--jsr-color-highlight);
	color: var(--jsr-color-slate-800);
}

.site-header,
.main-navigation,
.site-footer {
	background: var(--jsr-color-surface);
	color: var(--jsr-color-text);
}

.site-header,
#masthead {
	display: none !important;
}

.inside-header {
	gap: 1.5rem;
	padding-block: 1rem;
}

.site-logo,
.custom-logo-link {
	display: inline-flex;
	align-items: center;
	max-width: 100%;
}

.custom-logo {
	display: block;
	height: auto;
	max-height: 4.25rem;
	width: min(18rem, 56vw);
}

.site-branding {
	position: absolute;
	inline-size: 1px;
	block-size: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
}

.main-navigation .main-nav ul li a,
.main-navigation .menu-toggle,
.main-navigation .menu-bar-items {
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
}

.main-navigation {
	box-shadow: none;
}

.main-navigation .inside-navigation {
	min-height: 4rem;
}

.main-navigation .main-nav > ul > li > a {
	position: relative;
}

.main-navigation .main-nav > ul > li > a::after {
	background: var(--jsr-color-highlight);
	block-size: 0.18rem;
	border-radius: 999px;
	content: "";
	inline-size: calc(100% - 2.5rem);
	inset-block-end: 0.7rem;
	inset-inline-start: 1.25rem;
	position: absolute;
	transform: scaleX(0);
	transform-origin: left center;
}

.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li:focus > a,
.main-navigation .main-nav ul li[class*="current-menu-"] > a {
	color: var(--jsr-color-primary);
}

.main-navigation .main-nav > ul > li:hover > a::after,
.main-navigation .main-nav > ul > li:focus-within > a::after,
.main-navigation .main-nav > ul > li[class*="current-menu-"] > a::after {
	transform: scaleX(1);
}

.main-navigation ul ul {
	background: #ffffff;
	border: 1px solid var(--jsr-color-border);
	border-radius: var(--jsr-radius-md);
	box-shadow: var(--jsr-shadow-menu);
	overflow: hidden;
	padding-block: 0.45rem;
	transform: translateY(0.5rem);
}

.main-navigation:not(.toggled) ul li:hover > ul,
.main-navigation:not(.toggled) ul li.sfHover > ul,
.main-navigation:not(.toggled) ul li:focus-within > ul {
	transform: translateY(0);
}

.main-navigation .main-nav ul ul li a {
	color: var(--jsr-color-text);
	line-height: 1.25;
	padding: 0.75rem 1rem;
}

.main-navigation .main-nav ul ul li a:hover,
.main-navigation .main-nav ul ul li a:focus {
	background: var(--jsr-color-cream-100);
	color: var(--jsr-color-primary);
}

.main-navigation .main-nav > ul > li:last-child > a {
	background: var(--jsr-color-primary);
	border-radius: var(--jsr-radius-sm);
	color: #ffffff;
	line-height: 1.2;
	margin-inline-start: 0.65rem;
	padding-block: 0.8rem;
}

.main-navigation .main-nav > ul > li:last-child > a::after {
	display: none;
}

.main-navigation .main-nav > ul > li:last-child > a:hover,
.main-navigation .main-nav > ul > li:last-child > a:focus {
	background: var(--jsr-color-slate-800);
	color: #ffffff;
}

body {
	min-height: 100vh;
	overflow-x: hidden;
}

/* Custom scrollbar — dark teal brand colour */
:root {
	scrollbar-color: var(--jsr-color-teal-700) transparent;
	scrollbar-width: thin;
}

::-webkit-scrollbar {
	width: 7px;
}

::-webkit-scrollbar-track {
	background: transparent;
}

::-webkit-scrollbar-thumb {
	background: var(--jsr-color-teal-700);
	border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--jsr-color-teal-300);
}

.site-header,
.main-navigation {
	display: none;
}

.jsr-site-header {
	background: var(--jsr-color-slate-800);
	border-bottom: 1px solid rgb(255 255 255 / 12%);
	box-shadow: 0 0.75rem 2rem rgb(0 0 0 / 18%);
	color: #ffffff;
	inset-block-start: 0;
	inset-inline: 0;
	position: sticky;
	transition:
		background-color 240ms ease,
		border-color 240ms ease,
		box-shadow 240ms ease;
	z-index: 1000;
}

/* Header is always sticky and visible — no transparent-over-hero treatment */

.jsr-site-header__inner {
	align-items: center;
	display: flex;
	gap: clamp(1.5rem, 2.5vw, 2.5rem);
	min-height: clamp(4.5rem, 7vw, 6rem);
	padding: 0.85rem clamp(1rem, 3vw, 2.5rem);
	position: relative;
}

.jsr-site-header__right {
	align-items: center;
	display: flex;
	flex-shrink: 0;
	gap: clamp(0.75rem, 1.5vw, 1.25rem);
	margin-left: auto;
}

.jsr-site-header__logo {
	display: inline-flex;
	flex-shrink: 0;
	text-decoration: none;
}

.jsr-site-header__logo img {
	display: block;
	filter: brightness(0) invert(1);
	height: auto;
	max-height: clamp(3rem, 5vw, 4.4rem);
	opacity: 0.9;
	width: clamp(10.5rem, 17vw, 16rem);
}

/* ── Hamburglar ─────────────────────────────────────────────────────────── */
/* !important on background/border: overrides the global button reset below */
.jsr-hamburglar {
	-webkit-touch-callout: none;
	appearance: none;
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	cursor: pointer;
	display: block;
	flex-shrink: 0;
	height: 48px;
	padding: 0 !important;
	position: relative;
	user-select: none;
	width: 48px;
}

/* Masked sweep layer */
.jsr-hamburglar .path-burger {
	display: block;
	height: 48px;
	left: 0;
	mask: url('#jsr-ham-mask');
	-webkit-mask: url('#jsr-ham-mask');
	position: absolute;
	top: 0;
	width: 48px;
}

.jsr-hamburglar .animate-path {
	display: block;
	height: 48px;
	left: 0;
	position: absolute;
	top: 0;
	width: 48px;
}

/* Square that rotates behind the mask to create the sweep effect */
.jsr-hamburglar .path-rotation {
	display: block;
	height: 24px;
	margin: 24px 24px 0 0;
	transform: rotate(0deg);
	transform-origin: 100% 0;
	width: 24px;
}

.jsr-hamburglar .path-rotation::before {
	background: var(--jsr-color-teal-300);
	content: '';
	display: block;
	height: 24px;
	margin: 0 4px 0 0;
	width: 20px;
}

/* Burger icon lines */
.jsr-hamburglar .burger-icon {
	display: block;
	height: 48px;
	left: 0;
	padding: 14px 11px;
	position: absolute;
	top: 0;
	width: 48px;
}

.jsr-hamburglar .burger-container {
	display: block;
	height: 20px;
	position: relative;
	width: 26px;
}

.jsr-hamburglar .burger-bun-top,
.jsr-hamburglar .burger-bun-bot,
.jsr-hamburglar .burger-filling {
	background: #ffffff;
	border-radius: 1px;
	display: block;
	height: 2px;
	position: absolute;
	width: 26px;
}

.jsr-hamburglar .burger-bun-top {
	top: 0;
	transform-origin: 24px 1px;
}

.jsr-hamburglar .burger-bun-bot {
	bottom: 0;
	transform-origin: 24px 1px;
}

.jsr-hamburglar .burger-filling {
	top: 9px;
}

/* SVG ring */
.jsr-hamburglar .burger-ring {
	display: block;
	height: 48px;
	left: 0;
	position: absolute;
	top: 0;
	width: 48px;
}

.jsr-hamburglar .svg-ring {
	display: block;
	height: 48px;
	width: 48px;
}

.jsr-hamburglar .path {
	stroke: var(--jsr-color-teal-300);
	stroke-dasharray: 240;
	stroke-dashoffset: 240;
	stroke-linejoin: round;
}

/* Open → animate to X + ring draw */
.jsr-hamburglar.is-open .path          { animation: jsr-ham-dash-in 0.6s linear forwards; }
.jsr-hamburglar.is-open .animate-path  { animation: jsr-ham-rotate-in 0.6s linear forwards; }
.jsr-hamburglar.is-open .burger-bun-top  { animation: jsr-ham-bun-top-out 0.6s linear forwards; }
.jsr-hamburglar.is-open .burger-bun-bot  { animation: jsr-ham-bun-bot-out 0.6s linear forwards; }
.jsr-hamburglar.is-open .burger-filling  { animation: jsr-ham-fill-out 0.6s linear forwards; }

/* Closed → animate back to burger */
.jsr-hamburglar.is-closed .path          { animation: jsr-ham-dash-out 0.6s linear forwards; }
.jsr-hamburglar.is-closed .animate-path  { animation: jsr-ham-rotate-out 0.6s linear forwards; }
.jsr-hamburglar.is-closed .burger-bun-top  { animation: jsr-ham-bun-top-in 0.6s linear forwards; }
.jsr-hamburglar.is-closed .burger-bun-bot  { animation: jsr-ham-bun-bot-in 0.6s linear forwards; }
.jsr-hamburglar.is-closed .burger-filling  { animation: jsr-ham-fill-in 0.6s linear forwards; }

@keyframes jsr-ham-dash-in {
	0%   { stroke-dashoffset: 240; }
	40%  { stroke-dashoffset: 240; }
	100% { stroke-dashoffset: 0; }
}

@keyframes jsr-ham-dash-out {
	0%   { stroke-dashoffset: 0; }
	40%  { stroke-dashoffset: 240; }
	100% { stroke-dashoffset: 240; }
}

@keyframes jsr-ham-rotate-out {
	0%   { transform: rotate(0deg); }
	40%  { transform: rotate(180deg); }
	100% { transform: rotate(360deg); }
}

@keyframes jsr-ham-rotate-in {
	0%   { transform: rotate(360deg); }
	40%  { transform: rotate(180deg); }
	100% { transform: rotate(0deg); }
}

@keyframes jsr-ham-bun-top-out {
	0%   { left: 0; top: 0; transform: rotate(0deg); }
	20%  { left: 0; top: 0; transform: rotate(15deg); }
	80%  { left: -5px; top: 0; transform: rotate(-60deg); }
	100% { left: -5px; top: 1px; transform: rotate(-45deg); }
}

@keyframes jsr-ham-bun-bot-out {
	0%   { left: 0; transform: rotate(0deg); }
	20%  { left: 0; transform: rotate(-15deg); }
	80%  { left: -5px; transform: rotate(60deg); }
	100% { left: -5px; transform: rotate(45deg); }
}

@keyframes jsr-ham-bun-top-in {
	0%   { left: -5px; transform: rotate(-45deg); }
	20%  { left: -5px; transform: rotate(-60deg); }
	80%  { left: 0; transform: rotate(15deg); }
	100% { left: 0; transform: rotate(0deg); }
}

@keyframes jsr-ham-bun-bot-in {
	0%   { left: -5px; transform: rotate(45deg); }
	20%  { left: -5px; transform: rotate(60deg); }
	80%  { left: 0; transform: rotate(-15deg); }
	100% { left: 0; transform: rotate(0deg); }
}

@keyframes jsr-ham-fill-out {
	0%   { left: 0; width: 26px; }
	20%  { left: -6px; width: 32px; }
	40%  { left: 30px; width: 0; }
	100% { left: 26px; width: 0; }
}

@keyframes jsr-ham-fill-in {
	0%   { left: 26px; width: 0; }
	40%  { left: 30px; width: 0; }
	80%  { left: -6px; width: 26px; }
	100% { left: 0; width: 26px; }
}

/* Reduced-motion: snap to final state, no animation */
@media (prefers-reduced-motion: reduce) {
	.jsr-hamburglar.is-open .path,
	.jsr-hamburglar.is-closed .path,
	.jsr-hamburglar.is-open .animate-path,
	.jsr-hamburglar.is-closed .animate-path,
	.jsr-hamburglar.is-open .burger-bun-top,
	.jsr-hamburglar.is-open .burger-bun-bot,
	.jsr-hamburglar.is-open .burger-filling,
	.jsr-hamburglar.is-closed .burger-bun-top,
	.jsr-hamburglar.is-closed .burger-bun-bot,
	.jsr-hamburglar.is-closed .burger-filling { animation: none; }

	.jsr-hamburglar.is-open .burger-bun-top { left: -5px; top: 1px; transform: rotate(-45deg); }
	.jsr-hamburglar.is-open .burger-bun-bot { left: -5px; transform: rotate(45deg); }
	.jsr-hamburglar.is-open .burger-filling  { left: 26px; width: 0; }
	.jsr-hamburglar.is-open .path            { stroke-dashoffset: 0; }
}

.jsr-quick-nav {
	align-items: center;
	display: flex;
	flex: 1;
	font-family: var(--jsr-font-heading);
	font-size: clamp(0.78rem, 0.9vw, 0.86rem);
	font-weight: 700;
	gap: clamp(0.75rem, 1.8vw, 1.5rem);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.jsr-quick-nav a,
.jsr-language-trigger {
	color: rgba(255, 255, 255, 0.88);
	text-decoration: none;
}

.jsr-quick-nav a:hover,
.jsr-quick-nav a:focus {
	color: var(--jsr-color-teal-300);
}

.jsr-quick-nav > a,
.jsr-quick-nav__item > a,
.jsr-language-trigger {
	align-items: center;
	display: inline-flex;
	gap: 0.35rem;
	min-height: 2.75rem;
}

.jsr-quick-nav__item {
	position: relative;
}

.jsr-quick-nav__item::before {
	block-size: 0.9rem;
	content: "";
	inset-block-start: 100%;
	inset-inline: -0.75rem;
	position: absolute;
	z-index: 1;
}

.jsr-quick-nav__item > a::after,
.jsr-language-trigger::after {
	border-block-start: 0.34rem solid currentColor;
	border-inline: 0.28rem solid transparent;
	content: "";
	display: inline-block;
	transform: translateY(0.08rem) rotate(0deg);
	transform-origin: center;
}

.jsr-quick-nav__item.is-open > a::after,
.jsr-quick-nav__item:focus-within > a::after,
.jsr-quick-nav__item:hover > a::after,
.jsr-language-trigger:hover::after,
.jsr-language-trigger:focus::after {
	transform: translateY(-0.02rem) rotate(180deg);
}

.jsr-quick-nav__dropdown {
	background: #ffffff;
	border: 1px solid rgb(214 216 217 / 72%);
	border-radius: var(--jsr-radius-md);
	box-shadow: var(--jsr-shadow-menu);
	inline-size: min(17rem, 82vw);
	inset-block-start: calc(100% + 0.45rem);
	inset-inline-start: 0;
	opacity: 0;
	padding: 0.5rem;
	pointer-events: none;
	position: absolute;
	transform: translateY(0.55rem);
	visibility: hidden;
	z-index: 2;
}

.jsr-quick-nav__item:hover .jsr-quick-nav__dropdown,
.jsr-quick-nav__item:focus-within .jsr-quick-nav__dropdown,
.jsr-quick-nav__item.is-open .jsr-quick-nav__dropdown {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
	visibility: visible;
}

.jsr-quick-nav__dropdown a {
	border-radius: var(--jsr-radius-sm);
	color: var(--jsr-color-text);
	display: block;
	font-family: var(--jsr-font-body);
	font-size: 0.95rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.25;
	padding: 0.72rem 0.85rem;
	text-transform: none;
}

.jsr-quick-nav__dropdown a:hover,
.jsr-quick-nav__dropdown a:focus {
	background: var(--jsr-color-cream-100);
	color: var(--jsr-color-primary);
}

.jsr-header-phone {
	align-items: center;
	color: rgba(255, 255, 255, 0.88);
	display: inline-flex;
	font-family: var(--jsr-font-heading);
	font-size: 0.82rem;
	font-weight: 700;
	gap: 0.4rem;
	letter-spacing: 0.04em;
	text-decoration: none;
}

.jsr-header-phone svg {
	flex-shrink: 0;
	height: 1rem;
	width: 1rem;
}

.jsr-header-phone:hover {
	color: var(--jsr-color-teal-300);
}

.jsr-service-area {
	align-items: center;
	color: rgba(255, 255, 255, 0.75);
	display: inline-flex;
	font-family: var(--jsr-font-heading);
	font-size: 0.78rem;
	font-weight: 700;
	gap: 0.35rem;
	letter-spacing: 0.06em;
	text-decoration: none;
	text-transform: uppercase;
	white-space: nowrap;
}

.jsr-service-area svg {
	flex-shrink: 0;
	height: 1rem;
	width: 1rem;
}

.jsr-service-area:hover {
	color: var(--jsr-color-teal-300);
}

.jsr-contact-bubble {
	align-items: center;
	background: transparent;
	border: 1.5px solid rgba(255, 255, 255, 0.5);
	border-radius: 999px;
	color: #ffffff;
	display: inline-flex;
	font-family: var(--jsr-font-heading);
	font-size: 0.78rem;
	font-weight: 700;
	gap: 0.4rem;
	letter-spacing: 0.06em;
	padding: 0.55rem 1.1rem;
	text-decoration: none;
	text-transform: uppercase;
	transition: background var(--jsr-motion-fast), border-color var(--jsr-motion-fast), color var(--jsr-motion-fast);
	white-space: nowrap;
}

.jsr-contact-bubble:hover {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.85);
	color: #ffffff;
}

.jsr-menu-panel {
	background: rgb(59 71 82 / 94%);
	color: #ffffff;
	inset-inline: 0;
	position: absolute;
	top: 100%;
}

.jsr-menu-panel__inner {
	align-items: start;
	display: grid;
	gap: 0 2rem;
	grid-template-columns: repeat(3, minmax(0, 1fr)) minmax(14rem, 0.5fr);
	padding: 2rem clamp(1.5rem, 4vw, 3rem) 2.5rem;
}

/* Shared column styles */
.jsr-menu-panel__col {
	border-left: 1px solid rgb(255 255 255 / 12%);
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	padding-inline: 2rem;
}

.jsr-menu-panel__col:first-child {
	border-left: 0;
	padding-inline-start: 0;
}

.jsr-menu-panel__col-label {
	color: var(--jsr-color-teal-300);
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	margin-bottom: 0.6rem;
	text-transform: uppercase;
}

.jsr-menu-panel__col a {
	color: rgb(255 255 255 / 82%);
	font-size: 0.9rem;
	line-height: 1.3;
	padding-block: 0.28rem;
	text-decoration: none;
	transition: color 140ms ease, transform 160ms ease;
}

.jsr-menu-panel__col a:hover,
.jsr-menu-panel__col a:focus {
	color: #ffffff;
	transform: translateX(0.2rem);
}

.jsr-menu-panel__col a.is-primary {
	color: #ffffff;
	font-family: var(--jsr-font-heading);
	font-size: 0.92rem;
	font-weight: 700;
	padding-block: 0.35rem;
}

/* CTA column */
.jsr-menu-panel__cta {
	border-left: 1px solid rgb(255 255 255 / 18%);
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding-left: 2rem;
}

.jsr-menu-panel__cta p {
	color: rgb(255 255 255 / 68%);
	font-size: 0.85rem;
	line-height: 1.55;
	margin: 0;
}

.jsr-menu-panel__cta a {
	background: var(--jsr-color-teal-300);
	border-radius: 0.4rem;
	color: var(--jsr-color-slate-800);
	display: inline-block;
	font-family: var(--jsr-font-heading);
	font-size: 0.82rem;
	font-weight: 700;
	padding: 0.65rem 1.1rem;
	text-decoration: none;
	transition: background 140ms ease;
}

.jsr-menu-panel__cta a:hover {
	background: var(--jsr-color-teal-200);
}

.inside-article {
	padding-block: clamp(2rem, 5vw, 5rem);
}

.entry-header,
.page-header {
	margin-block-end: clamp(2rem, 4vw, 4rem);
}

.entry-title,
.page-title {
	font-size: clamp(2.75rem, 8vw, 6.5rem);
	max-width: 12ch;
}

.entry-content {
	font-size: clamp(1.05rem, 1.4vw, 1.2rem);
}

.entry-content > h2 {
	border-top: 1px solid var(--jsr-color-border);
	font-size: clamp(2rem, 4vw, 4.25rem);
	margin-block-start: clamp(3rem, 8vw, 6rem);
	padding-block-start: clamp(1.5rem, 3vw, 2.5rem);
}

.entry-content > h3 {
	color: var(--jsr-color-primary);
	font-size: clamp(1.35rem, 2vw, 2rem);
	margin-block-start: 2rem;
}

.entry-content > p,
.entry-content > ul,
.entry-content > ol {
	max-width: var(--jsr-reading-width);
}

.entry-content > ul,
.entry-content > ol {
	padding-inline-start: 1.25rem;
}

.entry-content > blockquote {
	background: var(--jsr-color-teal-200);
	border: 0;
	border-radius: var(--jsr-radius-md);
	box-shadow: var(--jsr-shadow-soft);
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: clamp(1.4rem, 3vw, 2.5rem);
	line-height: 1.15;
	margin-block: 2rem;
	padding: clamp(1.5rem, 4vw, 3rem);
}

.entry-content .wp-block-buttons,
.entry-content .wp-block-columns,
.entry-content .wp-block-group {
	margin-block: clamp(1.5rem, 4vw, 3rem);
}

@media (prefers-reduced-motion: no-preference) {
	a,
	button,
	.button,
	.wp-block-button__link,
	.custom-logo,
	.main-navigation .main-nav ul li a,
	.main-navigation .main-nav > ul > li > a::after,
	.main-navigation ul ul,
	.jsr-site-header__logo img,
	.jsr-hamburglar,
	.jsr-quick-nav a,
	.jsr-quick-nav__item > a::after,
	.jsr-quick-nav__dropdown,
	.jsr-service-area,
	.jsr-contact-bubble,
	.jsr-menu-panel,
	.jsr-menu-panel__nav a {
		transition:
			background-color var(--jsr-motion-fast),
			border-color var(--jsr-motion-fast),
			box-shadow var(--jsr-motion-fast),
			color var(--jsr-motion-fast),
			opacity var(--jsr-motion-fast),
			transform var(--jsr-motion-medium);
	}

	.site-logo:hover .custom-logo,
	.custom-logo-link:hover .custom-logo,
	.jsr-site-header__logo:hover img {
		transform: translateY(-0.1rem);
	}

	/* Hamburglar — animation-driven; no transitions needed on child elements */

	.jsr-site-header:not(.is-menu-open) .jsr-hamburglar:hover,
	.jsr-contact-bubble:hover,
	.jsr-contact-bubble:focus {
		transform: translateY(-0.1rem);
	}
}

.button,
button,
html input[type="button"],
input[type="reset"],
input[type="submit"],
.wp-block-button__link {
	background: var(--jsr-color-primary);
	border: 1px solid var(--jsr-color-primary);
	border-radius: var(--jsr-radius-sm);
	color: #ffffff;
	font-weight: 700;
	line-height: 1.2;
	padding: 0.75rem 1rem;
	text-decoration: none;
}

.button:hover,
button:hover,
html input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover,
.wp-block-button__link:hover,
.button:focus,
button:focus,
html input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
.wp-block-button__link:focus {
	background: var(--jsr-color-slate-800);
	border-color: var(--jsr-color-slate-800);
	color: #ffffff;
}

input,
textarea,
select {
	background: #ffffff;
	border: 1px solid var(--jsr-color-border);
	border-radius: var(--jsr-radius-sm);
	color: var(--jsr-color-text);
	font-family: var(--jsr-font-body);
}

input:focus,
textarea:focus,
select:focus {
	border-color: var(--jsr-color-primary);
	box-shadow: 0 0 0 0.2rem rgb(51 137 125 / 18%);
	outline: none;
}

.site-main,
.inside-article,
.comments-area {
	background: transparent;
}

/* ── MICRO-ANIMATIONS ────────────────────────────────────────────────────── */

@keyframes jsr-fade-up {
	from {
		opacity: 0;
		transform: translateY(28px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes jsr-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes jsr-rule-grow {
	from { transform: scaleX(0); transform-origin: left; }
	to   { transform: scaleX(1); transform-origin: left; }
}

@keyframes jsr-count-up {
	from { opacity: 0; transform: translateY(12px); }
	to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: no-preference) {
	[data-animate] {
		opacity: 0;
		transform: translateY(28px);
	}

	[data-animate="fade"] {
		transform: none;
	}

	[data-animate="left"] {
		transform: translateX(-28px);
	}

	[data-animate="right"] {
		transform: translateX(28px);
	}

	[data-animate].is-visible {
		animation: jsr-fade-up 0.7s cubic-bezier(0.22, 1, 0.36, 1) both;
	}

	[data-animate="fade"].is-visible {
		animation: jsr-fade-in 0.55s ease both;
	}

	[data-animate="left"].is-visible,
	[data-animate="right"].is-visible {
		animation: jsr-fade-up 0.7s cubic-bezier(0.22, 1, 0.36, 1) both;
		/* reuse fade-up since translateX is reset to 0 on .is-visible */
		transform: none;
	}

	[data-delay="1"].is-visible { animation-delay: 80ms; }
	[data-delay="2"].is-visible { animation-delay: 160ms; }
	[data-delay="3"].is-visible { animation-delay: 240ms; }
	[data-delay="4"].is-visible { animation-delay: 320ms; }
	[data-delay="5"].is-visible { animation-delay: 400ms; }
	[data-delay="6"].is-visible { animation-delay: 480ms; }

	.jsr-rule-animate {
		transform: scaleX(0);
		transform-origin: left;
	}

	.jsr-rule-animate.is-visible {
		animation: jsr-rule-grow 0.8s cubic-bezier(0.22, 1, 0.36, 1) both;
	}
}

@media (max-width: 768px) {

	.jsr-site-header__inner {
		gap: 0.75rem;
		min-height: 4.25rem;
		padding-inline: 0.85rem;
	}

	.jsr-quick-nav,
	.jsr-service-area,
	.jsr-language-trigger {
		display: none;
	}

	.jsr-contact-bubble {
		display: none;
	}

	.jsr-site-header__logo img {
		width: min(12rem, 48vw);
	}

	.jsr-menu-trigger {
		inline-size: 2.85rem;
	}

	.jsr-menu-panel__inner {
		grid-template-columns: 1fr 1fr;
		gap: 1.5rem;
		padding: 1.5rem;
	}

	.jsr-menu-panel__col {
		border-left: 0;
		border-top: 1px solid rgb(255 255 255 / 12%);
		padding-inline: 0;
		padding-top: 1rem;
	}

	.jsr-menu-panel__col:first-child {
		border-top: 0;
		padding-top: 0;
	}

	.jsr-menu-panel__cta {
		border-left: 0;
		border-top: 1px solid rgb(255 255 255 / 22%);
		grid-column: 1 / -1;
		padding-left: 0;
		padding-top: 1.25rem;
	}

	.inside-header {
		align-items: flex-start;
	}

	.custom-logo {
		width: min(14rem, 68vw);
	}

	.main-navigation .main-nav > ul > li:last-child > a {
		margin-inline-start: 0;
	}

	.main-navigation.toggled .main-nav ul ul {
		border: 0;
		border-radius: 0;
		box-shadow: none;
		transform: none;
	}
}
