/*!
 * XWHITE — Global Design System
 * -----------------------------------------------------------------------
 * Dark futuristic enterprise IT design.
 * bg #050507 · glass cards · neon cyan #00F5FF · neon violet #BF5FFF
 *
 * Owns: tokens, reset, typography, layout, buttons, cards, header,
 * mobile menu, footer, preloader, scroll progress, custom cursor,
 * forms baseline, WP core classes, pagination, a11y, reduced motion.
 *
 * Homepage sections & inner templates live in sections.css.
 *
 * @package XWhite
 * @since   1.0.0
 */

/* =========================================================================
   1. DESIGN TOKENS
   ========================================================================= */

:root {
	/* Colors */
	--xw-bg: #050507;
	--xw-bg-2: #111118;
	--xw-border: #222230;
	--xw-text-muted: #3A3A50;        /* decorative-muted only (low contrast) */
	--xw-text-soft: #8A8AA8;         /* readable secondary text (AA) */
	--xw-text: #E8F4FF;
	--xw-accent: #00F5FF;
	--xw-accent-2: #BF5FFF;

	/* Type */
	--xw-font-display: 'Cormorant Garamond', serif;
	--xw-font-heading: 'Rajdhani', sans-serif;
	--xw-font-body: 'Space Grotesk', sans-serif;

	/* Shape / layout */
	--xw-radius: 14px;
	--xw-radius-sm: 8px;
	--xw-container: 1280px;

	/* Effects */
	--xw-glow-cyan: 0 0 24px rgba(0, 245, 255, .35);
	--xw-glow-violet: 0 0 24px rgba(191, 95, 255, .35);
	--xw-gradient: linear-gradient(135deg, var(--xw-accent), var(--xw-accent-2));
	--xw-glass: rgba(17, 17, 24, .6);
	--xw-ease: cubic-bezier(.22, 1, .36, 1);
	--xw-section-pad: clamp(4rem, 9vw, 7.5rem);
}

/* =========================================================================
   2. MODERN RESET
   ========================================================================= */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
	scroll-padding-top: 6rem;
}

body {
	min-height: 100vh;
	background-color: var(--xw-bg);
	color: var(--xw-text);
	font-family: var(--xw-font-body);
	font-size: 1rem;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: clip;
}

img,
picture,
video,
canvas,
svg {
	display: block;
	max-width: 100%;
	height: auto;
}

svg {
	fill: currentColor;
}

input,
button,
textarea,
select {
	font: inherit;
	color: inherit;
}

button {
	background: none;
	border: 0;
	cursor: pointer;
}

ul[class],
ol[class] {
	list-style: none;
}

table {
	border-collapse: collapse;
	width: 100%;
}

blockquote,
figure {
	margin: 0;
}

/* Selection */
::selection {
	background-color: var(--xw-accent);
	color: var(--xw-bg);
	text-shadow: none;
}

/* Scrollbar — thin, dark with cyan thumb */
html {
	scrollbar-width: thin;
	scrollbar-color: rgba(0, 245, 255, .4) var(--xw-bg-2);
}

::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}

::-webkit-scrollbar-track {
	background: var(--xw-bg-2);
}

::-webkit-scrollbar-thumb {
	background: linear-gradient(180deg, rgba(0, 245, 255, .45), rgba(191, 95, 255, .45));
	border-radius: 8px;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--xw-accent);
}

/* Focus visibility — a11y */
:focus {
	outline: none;
}

:focus-visible {
	outline: 2px solid var(--xw-accent);
	outline-offset: 2px;
	border-radius: 2px;
}

/* =========================================================================
   3. BASE TYPOGRAPHY
   ========================================================================= */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--xw-font-heading);
	font-weight: 600;
	line-height: 1.15;
	color: var(--xw-text);
	letter-spacing: .01em;
	text-wrap: balance;
}

h1 { font-size: clamp(2.5rem, 6vw, 4.5rem); }
h2 { font-size: clamp(2rem, 4.5vw, 3.25rem); }
h3 { font-size: clamp(1.5rem, 3vw, 2.125rem); }
h4 { font-size: clamp(1.25rem, 2vw, 1.5rem); }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; letter-spacing: .06em; text-transform: uppercase; }

p {
	margin-bottom: 1.25em;
}

p:last-child {
	margin-bottom: 0;
}

/* Display serif accent (hero italics etc.) */
.xw-display {
	font-family: var(--xw-font-display);
	font-weight: 500;
	font-style: italic;
	letter-spacing: 0;
}

/* Gradient text utility */
.xw-gradient-text {
	background: var(--xw-gradient);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

a {
	color: var(--xw-accent);
	text-decoration: none;
	transition: color .3s var(--xw-ease);
}

a:hover {
	color: var(--xw-text);
}

strong, b { font-weight: 600; }

code, kbd, pre, samp {
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
	font-size: .92em;
	background: var(--xw-bg-2);
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	padding: .15em .4em;
	color: var(--xw-text);
}

pre {
	padding: 1.25rem;
	overflow-x: auto;
}

pre code {
	background: none;
	border: 0;
	padding: 0;
}

hr {
	border: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--xw-border), transparent);
	margin: 2rem 0;
}

