/*
Theme Name: PERRON
Theme URI: https://perron.ai/
Author: Perron
Description: Perron AI
Version: 20260410
Text Domain: perron
*/

/* Variables */
:root {
	color-scheme: light dark;
	--foreground: CanvasText;
	--background: Canvas;

	--wrap: 2560px;
	--wp--style--global--content-size: 1280px;
	--wp--style--global--wide-size: 1680px;

	--pad: 2rem;
	--hh: 0;
	/* JS set dynamically */

	/* FONT STACKS */
	--system-ui: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Oxygen-Sans", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
	--transitional: Charter, "Bitstream Charter", "Sitka Text", Cambria, serif;
	--old-style: "Iowan Old Style", "Palatino Linotype", "URW Palladio L", P052, var(--transitional);
	--humanist: Seravek, "Gill Sans Nova", Ubuntu, Calibri, "DejaVu Sans", source-sans-pro, var(--system-ui);
	--geometric-humanist: Avenir, "Avenir Next LT Pro", Montserrat, Corbel, "URW Gothic", source-sans-pro, var(--system-ui);
	--classical-humanist: Optima, Candara, "Noto Sans", var(--system-ui);
	--neo-grotesque: Inter, Roboto, "Helvetica Neue", "Arial Nova", "Nimbus Sans", Arial, var(--system-ui);
	--monospace-slab-serif: "Nimbus Mono PS", "Courier New", "Cutive Mono", monospace;
	--monospace-code: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, Consolas, "DejaVu Sans Mono", monospace;
	--industrial: Bahnschrift, "DIN Alternate", "Franklin Gothic Medium", "Nimbus Sans Narrow", sans-serif-condensed, var(--system-ui);
	--rounded-sans: ui-rounded, "Hiragino Maru Gothic ProN", Quicksand, Comfortaa, Manjari, "Arial Rounded MT Bold", Calibri, source-sans-pro, var(--system-ui);
	--slab-serif: Rockwell, "Rockwell Nova", "Roboto Slab", "DejaVu Serif", "Sitka Small", var(--transitional);
	--antique: Superclarendon, "Bookman Old Style", "Sitka Heading", "URW Bookman", "URW Bookman L", "Georgia Pro", Georgia, var(--transitional);
	--didone: Didot, "Bodoni MT", "Noto Serif Display", "URW Palladio L", P052, Sylfaen, var(--transitional);
	--handwritten: "Segoe Print", "Bradley Hand", Chilanka, TSCu_Comic, casual, cursive;
	--emoji: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
	--comfortaa: "Comfortaa";
	--oxanium: "Oxanium";
	--inter: "Inter";
	--font-primary: var(--inter), var(--neo-grotesque);
	--font-secondary: var(--oxanium), var(--industrial);

	/* THEMING */

	/* Neutral colors */
	--neutral-100: #ffffff;
	--neutral-200: #f5f5f5;
	--neutral-300: #e0e0e0;
	--neutral-400: #bdbdbd;
	--neutral-500: #9e9e9e;
	--neutral-600: #757575;
	--neutral-700: #616161;
	--neutral-800: #424242;
	--neutral-900: #212121;
	--neutral-1000: #101010;

	/* Light colors */
	--light-red: #ffcccc;
	--light-orange: #ffe0b3;
	--light-yellow: #fff9c4;
	--light-green: #c8e6c9;
	--light-cyan: #b2ebf2;
	--light-blue: #bbdefb;
	--light-indigo: #c5cae9;
	--light-violet: #d1c4e9;
	--light-magenta: #f8bbd0;

	/* Dark colors */
	--dark-red: #b71c1c;
	--dark-orange: #e65100;
	--dark-yellow: #f9a825;
	--dark-green: #33691e;
	--dark-cyan: #00838f;
	--dark-blue: #1a237e;
	--dark-indigo: #283593;
	--dark-violet: #4a148c;
	--dark-magenta: #880e4f;

	/* Cyber Light Palette */
	--cyber-blue-light: oklch(45% 0.15 250);
	/* Deep Digital Blue */
	--cyber-magenta-light: oklch(65% 0.2 320);
	/* Electric Magenta */
	--cyber-green-light: oklch(75% 0.25 140);
	/* Bright Electric Green */
	--cyber-black-light: oklch(15% 0.02 240);
	/* Near Black Blue-Grey */
	--cyber-grey-light: oklch(98% 0.005 220);
	/* Very Light Blue-Grey */

	/* Cyber Dark Palette */
	--cyber-blue-dark: oklch(70% 0.18 245);
	/* Lighter, Brighter Digital Blue */
	--cyber-magenta-dark: oklch(50% 0.22 315);
	/* Vivid Magenta */
	--cyber-green-dark: oklch(80% 0.3 130);
	/* More Intense Electric Green */
	--cyber-black-dark: oklch(90% 0.01 220);
	/* Light Off-White Blue */
	--cyber-grey-dark: oklch(8% 0.01 260);
	/* Very Dark Blue-Purple */

	/* Refreshing Light Palette */
	--refreshing-indigo-light: oklch(35% 0.1 270);
	/* Deep Indigo */
	--refreshing-orange-light: oklch(60% 0.18 50);
	/* Burnt Orange */
	--refreshing-aqua-light: oklch(70% 0.15 180);
	/* Bright Aqua */
	--refreshing-black-light: oklch(18% 0.01 0);
	/* Near Black */
	--refreshing-white-light: oklch(99% 0 0);
	/* Pure White */

	/* Refreshing Dark Palette */
	--refreshing-indigo-dark: oklch(65% 0.12 265);
	/* Lighter Indigo */
	--refreshing-orange-dark: oklch(45% 0.22 45);
	/* More Saturated Burnt Orange */
	--refreshing-aqua-dark: oklch(80% 0.2 170);
	/* Lighter, Brighter Aqua */
	--refreshing-black-dark: oklch(88% 0.01 0);
	/* Light Gray */
	--refreshing-white-dark: oklch(10% 0.02 270);
	/* Very Dark Indigo */

	/* AIXIS */
	--aixis-cyan: #00aeef;
	--ai-blue: #2563eb;
	--ai-cyan: #06b6d4;
	--ai-violet: #7c3aed;
	--ai-ink: #07111f;
	--ai-surface: rgba(255, 255, 255, 0.82);
	--ai-surface-dark: rgba(8, 14, 26, 0.78);
	--ai-border: color-mix(in oklch, var(--accentcolor), transparent 64%);
	--ai-shadow: 0 24px 80px color-mix(in oklch, var(--foreground), transparent 88%);

	/* Light defaults */
	--background: var(--neutral-100);
	--foreground: var(--neutral-900);
	--paper: var(--neutral-300);
	--text: var(--neutral-900);
	--accentcolor: var(--light-blue);
	--hover: var(--light-magenta);
}

html:not([data-theme]),
html[data-theme='light'] {
	color-scheme: light;
	--background: var(--neutral-100);
	--foreground: var(--neutral-900);
	--paper: rgba(255, 255, 255, 0.76);
	--text: var(--neutral-900);
	--accentcolor: var(--ai-blue);
	--hover: var(--ai-violet);
	--ai-page-glow-a: color-mix(in oklch, var(--ai-blue), transparent 78%);
	--ai-page-glow-b: color-mix(in oklch, var(--ai-cyan), transparent 84%);
	--ai-page-glow-c: color-mix(in oklch, var(--ai-violet), transparent 86%);
}

html[data-theme='dark'] {
	color-scheme: dark;
	--background: var(--neutral-1000);
	--foreground: var(--neutral-200);
	--paper: rgba(12, 18, 32, 0.78);
	--text: var(--neutral-100);
	--accentcolor: var(--ai-cyan);
	--hover: #a78bfa;
	--ai-page-glow-a: color-mix(in oklch, var(--ai-cyan), transparent 82%);
	--ai-page-glow-b: color-mix(in oklch, var(--ai-violet), transparent 86%);
	--ai-page-glow-c: color-mix(in oklch, var(--ai-blue), transparent 88%);
}

html[data-theme='combo'] {
	--background: var(--refreshing-indigo-light);
	--foreground: var(--cyber-grey-light);
	--paper: var(--cyber-blue-light);
	--text: var(--cyber-grey-light);
	--accentcolor: var(--cyber-magenta-light);
	--hover: var(--cyber-green-light);
	--ai-page-glow-a: color-mix(in oklch, var(--ai-cyan), transparent 82%);
	--ai-page-glow-b: color-mix(in oklch, var(--ai-violet), transparent 86%);
	--ai-page-glow-c: color-mix(in oklch, var(--ai-blue), transparent 88%);
}

/* Theme Switcher */
.no-js .themeswitcher {
	display: none !important;
}

.themeswitcher {
	padding: 0;
	margin: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 0 1em;
}

.themeswitcher::before {
	content: "THEME";
	font-weight: 700;
	;
}

html[data-theme='dark'] .theme-dark,
html[data-theme='light'] .theme-light,
html[data-theme='combo'] .theme-combo {
	font-weight: bold;
	text-transform: uppercase;
	color: var(--accentcolor);
}

.themeswitcher a {
	text-decoration: none;
	color: inherit;
}

button#fullscreenButton {
	background: none;
	border: none;
	color: inherit;
	cursor: pointer;
	vertical-align: middle;
}

/* ========================================
   VIEW TRANSITIONS & ANIMATIONS
   ======================================== */

@view-transition {
	navigation: auto;
}

/* 1. Defensive: Disable all root view transitions by default */
::view-transition-new(root),
::view-transition-old(root) {
	animation: none !important;
}

/* 2. Enable circular reveal ONLY during theme switching */
html.theme-switching[data-theme='light']::view-transition-new(root),
html.theme-switching[data-theme='dark']::view-transition-new(root),
html.theme-switching[data-theme='combo']::view-transition-new(root) {
	animation: none !important;
	z-index: 1;
	mix-blend-mode: normal;
	will-change: clip-path;
	isolation: isolate;
}

html.theme-switching[data-theme='light']::view-transition-old(root),
html.theme-switching[data-theme='dark']::view-transition-old(root),
html.theme-switching[data-theme='combo']::view-transition-old(root) {
	animation: none !important;
	z-index: 0;
	mix-blend-mode: normal;
}

/* 3. Suppress page (mainx) transitions during theme switching */
html.theme-switching::view-transition-old(mainx),
html.theme-switching::view-transition-new(mainx),
html.theme-switching::view-transition-group(mainx) {
	animation: none !important;
}

/* Ensure header stays on top during theme switch */
::view-transition-group(headerx) {
	z-index: 9999;
}

/* 4. Page transitions for mainx */
::view-transition-old(mainx) {
	animation: 300ms ease-out both view-out;
}

::view-transition-new(mainx) {
	animation: 600ms ease-out both view-in;
	animation-timing-function: cubic-bezier(0.5, 0, .5, 1);
}

::view-transition-group(mainx) {
	z-index: 900;
}

/* 5. Keyframes for circular reveal */
@keyframes reveal-in {
	from {
		clip-path: circle(0% at 50% 50%);
	}

	to {
		clip-path: circle(142% at 50% 50%);
	}
}

@keyframes reveal-out {
	from {
		clip-path: circle(142% at 50% 50%);
	}

	to {
		clip-path: circle(0% at 50% 50%);
	}
}

/* 6. Keyframes for page fade/scale */
@keyframes view-out {
	from {
		opacity: 0.4;
		transform-origin: bottom center;
		transform: scale(1);
	}

	to {
		opacity: 0;
		transform-origin: bottom center;
		transform: scale(0);
	}
}

@keyframes view-in {
	from {
		opacity: 0;
		transform: scale(0);
	}

	to {
		opacity: 1;
		transform: scale(1);
	}
}

@media (prefers-reduced-motion) {

	::view-transition-group(*),
	::view-transition-old(*),
	::view-transition-new(*) {
		animation: none !important;
	}
}

/* Disable transitions for admin elements */
html body #wpadminbar {
	position: fixed !important;
	view-transition-name: wpadminbarx;
	height: var(--wp-admin--admin-bar--height, 32px);
	max-height: var(--wp-admin--admin-bar--height, 32px);
	flex: 0 0 var(--wp-admin--admin-bar--height, 32px) !important;
	top: 0 !important;
	transition: all 1s ease-out;
	opacity: 0;
	transform: translateY(-100%) !important;
}

html.loaded body #wpadminbar {
	opacity: 1;
	transform: translateY(0%) !important;
}

::view-transition-group(wpadminbarx),
::view-transition-old(wpadminbarx) {
	transform: scale(0);
	opacity: 0;
	z-index: -999;
}

::view-transition-new(wpadminbarx) {
	transform: scale(1);
	opacity: 1;
	z-index: 50;
}

#wp-toolbar>ul>li#wp-admin-bar-xadmin {
	display: none !important;
}

@media screen and (max-width: 782px) {
	#wp-toolbar>ul>li#wp-admin-bar-site-name {
		display: none !important;
	}

	#wp-toolbar>ul>li#wp-admin-bar-autorefresh,
	#wp-toolbar>ul>li#wp-admin-bar-xadmin {
		display: list-item !important;
	}

	#wpadminbar #wp-admin-bar-xadmin>.ab-item {
		text-overflow: clip;
		text-indent: 100%;
		white-space: nowrap;
		overflow: hidden;
		width: 52px;
		padding: 0;
		color: #a7aaad;
		position: relative;
	}

	#wpadminbar #wp-admin-bar-xadmin>.ab-item:before {
		content: "\f226";
		display: block;
		text-indent: 0;
		font: normal 32px / 1 dashicons;
		top: 7px;
		width: 52px;
		text-align: center;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
	}
}

body.admin-bar::before {
	content: "";
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	display: block;
	height: var(--wp-admin--admin-bar--height, 32px);
	z-index: 999;
	background-color: #1d2327;
	view-transition-name: adminbarx;
}

/* ========================================
   CORE & BASE STYLES
   ======================================== */

/* CORE */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html {
	background-color: var(--background);
	width: 100%;
	font-size: 62.5%;
	scroll-behavior: smooth;
	scrollbar-color: var(--accentcolor, Canvas) var(--background);
	scrollbar-width: thin;
	-webkit-tap-highlight-color: transparent;
	interpolate-size: allow-keywords;
	height: 100%;
	overflow: hidden;
	overscroll-behavior: none;
	background-color: color-mix(in oklch, var(--background), var(--ai-page-glow-c) 100%);
	background-image:
		radial-gradient(circle at 15% 10%, var(--ai-page-glow-a), transparent 34rem),
		radial-gradient(circle at 85% 20%, var(--ai-page-glow-b), transparent 38rem),
		radial-gradient(circle at 50% 95%, var(--ai-page-glow-c), transparent 44rem),
		linear-gradient(135deg, var(--background), color-mix(in oklch, var(--paper), transparent 30%));
	background-attachment: fixed;
}