blockquote {
	border-left: 2px solid var(--xw-accent);
	padding: .5rem 0 .5rem 1.5rem;
	color: var(--xw-text-soft);
	font-family: var(--xw-font-display);
	font-size: 1.25rem;
	font-style: italic;
}

/* =========================================================================
   4. ACCESSIBILITY HELPERS (WordPress standard)
   ========================================================================= */

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--xw-bg-2);
	border-radius: var(--xw-radius-sm);
	box-shadow: var(--xw-glow-cyan);
	clip: auto !important;
	clip-path: none;
	color: var(--xw-accent);
	display: block;
	font-family: var(--xw-font-heading);
	font-size: .875rem;
	font-weight: 600;
	height: auto;
	left: 5px;
	letter-spacing: .06em;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	text-transform: uppercase;
	top: 5px;
	width: auto;
	z-index: 100000;
}

.skip-link {
	left: -9999rem;
	position: absolute;
	top: -9999rem;
	z-index: 100010;
}

.skip-link:focus {
	left: 6px;
	top: 7px;
}

/* =========================================================================
   5. LAYOUT
   ========================================================================= */

.xw-container {
	width: 100%;
	max-width: var(--xw-container);
	margin-inline: auto;
	padding-inline: clamp(1rem, 4vw, 2rem);
}

.xw-section {
	position: relative;
	padding-block: var(--xw-section-pad);
}

/* Section heading pattern (used by xwhite_section_heading) */
.xw-section__heading {
	max-width: 720px;
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.xw-section__heading--center {
	margin-inline: auto;
	text-align: center;
}

.xw-section__heading--left { text-align: left; }
.xw-section__heading--right { margin-inline-start: auto; text-align: right; }

.xw-section__tagline {
	display: inline-block;
	font-family: var(--xw-font-heading);
	font-size: .8125rem;
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--xw-accent);
	margin-bottom: .875rem;
	position: relative;
	padding: .35em 1em;
	border: 1px solid rgba(0, 245, 255, .25);
	border-radius: 100px;
	background: rgba(0, 245, 255, .05);
}

.xw-section__title {
	margin-bottom: .5em;
}

.xw-section__title span {
	background: var(--xw-gradient);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

.xw-section__subtitle {
	color: var(--xw-text-soft);
	font-size: 1.0625rem;
	margin-bottom: 0;
}

/* Grids — auto-collapsing */
.xw-grid {
	display: grid;
	gap: clamp(1.25rem, 3vw, 2rem);
}

.xw-grid--2 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 420px), 1fr)); }
.xw-grid--3 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr)); }
.xw-grid--4 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr)); }

/* =========================================================================
   6. BUTTONS & LINKS
   ========================================================================= */

.xw-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .55em;
	font-family: var(--xw-font-heading);
	font-size: .9375rem;
	font-weight: 600;
	letter-spacing: .06em;
	text-transform: uppercase;
	line-height: 1.2;
	padding: .8em 1.6em;
	border-radius: var(--xw-radius-sm);
	border: 1px solid transparent;
	background: transparent;
	color: var(--xw-text);
	overflow: hidden;
	cursor: pointer;
	white-space: nowrap;
	transition:
		color .35s var(--xw-ease),
		border-color .35s var(--xw-ease),
		background-color .35s var(--xw-ease),
		box-shadow .35s var(--xw-ease),
		transform .35s var(--xw-ease);
}

.xw-btn__text,
.xw-btn__icon {
	position: relative;
	z-index: 2;
}

.xw-btn__icon {
	flex-shrink: 0;
	transition: transform .35s var(--xw-ease);
}

.xw-btn:hover .xw-btn__icon {
	transform: translateX(4px);
}

/* Animated sheen */
.xw-btn__glow {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		105deg,
		transparent 30%,
		rgba(255, 255, 255, .12) 50%,
		transparent 70%
	);
	background-size: 250% 100%;
	background-position: 120% 0;
	pointer-events: none;
	transition: background-position .9s var(--xw-ease);
}

.xw-btn:hover .xw-btn__glow {
	background-position: -120% 0;
}

/* Primary — cyan */
.xw-btn--primary {
	border-color: var(--xw-accent);
	color: var(--xw-accent);
}

.xw-btn--primary:hover,
.xw-btn--primary:focus-visible {
	color: var(--xw-accent);
	background-color: rgba(0, 245, 255, .08);
	box-shadow: var(--xw-glow-cyan);
	transform: translateY(-2px);
}

/* Outline — violet */
.xw-btn--outline {
	border-color: var(--xw-accent-2);
	color: var(--xw-accent-2);
}

.xw-btn--outline:hover,
.xw-btn--outline:focus-visible {
	color: var(--xw-accent-2);
	background-color: rgba(191, 95, 255, .08);
	box-shadow: var(--xw-glow-violet);
	transform: translateY(-2px);
}

/* Ghost — borderless text button */
.xw-btn--ghost {
	border-color: transparent;
	color: var(--xw-text);
	padding-inline: .4em;
}

.xw-btn--ghost:hover,
.xw-btn--ghost:focus-visible {
	color: var(--xw-accent);
}