html[data-theme="combo"] {
	background-color: color-mix(in oklch, var(--background), var(--paper) 75%);
}

/* iOS notch guff? */
@supports (-webkit-touch-callout: none) {
	html {
		padding-block-start: max(0, env(safe-area-inset-top));
		padding-inline-end: max(0, env(safe-area-inset-right));
		padding-block-end: max(0, env(safe-area-inset-bottom));
		padding-inline-start: max(0, env(safe-area-inset-left));
	}
}

body {
	font-family: var(--font-primary);
	font-optical-sizing: auto;
	font-style: normal;
	font-size: clamp(1.6rem, 1.35vw, 1.9rem);
	font-weight: 400;
	line-height: 1.7;
	letter-spacing: -0.012em;
	width: 100%;
	display: flex;
	gap: 0;
	flex-direction: column;
	background-color: none;
	color: var(--text);
	accent-color: var(--accentcolor);
	scroll-behavior: smooth;
	scrollbar-color: var(--accentcolor, Canvas) var(--background);
	scrollbar-width: thin;
	-webkit-overflow-scrolling: touch;
	min-block-size: 100svh;
	scrollbar-gutter: stable;
	height: 100%;
	overflow-x: clip;
	overflow-y: auto;
	container-type: inline-size;
	scroll-timeline: --scrollTimeline block;
}

html:has(body.admin-bar) {
	margin-top: 0 !important;
}

html body.admin-bar {
	top: var(--wp-admin--admin-bar--height, 0);
	position: relative;
	height: calc(100% - var(--wp-admin--admin-bar--height, 32px));
	min-block-size: calc(100% - var(--wp-admin--admin-bar--height, 32px));
}

:is(h1, h2, h3, h4, h5, h6) {
	font-family: var(--font-secondary);
	font-optical-sizing: auto;
	font-style: normal;
	color: inherit;
	font-weight: 600;
	letter-spacing: -0.035em;
	text-wrap: pretty;
	line-height: 1.15;
	margin-block: 0;
}

[data-theme='combo'] :is(h1, h2, h3, h4, h5, h6) {
	color: var(--accentcolor, inherit);
}

:is(h1) {
	font-size: clamp(3.2rem, 5vw, 7.2rem);
	text-wrap: balance;
}

:is(h2, h1.h2) {
	font-size: clamp(2.1rem, 3vw, 3.8rem);
	text-wrap: balance;
}

:is(h1, h2) {
	filter: none;
}

:is(h1:hover, h2:hover) {
	filter: none;
}

:is(h3) {
	font-size: clamp(2rem, 3vw, 3rem);
}

:is(h4) {
	font-size: clamp(1.8rem, 2vw, 2.2rem);
}

:is(h5) {
	font-size: clamp(1.6rem, 1.8vw, 1.8rem);
}

:is(h6) {
	font-size: clamp(1.2rem, 1.5vw, 1.4rem);
	;
}

:is(strong, b) {
	font-weight: 700;
}

:is(em, i) {
	font-style: italic;
}

/* Remove outline for non-keyboard :focus */
:focus:not(:focus-visible) {
	outline: none;
}

/* Optional: Customize .focus-visible */
body:has(#hamburger:focus-visible) .hamburger,
:focus-visible {
	outline: var(--hover, Canvas) dashed 4px;
	outline-offset: 12px;
}

:is(main p) {
	--flow: 1rem;
}

/* :is(main p:not(:last-child)) {
    margin-block-end: 1rem;
} */
:where(main.main) :where(a) {
	color: var(--accentcolor, inherit)
}

:where(main.main) :where(a:hover) {
	color: var(--hover, inherit)
}

:where(main.main) :is(blockquote) {
	margin-block-end: 1rem;
}

:where(main.main) :is(q, [cite], blockquote a, figcaption) {
	color: var(--accentcolor, Canvas);
}

:where(main.main) :where(ul, ol) {
	list-style: revert;
}

:where(main.main) :where(ul li) {
	list-style-position: inside;
	text-indent: -1.25em;
	padding-left: 1.25em;
	isolation: isolate;
	text-wrap: pretty;
}

:where(main.main) :where(ul, ol) li {
	margin-block-end: 0.5em;
}

:where(main.main) :where(ul, ol) li::marker {
	color: var(--accentcolor, Canvas);
}

:where(main.main) :where(kbd, samp, code) {
	color: var(--accentcolor, Canvas);
}

:where(main.main) :where(ins) {
	text-decoration-style: dotted;
	text-decoration-color: var(--accentcolor, Canvas);
}

:where(main.main) :where(del) {
	text-decoration-style: dashed;
	text-decoration-color: var(--accentcolor, Canvas);
}

:where(main.main) :where(hr) {
	margin-block: var(--pad, 1em);
	border: 1px solid var(--accentcolor, Canvas);
	border-radius: 1px;
	height: 0;
}

:where(.has-text-align-center) {
	text-align: center;
}

:where(main.main) :where(ul, ol) :where(ul, ol) {
	margin-inline-start: 1.5em;
}

:is(ol) {
	list-style-position: inside;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

label,
button {
	cursor: pointer;
}

iframe {
	width: 100%;
	height: auto;
	border: none;
	object-fit: cover;
	aspect-ratio: 16 / 9;
	border-radius: var(--pad, 0);
}

mark {
	padding-inline: 1.25em;
	margin-inline: -0.75em;
	background: linear-gradient(105deg, transparent 1em, var(--accentcolor, cyan) 1em, var(--accentcolor, cyan) calc(100% - 1em), transparent calc(100% - 1em));
	color: var(--foreground, Canvas);
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
}

.animgradient {
	background: var(--accentcolor) linear-gradient(in hsl longer hue 45deg, hsl(221, 66%, 77%), hsl(221, 66%, 77%)) 0% 50% no-repeat scroll;
	background-size: 400% 100%;
	animation: animgradient 16s ease infinite;
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	text-align: center;
}

[data-theme="light"] .animgradient {
	background-image: linear-gradient(in hsl shorter hue 45deg, hsl(221, 66%, 77%), hsl(262, 83%, 58%));
}

[data-theme="dark"] .animgradient {
	background-image: linear-gradient(in hsl shorter hue 45deg, hsl(189, 94%, 43%), hsl(255, 92%, 76%));
}

[data-theme="combo"] .animgradient {
	background-image: linear-gradient(in hsl longer hue 45deg, hsl(221, 66%, 77%), hsl(221, 66%, 77%));
}

.animgradient.spectrum {
	background-image: linear-gradient(in hsl longer hue 45deg, hsl(0, 95%, 75%) 0 0);
}

@keyframes animgradient {
	0% {
		background-position: 0% 50%;
	}

	50% {
		background-position: 100% 50%;
	}

	100% {
		background-position: 0% 50%;
	}
}

/* PAPER */
.paper {
	--paper-size: clamp(10px, 1vw, 14px);
	--paper-size-half: calc(var(--paper-size) / 2);
	--paper-size-double: calc(var(--paper-size) * 2);
	--paper-size-big: calc(var(--paper-size-double) - var(--paper-size-half));
	position: relative;
	z-index: 0;
	transition: filter 0.3s ease-in-out;
	padding: var(--paper-size);
}

.paper:before {
	content: '';
	background: conic-gradient(from var(--deg, 0deg), transparent, color-mix(in oklch, var(--accentcolor), transparent 24%), transparent 28%, color-mix(in oklch, var(--hover), transparent 42%), transparent 58%);
	opacity: 0.7;
	animation: turn 10s linear infinite;
	animation-play-state: running;
	position: absolute;
	inset: calc(var(--paper-size) * -1);
	z-index: -2;
	width: calc(100% + var(--paper-size-double));
	height: calc(100% + var(--paper-size-double));

	filter: blur(0);
	opacity: 1;
	transition: all .3s ease-in-out;
	clip-path: polygon(0 var(--paper-size-double), var(--paper-size-double) 0, calc(100% - var(--paper-size-double)) 0, 100% var(--paper-size-double), 100% calc(100% - var(--paper-size-double)), calc(100% - var(--paper-size-double)) 100%, var(--paper-size-double) 100%, 0 calc(100% - var(--paper-size-double)));
}

body:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) .paper:before {
	animation-play-state: paused;
}

.paper:hover::before {
	opacity: 1;
	filter: blur(var(--paper-size));
	clip-path: none;
	transition: all 0.15s ease-in-out;
}

.paper::after {
	content: '';
	display: block;
	position: absolute;
	inset: 0;
	z-index: -1;
	background-color: var(--paper);
	clip-path: polygon(0 var(--paper-size-big), var(--paper-size-big) 0, calc(100% - var(--paper-size-big)) 0, 100% var(--paper-size-big), 100% calc(100% - var(--paper-size-big)), calc(100% - var(--paper-size-big)) 100%, var(--paper-size-big) 100%, 0 calc(100% - var(--paper-size-big)));
	transition: all .15s ease-in-out;
}

/* GLOW */

@property --deg {
	syntax: "<angle>";
	initial-value: 0deg;
	inherits: false;
}

@keyframes turn {
	0% {
		--deg: 0deg;
	}

	100% {
		--deg: 360deg;
	}
}

.glow {
	--glow-size: 12px;
	--glow-size-half: calc(var(--glow-size) / 2);
	--glow-size-double: calc(var(--glow-size) * 2);
	--glow-size-big: calc(var(--glow-size-double) - var(--glow-size-half));
	filter: drop-shadow(0 0 var(--glow-size) rgba(0, 0, 0, 0.5));
}

[data-theme="dark"].glow {
	filter: drop-shadow(0 0 var(--glow-size) rgba(255, 255, 255, 0.5));
}

.glow:before {
	background: linear-gradient(45deg, rgba(255, 255, 255, 0.1), transparent) padding-box, conic-gradient(from var(--deg, 0deg), transparent, var(--accentcolor) 10%, transparent 20%) border-box;
	/* background-image: conic-gradient(from var(--deg, 0deg), var(--accentcolor) 0%, var(--hover) 10%, var(--accentcolor) 20%); */
}

[data-theme="combo"] .glow:before {
	background: linear-gradient(135deg, rgba(0, 0, 0, 0.2), transparent) padding-box, conic-gradient(in hsl longer hue from var(--deg, 0deg), hsl(0, 95%, 65%) 0% 100%) border-box;
	/* background-image: conic-gradient(in hsl longer hue from var(--deg, 0deg), hsl(0, 95%, 65%) 0% 100%); */
}

.glow::after {
	box-shadow: inset 0 0 var(--glow-size-half) rgba(255, 255, 255, 0.9);
	filter: blur(var(--glow-size-double));
}

[data-theme="dark"].glow::after {
	box-shadow: inset 0 0 var(--glow-size-half) rgba(0, 0, 0, 0.9);
}

/* ========================================
   LAYOUT COMPONENTS
   ======================================== */

/* HEADER */
header.header {
	view-transition-name: headerx;
	text-align: center;
	padding: clamp(0.8rem, 1.2vw, 1.4rem) 0;
	background-color: rgba(0, 0, 0, 0.2);
	color: var(--foreground, Canvas);
	/* box-shadow: 0px 10px 5px 0px rgba(0, 0, 0, 0.25); */
	position: sticky;
	inset-inline: 0;
	top: var(--wp-admin--admin-bar--height, 0);
	z-index: 1100;
	/* max-width: 100vw;
	max-width: calc(var(--vw, 1vw) * 100); */
	backdrop-filter: blur(8px) brightness(110%) saturate(140%);
	background-image: linear-gradient(to bottom,
			var(--background) 0%,
			transparent 65%);
	transition: background-color 0.3s ease, backdrop-filter 0.25s ease;
	top: 0;
}

html[data-theme='dark'] header.header,
html[data-theme='combo'] header.header {
	backdrop-filter: blur(8px) brightness(90%) saturate(140%);
}

@supports not (backdrop-filter: blur(2px)) {
	header.header {
		background-image: linear-gradient(to bottom,
				var(--background) 0%,
				rgba(255, 255, 255, 0.5) 100%);
	}

	html[data-theme='dark'] header.header,
	html[data-theme='combo'] header.header {
		background-image: linear-gradient(to bottom,
				var(--background) 0%,
				rgba(0, 0, 0, 0.5) 100%);
	}
}

/* header.header:has(input.hamburger-switch:checked) {
    backdrop-filter: none;
    view-transition-name: none;
} */
/* body.admin-bar header.header {
    transition: background-color 0.3s ease, backdrop-filter 1.1s ease;
} */
body.admin-bar header.header:has(input.hamburger-switch:checked) {
	transition: background-color 0.3s ease, backdrop-filter 0s ease;
}

.backdrop-edge::after {
	content: "";
	display: block;
	--thickness: 5px;
	position: absolute;
	z-index: -1;
	inset: 0;
	height: 100%;
	transform: translateY(100%);
	background: hsl(0deg 0% 100% / 0.1);
	backdrop-filter: blur(16px) brightness(110%) saturate(120%);
	pointer-events: none;
	mask-image: linear-gradient(to bottom,
			black 0,
			black var(--thickness),
			transparent var(--thickness));
}

header.header:hover,
[data-theme="light"] header.header:hover {
	background-color: rgba(255, 255, 255, 0.65);
}

[data-theme="dark"] header.header:hover {
	background-color: rgba(0, 0, 0, 0.65);
}

[data-theme="combo"] header.header:hover {
	background-color: rgba(44, 62, 80, 0.65);
}

.header-content {
	position: relative;
	display: flex;
	gap: clamp(1rem, 2vw, 2.4rem);
	justify-content: center;
	align-items: center;
}

.getquote {
	justify-self: start;
	font-size: clamp(0.4em, 2.5vw, 1.5rem);
}

.sitelogo {
	display: flex;
	align-items: center;
	justify-content: start;
	gap: 0.5rem;
	color: var(--foreground, Canvas);
	font-size: 1.5rem;
	font-weight: bold;
	cursor: pointer;
	text-decoration: none;
	margin-inline-end: auto;
	max-width: 40vw;
}

.sitelogo svg {
	height: 4rem;
	transition: transform 0.5s ease;
	padding-block-start: 7.5%;
}

.sitelogo svg path {
	fill: #fff;
	min-height: 100%;
}

[data-theme="light"] .sitelogo svg path {
	fill: var(--foreground, #000);
}

.sitelogo svg {
	height: 4rem;
	padding-block-start: 0%;
	animation: shrink-logo linear forwards;
	animation-range: 0 25vh;
	animation-timeline: --scrollTimeline;
	will-change: height, padding-block-start;
}

.sitelogo svg path.erron {
	opacity: 0;
	animation: fade-erron linear forwards;
	animation-range: 0 25vh;
	animation-timeline: --scrollTimeline;
	will-change: opacity;
}

/* Scroll-driven animation for .sitelogo svg height */
@keyframes shrink-logo {
	from {
		height: 8rem;
		padding-block-start: 7.5%;
	}

	to {
		height: 4rem;
		padding-block-start: 0%;
	}
}

/* Scroll-driven animation for .erron path opacity */
@keyframes fade-erron {
	from {
		opacity: 1;
	}

	to {
		opacity: 0;
	}
}


/* Polyfill support — html.timeline is added by scroll-timeline.js in browsers
   that lack native animation-timeline support (older Firefox, Safari < 18) */
html.timeline .sitelogo svg {
	animation-timeline: --scrollTimeline;
	animation-range: 0 200px;
}

html.timeline .sitelogo svg path.erron {
	animation-timeline: --scrollTimeline;
	animation-range: 0 200px;
}

.sitelogo:hover svg path {
	fill: var(--accentcolor, #000);
}

.sitelogo:focus svg {
	filter: blur(2px);
}

.menuwrap {
	justify-content: end;
	display: flex;
}

/* nav {
    padding: 0;
}

nav ul {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
}

nav a {
    color: var(--foreground, Canvas);
    text-decoration: none;
    padding: 0.5rem 1rem;
    border-radius: 4px;
    transition: all 0.3s ease;
}

nav a:hover {
    background-color: var(--hover);
    transform: translateY(-2px);
}

nav a:active {
    transform: translateY(0);
} */

/* NAV */
nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

nav a {
	text-decoration: none;
	text-transform: uppercase;
	color: var(--color-text, #555);
}

nav li.current-menu-item>a {
	color: var(--foreground, Canvas);
}

nav a:hover {
	color: var(--hover);
}

nav.primary-menu li,
nav.primary-menu li a {
	position: relative;
}

/*@media screen and (min-width:1025px) {
    .hamburger-switch {
        display: none;
    }
	.menu {
		display: -webkit-box;
    	display: -ms-flexbox;
    	display: flex;
		gap: 2.5vw;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		position: relative;
	}
	nav.primary-menu .menu > li {
		position: relative;
	}
    @media (any-pointer: coarse) {
        nav.primary-menu .menu > li.menu-item-has-children {
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            gap:0 1rem;
        }
        nav.primary-menu .menu > li.menu-item-has-children::after {
            content: "▼";
            display: -ms-grid;
            display: grid;
            place-items: center;
            padding: 7px 11px;
            margin: -0.4em 0;
            font-size: 1.6rem;
            aspect-ratio: 1;
            border-radius: 50%;
            overflow: hidden;
            cursor: pointer;
            background: rgba(255,255,255,0.15);
        }
    }
	nav.primary-menu .menu .sub-menu {
		display: none;
		position: absolute;
		top: 100%;
		z-index: 10;
		background-color: var(--color-secondary);
		margin-left: 50%;
		transform: translateX(-50%);
		border-top: 7px solid transparent;
		filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.25));
	}
	nav.primary-menu .menu :where(li:hover,li:active) .sub-menu ,
	nav.primary-menu .menu > li.menu-item-has-children:focus-within .sub-menu {
		display: block;
	}
	nav.primary-menu .menu .sub-menu li a {
		display: block;
		text-align: center;
		white-space: nowrap;
		padding: 0.5em 1em;
		letter-spacing: 0.0248em;
		text-transform: none;
	}
}
*/

.hamburger {
	display: none;
	cursor: pointer;
	justify-content: end;
	gap: 5px;
	/*padding: 3px;
	transform-origin: center 6px;*/
}

.hamburger span {
	display: block;
	width: 24px;
	height: 3px;
	border-radius: 3px;
	background: var(--foreground, Canvas);
	transition: all 0.5s ease-in-out;
}

/* .hamburger:hover span {
	background: var(--hover) !important;
} */

/*
body:has(.hamburger-switch:checked) .hamburger {
	position: fixed;
	top: calc(0 + (var(--wp-admin--admin-bar--height,0) * 1px));
	margin-top: -12px;
	right: 5vw;
	z-index: 3000;
}
*/
body:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) .hamburger span {
	background: var(--foreground, Canvas) !important;
}

.hamburger span {
	transform-origin: center;
}

body:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) .hamburger span.ham1 {
	transform: rotateZ(45deg) translate(5px, 6px) scaleX(1.3);
}

body:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) .hamburger span.ham2 {
	transform: scale(0);
	opacity: 0;
}

body:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) .hamburger span.ham3 {
	transform: rotateZ(-45deg) translate(5px, -6px) scaleX(1.3);
}