.xw-btn--ghost:hover .xw-btn__icon {
	transform: translateX(6px);
}

/* Inline arrow link */
.xw-link {
	display: inline-flex;
	align-items: center;
	gap: .45em;
	font-family: var(--xw-font-heading);
	font-size: .9375rem;
	font-weight: 600;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--xw-accent);
}

.xw-link svg {
	transition: transform .35s var(--xw-ease);
}

.xw-link:hover {
	color: var(--xw-text);
}

.xw-link:hover svg {
	transform: translateX(5px);
}

/* =========================================================================
   7. CARDS & GLASS SURFACES
   ========================================================================= */

.xw-card {
	position: relative;
	background: var(--xw-glass);
	-webkit-backdrop-filter: blur(14px);
	backdrop-filter: blur(14px);
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius);
	overflow: hidden;
	transition:
		transform .45s var(--xw-ease),
		border-color .45s var(--xw-ease),
		box-shadow .45s var(--xw-ease);
}

.xw-card:hover {
	transform: translateY(-6px);
	border-color: rgba(0, 245, 255, .5);
	box-shadow: var(--xw-glow-cyan);
}

/* Gradient-border utility (pseudo-element mask trick) */
.xw-gradient-border {
	position: relative;
	border-radius: var(--xw-radius);
	background: var(--xw-bg-2);
}

.xw-gradient-border::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	padding: 1px;
	background: var(--xw-gradient);
	-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}

/* =========================================================================
   8. HEADER
   ========================================================================= */

.xw-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: transparent;
	transition: background-color .4s var(--xw-ease), box-shadow .4s var(--xw-ease);
}

.xw-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	min-height: 84px;
	transition: min-height .4s var(--xw-ease);
}

/* Bottom gradient border — animates in on scroll */
.xw-header__border {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--xw-accent), var(--xw-accent-2), transparent);
	transform: scaleX(0);
	transform-origin: center;
	transition: transform .6s var(--xw-ease), opacity .6s var(--xw-ease);
	opacity: 0;
	pointer-events: none;
}

.xw-header.is-scrolled {
	background: rgba(5, 5, 7, .75);
	-webkit-backdrop-filter: blur(16px);
	backdrop-filter: blur(16px);
	box-shadow: 0 8px 32px rgba(0, 0, 0, .4);
}

.xw-header.is-scrolled .xw-header__inner {
	min-height: 68px;
}

.xw-header.is-scrolled .xw-header__border {
	transform: scaleX(1);
	opacity: 1;
}

/* Brand / logo */
.xw-header__brand {
	flex-shrink: 0;
	display: flex;
	align-items: center;
}

.xw-header__brand .custom-logo {
	max-height: 48px;
	width: auto;
}

.xw-header__logo {
	display: inline-flex;
	align-items: center;
	gap: .7rem;
	color: var(--xw-text);
}

.xw-header__logo:hover {
	color: var(--xw-text);
}

.xw-header__logo-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: var(--xw-radius-sm);
	background: var(--xw-gradient);
	color: var(--xw-bg);
	font-family: var(--xw-font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	box-shadow: var(--xw-glow-cyan);
	transition: box-shadow .35s var(--xw-ease), transform .35s var(--xw-ease);
}

.xw-header__logo:hover .xw-header__logo-mark {
	box-shadow: var(--xw-glow-violet);
	transform: rotate(-6deg) scale(1.05);
}

.xw-header__logo-text {
	font-family: var(--xw-font-heading);
	font-size: 1.375rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
}

/* Primary nav */
.xw-header__nav {
	flex: 1;
	display: flex;
	justify-content: center;
	min-width: 0;
}

.xw-nav {
	display: flex;
	align-items: center;
	gap: .25rem;
	list-style: none;
}

.xw-nav li {
	position: relative;
}

.xw-nav a {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: .3em;
	font-family: var(--xw-font-heading);
	font-size: .875rem;
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--xw-text);
	padding: .6em .9em;
	white-space: nowrap;
	transition: color .3s var(--xw-ease);
}

/* Animated gradient underline */
.xw-nav > li > a::after {
	content: "";
	position: absolute;
	left: .9em;
	right: .9em;
	bottom: .25em;
	height: 2px;
	background: var(--xw-gradient);
	border-radius: 2px;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .4s var(--xw-ease);
}

.xw-nav > li > a:hover,
.xw-nav > li > a:focus-visible {
	color: var(--xw-accent);
}

.xw-nav > li > a:hover::after,
.xw-nav > li > a:focus-visible::after,
.xw-nav > li.current-menu-item > a::after,
.xw-nav > li.current-menu-ancestor > a::after {
	transform: scaleX(1);
}

.xw-nav > li.current-menu-item > a,
.xw-nav > li.current-menu-ancestor > a {
	color: var(--xw-accent);
}

/* Dropdown indicator */
.xw-nav li.menu-item-has-children > a::before {
	content: "";
	order: 2;
	width: 7px;
	height: 7px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	transition: transform .3s var(--xw-ease);
	flex-shrink: 0;
	margin-left: .1em;
}