/* body:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) .hamburger:hover span {
	background: var(--hover) !important;
} */

nav.primary-menu {
	min-width: 24px;
	margin-inline-start: calc(-24px + var(--pad));
}

nav.primary-menu>.wrap {
	position: relative;
}

.hamburger {
	display: -ms-grid;
	display: grid;
}

.menu-main-container {
	backface-visibility: hidden;
}

.menu-main-container .menu {
	transform: translateZ(0);
	clip-path: circle(0% at 100% 0%);
	transition: clip-path 1.1s cubic-bezier(.25, 1, .30, 1);
	will-change: clip-path;
	pointer-events: none;
	position: fixed;
	display: -ms-grid;
	display: grid;
	gap: clamp(2rem, 5vh, 5rem);
	justify-content: center;
	align-content: center;
	left: 0;
	right: 0;
	z-index: 1000;
	top: calc(var(--hh, 64px) + var(--wp-admin--admin-bar--height, 0px));
	bottom: 0;
	padding: 5vh;
	max-inline-size: 100cqw;
	overflow-x: hidden;
	overflow-y: auto;
	scrollbar-gutter: stable both-edges;
	overscroll-behavior: contain;
	background-color: rgba(255, 255, 255, 0.6);
	text-align: center;
	--blur: 7px;
	--backdrop: brightness(85%) saturate(165%) contrast(165%) blur(var(--blur));
	backdrop-filter: var(--backdrop);

	-webkit-backface-visibility: hidden;
	-webkit-perspective: 1000;
	-webkit-transform: translate3d(0, 0, 0);
	-webkit-transform: translateZ(0);
	backface-visibility: hidden;
	perspective: 1000;
	transform: translate3d(0, 0, 0);
	transform: translateZ(0);
	will-change: clip-path;
}

[data-theme="dark"] .menu-main-container .menu,
[data-theme="combo"] .menu-main-container .menu {
	background-color: rgba(0, 0, 0, 0.75);
	--backdrop: brightness(125%) saturate(125%) contrast(125%) blur(var(--blur));
}

@supports not (backdrop-filter: blur(2px)) {
	.menu-main-container .menu {
		background-color: rgba(255, 255, 255, 0.85);
	}

	[data-theme="dark"] .menu-main-container .menu,
	[data-theme="combo"] .menu-main-container .menu {
		background-color: rgba(0, 0, 0, 0.85);
	}
}

.menu-main-container .menu:has(:focus-visible),
body:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) .menu-main-container .menu {
	clip-path: circle(142% at 100% 0%);
	transition: clip-path 1.4s cubic-bezier(.25, 1, .30, 1);
	pointer-events: all;
}

/* html:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) {
	scrollbar-gutter: stable;
} */

html:has(.hamburger-switch:focus-visible, .hamburger-switch:checked) body {
	overflow-y: hidden;
}

/*
.menu-main-container .menu {
    display: none;
}
body:has(.hamburger-switch:checked) .menu-main-container .menu {
    display: block;
}
*/
.menu>li {
	list-style: none;
}

/* .menu > li:not(:last-child) {
    margin: 0 0 1em 0;
} */
nav.primary-menu .menu .sub-menu {
	display: block;
	margin: 0 0 1em 0;
}

.sub-menu li {
	display: block;
}

.sub-menu a {
	font-size: 1.3rem !important;
	padding: 0 0.5em;
	text-transform: none !important;
}

nav.primary-menu .menu a {
	color: var(--foreground, Canvas) !important;
	border-bottom: none !important;
	padding: 0.5em 1em;
	font-size: clamp(2rem, 6vmin, 4.2rem);
}

nav.primary-menu .menu a:hover {
	color: var(--hover) !important;
}

nav.primary-menu .menu li.current-menu-item>a {
	color: var(--accentcolor) !important;
}


/* Theme Dropdown */
.theme-dropdown {
	position: relative;
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
	/* margin-inline: auto 1rem; */
	contain: layout style;
}

.theme-toggle {
	background: none;
	border: none;
	padding: 0.75rem;
	cursor: pointer;
	color: inherit;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.5rem;
	transition: all 0.2s ease;
	border: 1px solid color-mix(in oklch, var(--foreground), transparent 86%);
	background: color-mix(in oklch, var(--paper), transparent 20%);
}

.theme-toggle:hover {
	background: color-mix(in oklch, var(--accentcolor), transparent 82%);
	border-color: color-mix(in oklch, var(--accentcolor), transparent 35%);
	/* transform: translateY(-2px); */
}

.theme-panel {
	position: absolute;
	top: 100%;
	right: 0;
	z-index: 1300;
	background: var(--background);
	border: 1px solid var(--bordercolor, var(--neutral-300));
	border-radius: 0.75rem;
	box-shadow: 0 10px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	min-width: 180px;
	padding: 0.75rem;
	margin-top: 0.75rem;
	backdrop-filter: blur(12px) saturate(150%);
}

/* Panel visibility is now controlled by JavaScript */

.theme-panel .themeswitcher {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.25rem;
	padding: 0;
	margin: 0;
	list-style: none;
}

.theme-panel .themeswitcher::before {
	content: none;
}

.theme-panel .themeswitcher li {
	position: relative;
}

/* 
.theme-panel .themeswitcher li:not(:last-child)::after {
	content: '';
	position: absolute;
	bottom: -0.125rem;
	left: 1.125rem;
	right: 1.125rem;
	height: 1px;
	background: color-mix(in oklch, var(--foreground), transparent 12%);
} */

.theme-panel .themeswitcher a,
.theme-panel .themeswitcher button {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding: 0.875rem 1.125rem;
	text-decoration: none;
	color: inherit;
	border: 1px solid color-mix(in oklch, var(--foreground), transparent 88%);
	border-radius: 0.5rem;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	width: 100%;
	text-align: left;
	font-weight: 500;
	background: color-mix(in oklch, var(--paper), transparent 10%);
	gap: 0.75rem;
}

.theme-panel .themeswitcher a:hover,
.theme-panel .themeswitcher button:hover {
	background: color-mix(in oklch, var(--accentcolor), transparent 15%);
	border-color: color-mix(in oklch, var(--accentcolor), transparent 40%);
	transform: translateY(-1px);
	box-shadow: 0 2px 8px color-mix(in oklch, var(--accentcolor), transparent 20%);
}

.theme-panel .fullscreen-button button {
	padding: 0.875rem 1.125rem;
	background: color-mix(in oklch, var(--paper), transparent 10%);
	border: 1px solid color-mix(in oklch, var(--foreground), transparent 88%);
	border-radius: 0.5rem;
	cursor: pointer;
	font-weight: 500;
	gap: 0.75rem;
}

/* Mobile responsive */
@media (max-width: 768px) {
	.theme-dropdown {
		margin-right: 0.5rem;
	}

	.theme-panel {
		right: -0.5rem;
		min-width: 140px;
	}
}

/* Social */
.social {
	display: flex;
	gap: 1rem;
}

header .social {
	display: none;
}

.social a {
	color: var(--foreground, Canvas);
	line-height: 0;
	transition: all 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}

.social a:hover {
	color: var(--hover);
	/* transform: translateY(-2px); */
}

.social svg {
	width: 24px;
	height: 24px;
}

.social a[href*="x.com"]:hover,
.social a[href*="twitter.com"]:hover {
	color: #000;
	background-color: #fff;
	border-radius: 2px;
	;
}

.social a[href*="facebook.com"]:hover,
.social a[href*="fb.me"]:hover {
	color: #1877f2;
}

/*
.social a[href*="twitter.com"]:hover {
    color: #1da1f2;
}
*/

.social a[href*="youtube.com"]:hover,
.social a[href*="youtu.be"]:hover {
	color: #ff0000;
}

.social a[href*="linkedin.com"]:hover {
	color: #0077b5;
}

/* MAIN */

main#main {
	scroll-margin-top: calc(var(--hh, 0px) + var(--pad) + 5px);
}

main.main {
	flex: 1;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: clamp(2rem, 3vw, 5rem);
	padding: 0 clamp(1.6rem, 3vw, 4rem);
	view-transition-name: mainx;
	position: relative;
	z-index: 2;
}

/* main.main::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    z-index: -1;
    top: 3px;
    height: 100lvh;
    --size: 45px;
    --line: color-mix(in hsl, canvasText, transparent 70%);
    --line: var(--foreground, Canvas);
    opacity: 0.3;
    background: linear-gradient(
          90deg,
          var(--line) 1px,
          transparent 1px var(--size)
        )
        50% 50% / var(--size) var(--size),
      linear-gradient(var(--line) 1px, transparent 1px var(--size)) 50% 50% /
        var(--size) var(--size);
    mask: linear-gradient(-20deg, transparent 40%, white);
    transform-style: flat;
    pointer-events: none;
} */

/* ARTICLE */

article.article {
	flex: 1;
	width: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
	align-self: stretch;
}

article.article>*+* {
	margin-block-start: var(--flow, 2rem);
}

/* ASIDE */

aside.aside {
	width: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
	padding: 2rem;
}

/* FOOTER */

footer.footer {
	padding: var(--pad) 0;
	background-color: rgba(0, 0, 0, 0.2);
	background-image: linear-gradient(to top, var(--background) 0%, transparent 65%);
	color: var(--foreground, Canvas);
	view-transition-name: footerx;
	z-index: 1000;
	/* keep higher than header for wpadminbar */
}

.footer-content {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	text-align: center;
	align-items: center;
}