.xw-nav li.menu-item-has-children:hover > a::before,
.xw-nav li.menu-item-has-children:focus-within > a::before {
	transform: rotate(225deg) translateY(-1px);
}

/* Submenus — glass panels, hover + :focus-within (keyboard), depth 3 */
.xw-nav .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 1001;
	min-width: 230px;
	padding: .6rem;
	list-style: none;
	background: rgba(10, 10, 15, .92);
	-webkit-backdrop-filter: blur(18px);
	backdrop-filter: blur(18px);
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	box-shadow: 0 20px 40px rgba(0, 0, 0, .5), 0 0 0 1px rgba(0, 245, 255, .06);
	opacity: 0;
	visibility: hidden;
	transform: translateY(12px);
	transition:
		opacity .35s var(--xw-ease),
		transform .35s var(--xw-ease),
		visibility 0s linear .35s;
	pointer-events: none;
}

.xw-nav li:hover > .sub-menu,
.xw-nav li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	transition-delay: 0s;
	pointer-events: auto;
}

/* Depth 2/3 fly out sideways */
.xw-nav .sub-menu .sub-menu {
	top: -.6rem;
	left: 100%;
	transform: translateX(12px);
}

.xw-nav .sub-menu li:hover > .sub-menu,
.xw-nav .sub-menu li:focus-within > .sub-menu {
	transform: translateX(0);
}

.xw-nav .sub-menu a {
	display: flex;
	width: 100%;
	font-size: .8125rem;
	letter-spacing: .08em;
	padding: .65em 1em;
	border-radius: 6px;
	color: var(--xw-text-soft);
	transition: color .3s var(--xw-ease), background-color .3s var(--xw-ease), padding-left .3s var(--xw-ease);
}

.xw-nav .sub-menu a:hover,
.xw-nav .sub-menu a:focus-visible,
.xw-nav .sub-menu .current-menu-item > a {
	color: var(--xw-accent);
	background: rgba(0, 245, 255, .07);
	padding-left: 1.25em;
}

.xw-nav .sub-menu li.menu-item-has-children > a::before {
	margin-left: auto;
	transform: rotate(-45deg);
}

/* Header actions */
.xw-header__actions {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	gap: 1rem;
}

/* Mobile toggle — hidden on desktop */
.xw-header__toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	color: var(--xw-text);
	background: var(--xw-glass);
	transition: border-color .3s var(--xw-ease), color .3s var(--xw-ease), box-shadow .3s var(--xw-ease);
}

.xw-header__toggle:hover {
	border-color: var(--xw-accent);
	color: var(--xw-accent);
	box-shadow: var(--xw-glow-cyan);
}

/* Icon swap via aria-expanded */
.xw-header__toggle .xw-header__toggle-close { display: none; }
.xw-header__toggle .xw-header__toggle-open { display: block; }
.xw-header__toggle[aria-expanded="true"] .xw-header__toggle-open { display: none; }
.xw-header__toggle[aria-expanded="true"] .xw-header__toggle-close { display: block; }

/* =========================================================================
   9. MOBILE MENU
   ========================================================================= */

.xw-mobile-menu {
	position: fixed;
	inset: 0;
	z-index: 990;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 2.5rem;
	padding: 7rem clamp(1.5rem, 8vw, 4rem) 3rem;
	background: rgba(5, 5, 7, .88);
	-webkit-backdrop-filter: blur(24px);
	backdrop-filter: blur(24px);
	transform: translateX(100%);
	transition: transform .5s var(--xw-ease), visibility 0s linear .5s;
	visibility: hidden;
	overflow-y: auto;
}

/* [hidden] wins until JS removes it; visibility handles the transition */
.xw-mobile-menu[hidden] {
	display: none;
}

.xw-mobile-menu.is-open {
	transform: translateX(0);
	visibility: visible;
	transition-delay: 0s;
}

.xw-mobile-nav {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: .25rem;
}

.xw-mobile-nav a {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-family: var(--xw-font-heading);
	font-size: clamp(1.75rem, 6vw, 2.5rem);
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--xw-text);
	padding: .3em 0;
	transition: color .3s var(--xw-ease), padding-left .3s var(--xw-ease);
}

.xw-mobile-nav a:hover,
.xw-mobile-nav a:focus-visible,
.xw-mobile-nav .current-menu-item > a {
	color: var(--xw-accent);
	padding-left: .4em;
}

.xw-mobile-nav .sub-menu {
	list-style: none;
	padding-left: 1.25rem;
	border-left: 1px solid var(--xw-border);
	margin: .25rem 0 .75rem;
}

.xw-mobile-nav .sub-menu a {
	font-size: 1.125rem;
	font-weight: 500;
	color: var(--xw-text-soft);
}

.xw-mobile-menu__cta {
	flex-shrink: 0;
}

/* Body scroll lock while menu is open */
body.xw-menu-open {
	overflow: hidden;
}

/* =========================================================================
   10. FOOTER
   ========================================================================= */

.xw-footer {
	position: relative;
	background:
		radial-gradient(ellipse 60% 40% at 50% 0%, rgba(0, 245, 255, .05), transparent 70%),
		var(--xw-bg-2);
	margin-top: auto;
}