/* SCROLL TO TOP */
.scrolltotop {
	position: fixed;
	z-index: 1001;
	bottom: 1.8rem;
	left: var(--pad);
	right: auto;
	margin-inline-end: auto;
	margin-inline-start: 0;
	padding: 0.45em;
	border-radius: 50%;
	corner-shape: bevel square bevel square;
	cursor: pointer;
	background-color: var(--accentcolor);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
	color: var(--foreground, Canvas);
	text-decoration: none;
	font-size: 0.9em;
	line-height: 0;
	width: auto;
	aspect-ratio: 1;
	display: block;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.no-js .scrolltotop {
	opacity: 0.6;
}

body:has(.hamburger-switch:checked) .scrolltotop {
	display: none !important;
}

.scrolltotop svg {
	stroke: var(--background, currentcolor);
	aspect-ratio: 1;
	width: 24px;
	height: 24px;
	display: block;
}

[data-theme="combo"] .scrolltotop svg {
	stroke: var(--foreground, Canvas);
}

.scrolltotop:hover {
	background-color: var(--hover);
	color: var(--background);
	opacity: 0.8;
}

.scrolltotop:hover svg path {
	fill: var(--background);
}

@supports (animation-timeline: scroll()) {
	.scrolltotop {
		animation: none;
		animation-range: 200px 300px;
		animation-name: fade;
		animation-fill-mode: both;
		animation-timeline: --scrollTimeline;
	}
}

@keyframes fade {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 0.6;
	}
}

/* FLOW */

.flow>*+* {
	/* FLOW auto spaces between elements, and each can be overriden with --flow. */
	margin-block-start: var(--flow, var(--pad, 1em));
}

:where(.flow .flow) {
	--flow: var(--pad2, 1em);
}

/* ========================================
   WORDPRESS BLOCKS & UTILITIES
   ======================================== */

/* CORE WP BLOCKS */
.wp-block-group {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(12rem, 100%), 1fr));
}

.wp-block-buttons {
	display: flex;
	justify-content: center;
	gap: 1em 2em;
}

/* Wide and Full Width Block Alignments */
:where(article.article > *) {
	max-width: var(--wp--style--global--content-size, 1280px);
	width: 100%;
	margin-inline: auto;
}

.alignwide {
	max-width: var(--wp--style--global--wide-size, 1680px);
	width: 100%;
	margin-inline: auto;
}

.alignfull {
	width: 100vw;
	max-width: 100cqw;
	/* max-width: calc(var(--vw, 1vw) * 100); */
	/* margin-inline: calc(50% - (50 * calc(var(--vw, 1vw)))); */
	margin-inline: calc(50% - 50cqw);
	/* max-width: calc(var(--vw, 1vw) * 100 - 4rem);
    margin-inline: calc(50% - (50 * var(--vw, 1vw) - 2rem)); */
}

@media screen and (min-width: var(--wp--style--global--wide-size, 1680px)) {
	.alignwide {
		margin-inline: calc((100vw - var(--wp--style--global--wide-size, 1680px)) / -2);
	}
}

/* UTILITY */
body .wrapper {
	width: min(100% - 4rem, var(--wrap, 1920px));
	margin-inline: auto;
}

.visuallyhidden {
	text-indent: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	position: absolute;
	clip: rect(1px, 1px, 1px, 1px)
}

.sr-only {
	position: fixed;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

.noselect {
	-webkit-tap-highlight-color: transparent;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.noselect:focus {
	outline: none !important;
}

:is(.btn,
	.wp-element-button,
	input[type="search"]) {
	appearance: none;
	color: var(--background);
	text-decoration: none;
	display: inline-block;
	padding: 0.95em 1.35em;
	font-size: clamp(0.9em, 1.4vw, 1.2em);
	font-family: var(--font-secondary);
	text-transform: uppercase;
	font-weight: 300;
	line-height: 1;
	text-box-trim: trim-both;
	text-box-edge: cap alphabetic;
	border: none;
	/* border-radius: 4px; */
	transition: all 0.1s ease;
	position: relative;
	background: none;
	/* filter: drop-shadow(2px 2px 3px var(--accentcolor)); */
}

/* [data-theme="dark"] .btn,
[data-theme="dark"] .wp-element-button,
[data-theme="dark"] input[type="search"] {
	color: var(--background);
} */

:is(.btn, .wp-element-button)::before {
	content: '';
	pointer-events: none;
	position: absolute;
	z-index: -2;
	inset: 0;
	background:
		linear-gradient(135deg, color-mix(in oklch, var(--accentcolor), white 10%), color-mix(in oklch, var(--hover), white 4%));
	/* background-color: var(--background); */
	/* border-radius: var(--pad);
	transition: border-radius 0.3s ease; */
	/* box-shadow: 0.2em 0.2em 0.4em var(--accentcolor); */
	clip-path: polygon(0 1rem, 1rem 0, 100% 0, 100% 0, 100% calc(100% - 1rem), calc(100% - 1rem) 100%, 0 100%, 0 100%);
}

:is(.btn,
	.wp-element-button,
	input[type="search"]):hover {
	color: var(--foreground, Canvas);
	filter: drop-shadow(2px 2px 3px var(--hover));
}

.btn:hover::before,
.wp-element-button:hover::before,
input[type="search"]:hover::before {
	background-color: var(--hover);
	border-radius: 0;
}

/* 
main.main :where(p, li) {
	max-width: 72ch;
}

article.article>p:first-of-type {
	font-size: clamp(1.8rem, 1.7vw, 2.4rem);
	color: color-mix(in oklch, var(--text), transparent 14%);
}

main.main :where(h1 + p, h2 + p) {
	margin-block-start: clamp(1.2rem, 2vw, 2.4rem);
} 
	*/

header.header {
	border-bottom: 1px solid color-mix(in oklch, var(--foreground), transparent 88%);
	background-image:
		linear-gradient(to bottom, color-mix(in oklch, var(--background), transparent 8%), transparent),
		linear-gradient(90deg, transparent, color-mix(in oklch, var(--accentcolor), transparent 82%), transparent);
	box-shadow: 0 1.2rem 4rem color-mix(in oklch, var(--foreground), transparent 94%);
}

.header-content {
	gap: clamp(1rem, 2vw, 2.4rem);
	padding: 0 clamp(1.6rem, 3vw, 4rem);
}

.hamburger {
	width: 4.8rem;
	height: 4.8rem;
	place-content: center;
	border: 1px solid color-mix(in oklch, var(--foreground), transparent 82%);
	border-radius: 999px;
	background: color-mix(in oklch, var(--paper), transparent 20%);
	box-shadow: 0 1rem 3rem color-mix(in oklch, var(--foreground), transparent 92%);
}

.hamburger:hover {
	background: color-mix(in oklch, var(--accentcolor), transparent 82%);
	border-color: color-mix(in oklch, var(--accentcolor), transparent 35%);

}

.hamburger span {
	width: 22px;
	height: 2px;
}

.menu-main-container .menu {
	gap: clamp(2rem, 5vh, 5rem);
	background:
		radial-gradient(circle at 80% 15%, color-mix(in oklch, var(--accentcolor), transparent 80%), transparent 28rem),
		radial-gradient(circle at 20% 85%, color-mix(in oklch, var(--hover), transparent 82%), transparent 32rem),
		color-mix(in oklch, var(--background), transparent 16%);
}

nav.primary-menu .menu a {
	font-weight: 600;
	letter-spacing: -0.04em;
}

nav.primary-menu .menu a::after {
	content: "";
	position: absolute;
	inset-inline: 1em;
	bottom: 0.25em;
	height: 0.08em;
	background: linear-gradient(90deg, var(--accentcolor), var(--hover));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.25s ease;
}

nav.primary-menu .menu a:hover::after,
nav.primary-menu .menu li.current-menu-item>a::after {
	transform: scaleX(1);
}

main.main {
	gap: clamp(2rem, 3vw, 5rem);
	padding: 0 clamp(1.6rem, 3vw, 4rem);
}

article.article {
	gap: clamp(2rem, 4vw, 5rem);
}

article.article>*+* {
	margin-block-start: 0;
}

.paper {
	--paper-size: clamp(10px, 1vw, 14px);
}

.paper::after {
	background:
		linear-gradient(145deg, color-mix(in oklch, var(--paper), white 14%), color-mix(in oklch, var(--paper), transparent 10%)),
		var(--paper);
	border: 1px solid color-mix(in oklch, var(--foreground), transparent 88%);
	box-shadow: var(--ai-shadow);
	backdrop-filter: blur(18px) saturate(130%);
}

.paper::before {
	background: conic-gradient(from var(--deg, 0deg), transparent, color-mix(in oklch, var(--accentcolor), transparent 24%), transparent 28%, color-mix(in oklch, var(--hover), transparent 42%), transparent 58%);
	opacity: 0.7;
}

.glow {
	filter: drop-shadow(0 1.2rem 4rem color-mix(in oklch, var(--accentcolor), transparent 84%));
}

.wp-block-button__link {
	align-content: center;
	box-sizing: border-box;
	cursor: pointer;
	display: inline-block;
	height: 100%;
	text-align: center;
	word-break: break-word;
}

.btn,
.wp-element-button,
input[type="search"] {
	padding: 0.95em 1.35em;
	font-weight: 600;
	letter-spacing: 0.04em;
	clip-path: none;
	filter: none;
	transform: translateY(0);
}

.btn:hover,
.wp-element-button:hover,
input[type="search"]:hover {
	color: #fff;
	filter: drop-shadow(2px 2px 3px var(--accentcolor));
}

.btn:hover::before,
.wp-element-button:hover::before {
	background:
		linear-gradient(135deg, color-mix(in oklch, var(--hover), white 8%), color-mix(in oklch, var(--accentcolor), white 4%));
}

.wp-block-buttons {
	align-items: center;
	flex-wrap: wrap;
}

.wp-block-group {
	gap: clamp(1.6rem, 2.5vw, 3.2rem);
}

.wp-block-image img,
article.article figure img {
	border-radius: clamp(1.2rem, 2vw, 2.8rem);
	box-shadow: var(--ai-shadow);
}

.item-post,
.terms-list,
.archive-header,
.wp-block-shortcode {
	padding: clamp(1.6rem, 2.5vw, 3.2rem);
	border: 1px solid color-mix(in oklch, var(--foreground), transparent 88%);
	border-radius: clamp(1.4rem, 2vw, 2.6rem);
	background: color-mix(in oklch, var(--paper), transparent 12%);
	box-shadow: var(--ai-shadow);
	backdrop-filter: blur(16px) saturate(130%);
}

.item-post {
	align-items: center;
}

.item-post-image img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
	border-radius: 1.8rem;
}

.terms-list-items a {
	display: inline-flex;
	padding: 0.45em 0.85em;
	border: 1px solid var(--ai-border);
	border-radius: 999px;
	background: color-mix(in oklch, var(--paper), transparent 20%);
	text-decoration: none;
}

footer.footer {
	border-top: 1px solid color-mix(in oklch, var(--foreground), transparent 88%);
	background-image:
		radial-gradient(circle at 50% 0%, color-mix(in oklch, var(--accentcolor), transparent 82%), transparent 32rem),
		linear-gradient(to top, color-mix(in oklch, var(--background), transparent 6%) 0%, transparent 75%);
}

.footer-brand {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.footer-brand p:first-child {
	font-weight: 700;
	letter-spacing: 0.08em;
}

.footer-tagline {
	max-width: 52ch;
	color: color-mix(in oklch, var(--foreground), transparent 24%);
	font-size: clamp(1.4rem, 1vw, 1.6rem);
}

.social {
	align-items: center;
	justify-content: center;
}

.social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 4rem;
	min-height: 4rem;
	border: 1px solid color-mix(in oklch, var(--foreground), transparent 86%);
	border-radius: 999px;
	background: color-mix(in oklch, var(--paper), transparent 20%);
	transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.social a:hover {
	transform: translateY(-2px);
	border-color: color-mix(in oklch, var(--accentcolor), transparent 35%);
	background: color-mix(in oklch, var(--accentcolor), transparent 82%);
}

.wp-block-separator.is-style-dots {
	margin-block: 0;
}

.wp-block-separator.is-style-dots::before {
	content: none;
}

.scrolltotop {
	right: var(--pad);
	left: auto;
	background: linear-gradient(135deg, var(--accentcolor), var(--hover));
	box-shadow: 0 1rem 3rem color-mix(in oklch, var(--accentcolor), transparent 72%);
}

/* ========================================
   RESPONSIVE DESIGN & MEDIA QUERIES
   ======================================== */

@media screen and (min-width: 740px) {
	main.main {
		flex-direction: row;
		align-items: flex-start;
		gap: 2rem;
	}

	article.article {
		flex: 1;
	}

	aside.aside {
		width: 30%;
		/*
        position: sticky;
        top: calc(2rem + var(--wp-admin--admin-bar--height,0px));
        */
		align-self: flex-start;
	}

	.footer-content {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
	}

	.footer-brand {
		display: flex;
		flex-direction: column;
		gap: 0.4rem;
	}

	.footer-brand p:first-child {
		font-weight: 700;
		letter-spacing: 0.08em;
	}

	.footer-tagline {
		max-width: 52ch;
		color: color-mix(in oklch, var(--foreground), transparent 24%);
		font-size: clamp(1.4rem, 1vw, 1.6rem);
	}

	.themeswitcher,
	.social {
		align-items: center;
		justify-content: center;
	}

	.themeswitcher a,
	.social a,
	button#fullscreenButton {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-width: 4rem;
		min-height: 4rem;
		border: 1px solid color-mix(in oklch, var(--foreground), transparent 86%);
		border-radius: 999px;
		background: color-mix(in oklch, var(--paper), transparent 20%);
		transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
	}

	.themeswitcher a {
		padding-inline: 1.2em;
	}

	.themeswitcher a:hover,
	.social a:hover,
	button#fullscreenButton:hover {
		transform: translateY(-2px);
		border-color: color-mix(in oklch, var(--accentcolor), transparent 35%);
		background: color-mix(in oklch, var(--accentcolor), transparent 82%);
	}

	.scrolltotop {
		right: var(--pad);
		left: auto;
		background: linear-gradient(135deg, var(--accentcolor), var(--hover));
		box-shadow: 0 1rem 3rem color-mix(in oklch, var(--accentcolor), transparent 72%);
	}
}

/* @media screen and (max-width: 739px) {
	:root {
		--pad: 1.4rem;
	}

	.sitelogo {
		max-width: 58vw;
	}

	.header-content {
		width: min(100% - 2.4rem, var(--wrap, 1920px));
	}

	main.main {
		padding-inline: 1.2rem;
	}

	.footer-content {
		width: min(100% - 2.4rem, var(--wrap, 1920px));
	}
} */

@media (prefers-reduced-motion: reduce) {

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}
}