/* Animated gradient top border */
.xw-footer__border {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent,
		var(--xw-accent),
		var(--xw-accent-2),
		var(--xw-accent),
		transparent
	);
	background-size: 200% 100%;
	animation: xw-border-slide 6s linear infinite;
}

@keyframes xw-border-slide {
	0%   { background-position: 0% 0; }
	100% { background-position: -200% 0; }
}

.xw-footer__grid {
	display: grid;
	grid-template-columns: 1.6fr repeat(4, 1fr);
	gap: clamp(2rem, 4vw, 3.5rem);
	padding-block: clamp(3.5rem, 7vw, 5.5rem) clamp(2.5rem, 5vw, 4rem);
}

/* Brand column */
.xw-footer__logo {
	display: inline-flex;
	align-items: center;
	gap: .7rem;
	font-family: var(--xw-font-heading);
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--xw-text);
	margin-bottom: 1.25rem;
}

.xw-footer__logo:hover {
	color: var(--xw-accent);
}

.xw-footer__logo-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: var(--xw-radius-sm);
	background: var(--xw-gradient);
	color: var(--xw-bg);
	font-size: 1.375rem;
	font-weight: 700;
	line-height: 1;
}

.xw-footer__about {
	color: var(--xw-text-soft);
	font-size: .9375rem;
	max-width: 34ch;
	margin-bottom: 1.75rem;
}

/* Social circles */
.xw-footer__social {
	display: flex;
	flex-wrap: wrap;
	gap: .6rem;
}

.xw-footer__social-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border: 1px solid var(--xw-border);
	border-radius: 50%;
	color: var(--xw-text-soft);
	background: transparent;
	overflow: hidden;
	transition:
		color .35s var(--xw-ease),
		border-color .35s var(--xw-ease),
		box-shadow .35s var(--xw-ease),
		transform .35s var(--xw-ease);
}

.xw-footer__social-link::before {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--xw-gradient);
	opacity: 0;
	transition: opacity .35s var(--xw-ease);
}

.xw-footer__social-link svg {
	position: relative;
	z-index: 1;
}

.xw-footer__social-link:hover,
.xw-footer__social-link:focus-visible {
	color: var(--xw-bg);
	border-color: transparent;
	box-shadow: var(--xw-glow-cyan);
	transform: translateY(-3px);
}

.xw-footer__social-link:hover::before,
.xw-footer__social-link:focus-visible::before {
	opacity: 1;
}

/* Widget titles */
.xw-footer__widget-title,
.xw-footer .widget-title {
	position: relative;
	font-family: var(--xw-font-heading);
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--xw-text);
	padding-bottom: .75rem;
	margin-bottom: 1.5rem;
}

.xw-footer__widget-title::after,
.xw-footer .widget-title::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 32px;
	height: 2px;
	border-radius: 2px;
	background: var(--xw-accent);
	box-shadow: 0 0 8px rgba(0, 245, 255, .6);
}

/* Footer menus */
.xw-footer__menu {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: .65rem;
}

.xw-footer__menu a {
	position: relative;
	display: inline-block;
	color: var(--xw-text-soft);
	font-size: .9375rem;
	padding-left: 0;
	transition: color .3s var(--xw-ease), padding-left .3s var(--xw-ease);
}

.xw-footer__menu a::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 0;
	height: 1px;
	background: var(--xw-accent);
	transition: width .3s var(--xw-ease);
}

.xw-footer__menu a:hover,
.xw-footer__menu a:focus-visible {
	color: var(--xw-accent);
	padding-left: 16px;
}

.xw-footer__menu a:hover::before,
.xw-footer__menu a:focus-visible::before {
	width: 10px;
}

/* Contact list */
.xw-footer__contact {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: .9rem;
}

.xw-footer__contact li {
	display: flex;
	align-items: flex-start;
	gap: .7rem;
	color: var(--xw-text-soft);
	font-size: .9375rem;
}

.xw-footer__contact svg {
	flex-shrink: 0;
	margin-top: .3em;
	color: var(--xw-accent);
}

.xw-footer__contact a {
	color: var(--xw-text-soft);
}

.xw-footer__contact a:hover {
	color: var(--xw-accent);
}

/* Bottom bar */
.xw-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-block: 1.5rem;
	border-top: 1px solid var(--xw-border);
}

.xw-footer__copyright {
	color: var(--xw-text-soft);
	font-size: .875rem;
	margin: 0;
}

.xw-footer__legal {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
}

.xw-footer__legal a {
	color: var(--xw-text-soft);
	font-size: .875rem;
}

.xw-footer__legal a:hover {
	color: var(--xw-accent);
}

/* =========================================================================
   11. PRELOADER
   ========================================================================= */

.xw-preloader {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--xw-bg);
	transition: opacity .6s var(--xw-ease), visibility 0s linear .6s;
}

.xw-preloader__mark {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 88px;
	height: 88px;
	border-radius: var(--xw-radius);
	background: var(--xw-gradient);
	animation: xw-preloader-pulse 1.6s var(--xw-ease) infinite;
}

.xw-preloader__x {
	font-family: var(--xw-font-heading);
	font-size: 3rem;
	font-weight: 700;
	line-height: 1;
	color: var(--xw-bg);
}

@keyframes xw-preloader-pulse {
	0%, 100% {
		box-shadow: 0 0 24px rgba(0, 245, 255, .35), 0 0 64px rgba(191, 95, 255, .2);
		transform: scale(1);
	}
	50% {
		box-shadow: 0 0 48px rgba(0, 245, 255, .65), 0 0 110px rgba(191, 95, 255, .4);
		transform: scale(1.07);
	}
}

.xw-preloader.is-done {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

/* =========================================================================
   12. SCROLL PROGRESS BAR
   ========================================================================= */

.xw-scroll-progress {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	z-index: 1200;
	pointer-events: none;
	background: transparent;
}

.xw-scroll-progress span {
	display: block;
	width: 100%;
	height: 100%;
	background: var(--xw-gradient);
	box-shadow: 0 0 12px rgba(0, 245, 255, .5);
	transform: scaleX(0);
	transform-origin: left center;
	will-change: transform;
}

/* =========================================================================
   13. CUSTOM CURSOR
   ========================================================================= */

.xw-cursor,
.xw-cursor-dot {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10000;
	pointer-events: none;
	border-radius: 50%;
	will-change: transform;
}

/* Only shown for fine pointers when animations are enabled */
@media (hover: hover) and (pointer: fine) {
	body.xw-has-animations .xw-cursor,
	body.xw-has-animations .xw-cursor-dot {
		display: block;
	}

	body.xw-has-animations {
		cursor: none;
	}

	body.xw-has-animations a,
	body.xw-has-animations button,
	body.xw-has-animations input,
	body.xw-has-animations textarea,
	body.xw-has-animations select,
	body.xw-has-animations label {
		cursor: none;
	}
}

.xw-cursor {
	width: 28px;
	height: 28px;
	margin: -14px 0 0 -14px;
	border: 1px solid rgba(0, 245, 255, .8);
	mix-blend-mode: difference;
	transition: width .3s var(--xw-ease), height .3s var(--xw-ease), margin .3s var(--xw-ease), border-color .3s var(--xw-ease), background-color .3s var(--xw-ease);
}

.xw-cursor.is-hover {
	width: 52px;
	height: 52px;
	margin: -26px 0 0 -26px;
	border-color: rgba(191, 95, 255, .9);
	background: rgba(0, 245, 255, .08);
}

.xw-cursor-dot {
	width: 4px;
	height: 4px;
	margin: -2px 0 0 -2px;
	background: var(--xw-accent);
	box-shadow: 0 0 8px rgba(0, 245, 255, .8);
}

/* =========================================================================
   14. FORMS BASELINE
   ========================================================================= */

label {
	display: inline-block;
	font-family: var(--xw-font-heading);
	font-size: .875rem;
	font-weight: 600;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--xw-text-soft);
	margin-bottom: .5rem;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="tel"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="date"],
textarea,
select {
	display: block;
	width: 100%;
	background: #111118;
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	color: var(--xw-text);
	font-family: var(--xw-font-body);
	font-size: 1rem;
	line-height: 1.5;
	padding: .8em 1.1em;
	transition: border-color .3s var(--xw-ease), box-shadow .3s var(--xw-ease);
	-webkit-appearance: none;
	appearance: none;
}

select {
	background-image:
		linear-gradient(45deg, transparent 50%, var(--xw-accent) 50%),
		linear-gradient(135deg, var(--xw-accent) 50%, transparent 50%);
	background-position:
		calc(100% - 20px) calc(50% - 2px),
		calc(100% - 14px) calc(50% - 2px);
	background-size: 6px 6px;
	background-repeat: no-repeat;
	padding-right: 2.75em;
}

textarea {
	min-height: 140px;
	resize: vertical;
}

input:focus,
textarea:focus,
select:focus {
	outline: none;
	border-color: var(--xw-accent);
	box-shadow: 0 0 0 3px rgba(0, 245, 255, .15), var(--xw-glow-cyan);
}

::placeholder {
	color: var(--xw-text-soft);
	opacity: .8;
}

input[type="checkbox"],
input[type="radio"] {
	width: 1.1em;
	height: 1.1em;
	accent-color: var(--xw-accent);
}

fieldset {
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	padding: 1.25rem;
}

/* Themed forms + AJAX message states */
.xw-form {
	position: relative;
}

.xw-form__message {
	margin-top: 1rem;
	padding: .8em 1.1em;
	border-radius: var(--xw-radius-sm);
	border: 1px solid var(--xw-border);
	background: var(--xw-glass);
	font-size: .9375rem;
	display: none;
}

.xw-form__message.is-visible {
	display: block;
}

.xw-form__message.is-success {
	border-color: rgba(0, 245, 255, .5);
	color: var(--xw-accent);
	box-shadow: var(--xw-glow-cyan);
}

.xw-form__message.is-error {
	border-color: rgba(255, 80, 100, .55);
	color: #FF7A8A;
	box-shadow: 0 0 18px rgba(255, 80, 100, .18);
}

.xw-form .xw-btn[disabled],
.xw-form button[disabled] {
	opacity: .55;
	pointer-events: none;
}

input.is-invalid,
textarea.is-invalid,
select.is-invalid {
	border-color: rgba(255, 80, 100, .7);
	box-shadow: 0 0 0 3px rgba(255, 80, 100, .12);
}

/* =========================================================================
   15. GENERIC COMPONENTS DRIVEN BY main.js
   (structural baseline only — decorative styling may extend in sections.css)
   ========================================================================= */

/* Accordion */
.xw-accordion__item {
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	background: var(--xw-glass);
	-webkit-backdrop-filter: blur(14px);
	backdrop-filter: blur(14px);
	margin-bottom: .75rem;
	overflow: hidden;
	transition: border-color .35s var(--xw-ease);
}

.xw-accordion__item.is-open {
	border-color: rgba(0, 245, 255, .45);
}

.xw-accordion__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	width: 100%;
	text-align: left;
	font-family: var(--xw-font-heading);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--xw-text);
	padding: 1.1rem 1.4rem;
	transition: color .3s var(--xw-ease);
}

.xw-accordion__header:hover,
.xw-accordion__header[aria-expanded="true"] {
	color: var(--xw-accent);
}

.xw-accordion__header svg {
	flex-shrink: 0;
	transition: transform .35s var(--xw-ease);
}

.xw-accordion__header[aria-expanded="true"] svg {
	transform: rotate(45deg);
}

.xw-accordion__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height .45s var(--xw-ease);
}

.xw-accordion__body > * {
	padding: 0 1.4rem 1.25rem;
	color: var(--xw-text-soft);
}

/* Carousel — scroll-snap track */
[data-xw-carousel] {
	position: relative;
}

.xw-carousel__track {
	display: flex;
	gap: clamp(1rem, 2.5vw, 1.75rem);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding-block: .5rem;
	cursor: grab;
}

.xw-carousel__track::-webkit-scrollbar {
	display: none;
}

.xw-carousel__track.is-dragging {
	cursor: grabbing;
	scroll-snap-type: none;
	scroll-behavior: auto;
}

.xw-carousel__track > * {
	flex: 0 0 auto;
	scroll-snap-align: start;
}

.xw-carousel__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border: 1px solid var(--xw-border);
	border-radius: 50%;
	background: var(--xw-glass);
	-webkit-backdrop-filter: blur(14px);
	backdrop-filter: blur(14px);
	color: var(--xw-text);
	transition: color .3s var(--xw-ease), border-color .3s var(--xw-ease), box-shadow .3s var(--xw-ease), opacity .3s var(--xw-ease);
}

.xw-carousel__btn:hover:not([disabled]) {
	color: var(--xw-accent);
	border-color: var(--xw-accent);
	box-shadow: var(--xw-glow-cyan);
}

.xw-carousel__btn[disabled] {
	opacity: .35;
	cursor: not-allowed;
}

/* Marquee — children duplicated once by main.js for a seamless loop */
[data-xw-marquee] {
	overflow: hidden;
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
	mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

.xw-marquee__inner,
[data-xw-marquee] > * {
	display: flex;
	align-items: center;
	gap: clamp(2rem, 6vw, 4.5rem);
	width: max-content;
	animation: xw-marquee 32s linear infinite;
	will-change: transform;
}

[data-xw-marquee]:hover .xw-marquee__inner,
[data-xw-marquee]:hover > * {
	animation-play-state: paused;
}

@keyframes xw-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* =========================================================================
   16. PAGE HEADER & BREADCRUMBS (global inner-page band)
   ========================================================================= */

.xw-page-header {
	position: relative;
	padding: calc(84px + clamp(3rem, 8vw, 6rem)) 0 clamp(3rem, 6vw, 5rem);
	overflow: hidden;
	background:
		radial-gradient(ellipse 50% 60% at 80% 0%, rgba(191, 95, 255, .08), transparent 70%),
		var(--xw-bg);
}

.xw-page-header__glow {
	position: absolute;
	top: -160px;
	left: 50%;
	transform: translateX(-50%);
	width: 640px;
	height: 320px;
	background: radial-gradient(ellipse, rgba(0, 245, 255, .12), transparent 70%);
	filter: blur(40px);
	pointer-events: none;
}

.xw-page-header__title {
	margin: .35em 0 0;
}

.xw-page-header__subtitle {
	color: var(--xw-text-soft);
	font-size: 1.125rem;
	max-width: 60ch;
	margin-top: 1rem;
}

.xw-breadcrumbs {
	font-family: var(--xw-font-heading);
	font-size: .8125rem;
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
}

.xw-breadcrumbs ol {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .5rem;
}

.xw-breadcrumbs li {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	color: var(--xw-text-soft);
}

.xw-breadcrumbs li + li::before {
	content: "/";
	color: var(--xw-text-muted);
}

.xw-breadcrumbs a {
	color: var(--xw-text-soft);
}

.xw-breadcrumbs a:hover {
	color: var(--xw-accent);
}

.xw-breadcrumbs [aria-current="page"] {
	color: var(--xw-accent);
}

/* =========================================================================
   17. PAGINATION
   ========================================================================= */

.xw-pagination .nav-links,
.xw-pagination {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: .6rem;
	margin-top: clamp(2.5rem, 5vw, 4rem);
}

.xw-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 46px;
	height: 46px;
	padding: 0 .8em;
	font-family: var(--xw-font-heading);
	font-size: .9375rem;
	font-weight: 600;
	color: var(--xw-text-soft);
	background: var(--xw-glass);
	-webkit-backdrop-filter: blur(14px);
	backdrop-filter: blur(14px);
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	transition: color .3s var(--xw-ease), border-color .3s var(--xw-ease), box-shadow .3s var(--xw-ease), transform .3s var(--xw-ease);
}

.xw-pagination a.page-numbers:hover,
.xw-pagination a.page-numbers:focus-visible {
	color: var(--xw-accent);
	border-color: var(--xw-accent);
	box-shadow: var(--xw-glow-cyan);
	transform: translateY(-2px);
}

.xw-pagination .page-numbers.current {
	background: var(--xw-gradient);
	color: var(--xw-bg);
	border-color: transparent;
	box-shadow: var(--xw-glow-cyan);
}

.xw-pagination .page-numbers.dots {
	background: transparent;
	border-color: transparent;
	-webkit-backdrop-filter: none;
	backdrop-filter: none;
}

/* Post navigation (prev/next single post) */
.post-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
}

/* =========================================================================
   18. WORDPRESS CORE CLASSES
   ========================================================================= */

.alignleft {
	float: left;
	margin: .5em 1.5em 1.5em 0;
}

.alignright {
	float: right;
	margin: .5em 0 1.5em 1.5em;
}

.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
	clear: both;
}

.alignwide {
	margin-left: calc(50% - min(50vw, 640px) + 1rem);
	margin-right: calc(50% - min(50vw, 640px) + 1rem);
	max-width: none;
	width: auto;
}

.alignfull {
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: 100vw;
	width: auto;
}

.wp-caption {
	max-width: 100%;
	background: var(--xw-glass);
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	padding: .5rem;
}

.wp-caption img {
	border-radius: calc(var(--xw-radius-sm) - 3px);
}

.wp-caption-text,
.wp-caption .wp-caption-text,
figcaption {
	font-size: .8125rem;
	color: var(--xw-text-soft);
	text-align: center;
	padding: .6em .5em .2em;
}

.gallery {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.gallery-columns-2 { grid-template-columns: repeat(2, 1fr); }
.gallery-columns-4 { grid-template-columns: repeat(4, 1fr); }
.gallery-columns-5 { grid-template-columns: repeat(5, 1fr); }

.gallery-item img {
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius-sm);
	transition: border-color .3s var(--xw-ease), box-shadow .3s var(--xw-ease);
}

.gallery-item img:hover {
	border-color: rgba(0, 245, 255, .5);
	box-shadow: var(--xw-glow-cyan);
}

.sticky {
	/* Required WP class — styling handled by post card border */
	border-color: rgba(0, 245, 255, .4);
}

.bypostauthor {
	/* Required WP class */
	display: block;
}

/* Comments baseline */
.comment-list {
	list-style: none;
	padding: 0;
}

.comment-body {
	background: var(--xw-glass);
	border: 1px solid var(--xw-border);
	border-radius: var(--xw-radius);
	padding: 1.5rem;
	margin-bottom: 1.25rem;
}

.comment-list .children {
	list-style: none;
	padding-left: clamp(1rem, 4vw, 2.5rem);
}

.comment-metadata,
.comment-metadata a {
	font-size: .8125rem;
	color: var(--xw-text-soft);
}

.comment-author .fn {
	font-family: var(--xw-font-heading);
	font-weight: 600;
	font-style: normal;
	color: var(--xw-text);
}

.comment-reply-link {
	font-family: var(--xw-font-heading);
	font-size: .8125rem;
	font-weight: 600;
	letter-spacing: .08em;
	text-transform: uppercase;
}

/* =========================================================================
   19. GLOBAL DECOR UTILITIES
   ========================================================================= */

/* Ambient glow orb — positioned per-section, drifted by animations.js */
.xw-glow-orb {
	position: absolute;
	width: 420px;
	height: 420px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(0, 245, 255, .12), transparent 70%);
	filter: blur(50px);
	pointer-events: none;
	z-index: 0;
}

.xw-glow-orb--violet {
	background: radial-gradient(circle, rgba(191, 95, 255, .12), transparent 70%);
}

/* Text reveal — lines masked until animations.js reveals them */
[data-xw-text-reveal] .xw-line {
	display: block;
	overflow: hidden;
}

[data-xw-text-reveal] .xw-line__inner {
	display: block;
	will-change: transform;
}

/* Ensure main content sits above decorative layers */
#primary {
	position: relative;
	z-index: 1;
}

/* =========================================================================
   20. REDUCED MOTION
   ========================================================================= */

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	*,
	*::before,
	*::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
		scroll-behavior: auto !important;
	}

	.xw-cursor,
	.xw-cursor-dot {
		display: none !important;
	}

	body.xw-has-animations,
	body.xw-has-animations a,
	body.xw-has-animations button {
		cursor: auto;
	}

	.xw-footer__border {
		animation: none;
		background-size: 100% 100%;
	}
}
