/*!
Theme Name: PROSPEX Consulting
Theme URI: https://prospexconsulting.hu
Author: Molnár Dávid
Description: Elegáns, egyoldalas, kétnyelvű (HU/EN) bemutatkozó téma építőipari projektmenedzsment és vasbeton szerkezetek területére. Sötét, prémium megjelenés, animált slider és scroll-animációk, optimalizált képek.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: prospex
*/

/* ===================================================================
   1. Design tokens
   =================================================================== */
:root {
	--bg:            #111729;   /* navy (brand) – RGB 17 23 41 */
	--bg-2:          #0b1020;   /* deeper – footer / inputs */
	--surface:       #161f38;   /* cards */
	--surface-2:     #1c274480; /* raised / hover */
	--line:          rgba(255,255,255,.09);
	--line-strong:   rgba(255,255,255,.18);

	--text:          #e9edf6;
	--text-read:     #d3dcee;   /* long-form body copy – brighter than soft for legibility */
	--text-soft:     #b2bcd4;
	--text-mut:      #7e8aa8;

	--accent:        #3d7b42;   /* brand green – RGB 61 123 66 */
	--accent-2:      #71b777;   /* brighter highlight – green text on dark bg */
	--accent-deep:   #2c5a31;   /* deeper green – button hover / depth */
	--accent-ink:    #f4faf5;   /* text on accent fills (light on dark green) */
	--accent-glow:   rgba(61,123,66,.30);

	--font-display:  'Cormorant Garamond', Georgia, 'Times New Roman', serif;
	--font-sans:     'Jost', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;

	--r-sm: 8px;
	--r:    14px;
	--r-lg: 22px;

	--container: 1200px;
	--header-h: 84px;
	--trp-ald-h: 0px;   /* height of the TranslatePress language-detection bar (set by JS) */

	--shadow:    0 26px 60px -28px rgba(0,0,0,.7);
	--shadow-sm: 0 12px 30px -16px rgba(0,0,0,.6);

	--ease: cubic-bezier(.22,.7,.2,1);
}

/* ===================================================================
   2. Reset & base
   =================================================================== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
	background: var(--bg);
	color: var(--text);
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}

body.px-noscroll { overflow: hidden; }

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

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
ul { list-style: none; padding: 0; }

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

section[id] { scroll-margin-top: calc(var(--header-h) + var(--trp-ald-h, 0px)); }

::selection { background: var(--accent); color: var(--accent-ink); }

/* ===================================================================
   3. Layout utilities
   =================================================================== */
.px-container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: clamp(20px, 5vw, 48px);
}

.px-section { padding-block: clamp(72px, 10vw, 140px); position: relative; }

.px-section__head { max-width: 720px; margin-bottom: clamp(40px, 5vw, 64px); }
.px-section__title {
	font-family: var(--font-display);
	font-weight: 500;
	line-height: 1.08;
	letter-spacing: .005em;
	font-size: clamp(2rem, 1.2rem + 3.4vw, 3.4rem);
	color: var(--text);
	margin-top: .35em;
}
.px-section__intro {
	color: var(--text-soft);
	font-size: clamp(1rem, .96rem + .3vw, 1.18rem);
	max-width: 60ch;
	margin-top: 1.1rem;
}

.px-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .7em;
	font-size: clamp(.7rem, .67rem + .16vw, .78rem);
	font-weight: 500;
	letter-spacing: .26em;
	text-transform: uppercase;
	color: var(--accent);
}
.px-eyebrow::before {
	content: "";
	width: 2.4em;
	height: 1px;
	background: linear-gradient(90deg, var(--accent), transparent);
}

/* Buttons */
.px-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .6em;
	padding: .95em 1.7em;
	font-size: clamp(.72rem, .69rem + .14vw, .78rem);
	font-weight: 500;
	letter-spacing: .16em;
	text-transform: uppercase;
	border-radius: 6px;
	border: 1px solid transparent;
	transition: transform .35s var(--ease), background-color .3s, border-color .3s, color .3s, box-shadow .3s;
	white-space: nowrap;
}
.px-btn--primary { background: var(--accent); color: var(--accent-ink); box-shadow: 0 14px 30px -16px var(--accent-glow); }
.px-btn--primary:hover { background: var(--accent-deep); transform: translateY(-2px); box-shadow: 0 20px 40px -16px var(--accent-glow); }
.px-btn--ghost { border-color: var(--line-strong); color: var(--text); }
.px-btn--ghost:hover { border-color: var(--accent); color: var(--accent-2); background: rgba(61,123,66,.08); transform: translateY(-2px); }

/* Chips */
.px-chips { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.6rem; }
.px-chip {
	font-size: clamp(.7rem, .68rem + .12vw, .76rem);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--accent-2);
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	padding: .5em 1.1em;
}

/* Reveal animation */
[data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); will-change: opacity, transform; }
[data-reveal].is-in { opacity: 1; transform: none; }

/* ===================================================================
   4. Header / navigation
   =================================================================== */
.px-skip {
	position: fixed; top: -100px; left: 16px; z-index: 2000;
	background: var(--accent); color: var(--accent-ink);
	padding: .7em 1.2em; border-radius: 0 0 8px 8px; font-weight: 500;
	transition: top .25s;
}
.px-skip:focus { top: 0; }

.px-header {
	position: fixed; inset: 0 0 auto 0; z-index: 1000;
	transition: background-color .4s, box-shadow .4s, backdrop-filter .4s;
}
.px-header__inner {
	max-width: 1320px; margin-inline: auto;
	padding: 20px clamp(20px, 5vw, 48px);
	display: flex; align-items: center; justify-content: space-between; gap: 24px;
	transition: padding .4s var(--ease);
}
.px-header[data-state="top"] {
	background: rgba(16,22,41,.34);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.px-header[data-state="scrolled"] {
	background: rgba(11,16,30,.82);
	backdrop-filter: blur(16px) saturate(1.4);
	-webkit-backdrop-filter: blur(16px) saturate(1.4);
	border-bottom: 1px solid var(--line);
	box-shadow: 0 18px 40px -28px rgba(0,0,0,.8);
}
.px-header[data-state="scrolled"] .px-header__inner { padding-block: 12px; }

/* Brand */
.px-brand { display: inline-flex; align-items: center; gap: 13px; }
.px-brand__mark { color: var(--accent); width: 34px; flex: none; transition: transform .4s var(--ease); }
.px-header[data-state="scrolled"] .px-brand__mark { width: 30px; }
.px-brand:hover .px-brand__mark { transform: rotate(-3deg); }
.px-brand__text { display: flex; flex-direction: column; line-height: 1; }
.px-brand__name { font-size: clamp(.95rem, .92rem + .18vw, 1.05rem); font-weight: 500; letter-spacing: .3em; color: var(--text); }
.px-brand__sub { font-size: clamp(.54rem, .52rem + .08vw, .58rem); letter-spacing: .42em; color: var(--text-mut); margin-top: .42em; }
.px-brand--custom img { max-height: 52px; width: auto; }

/* Desktop nav */
.px-nav { display: flex; align-items: center; gap: clamp(16px, 2.2vw, 38px); }
.px-nav__link { position: relative; color: var(--text-soft); font-size: clamp(.9rem, .86rem + .2vw, .98rem); letter-spacing: .03em; padding: 6px 0; transition: color .3s; }
.px-nav__link::after {
	content: ""; position: absolute; left: 0; bottom: 0; height: 1.5px; width: 0;
	background: var(--accent); transition: width .35s var(--ease);
}
.px-nav__link:hover, .px-nav__link.is-active { color: var(--text); }
.px-nav__link:hover::after, .px-nav__link.is-active::after { width: 100%; }

.px-header__actions { display: flex; align-items: center; gap: clamp(12px, 1.6vw, 22px); }

/* Language switch */
.px-lang { display: inline-flex; align-items: center; gap: .35em; }
.px-lang__btn { font-size: clamp(.76rem, .73rem + .14vw, .82rem); letter-spacing: .08em; color: var(--text-mut); padding: .2em .15em; transition: color .3s; }
.px-lang__btn.is-active { color: var(--accent); font-weight: 500; }
.px-lang__btn:hover { color: var(--text); }
.px-lang__sep { color: var(--line-strong); font-size: clamp(.74rem, .72rem + .12vw, .8rem); }
/* We use our own header HU/EN switch; hide TranslatePress' built-in switcher/floater. */
.trp-language-switcher-container { display: none !important; }

/* Burger */
.px-burger { display: none; width: 44px; height: 44px; position: relative; }
.px-burger span {
	position: absolute; left: 11px; right: 11px; height: 1.5px; background: var(--text);
	transition: transform .3s var(--ease), opacity .25s; border-radius: 2px;
}
.px-burger span:nth-child(1) { top: 16px; }
.px-burger span:nth-child(2) { top: 21px; }
.px-burger span:nth-child(3) { top: 26px; }
.px-burger.is-open span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.px-burger.is-open span:nth-child(2) { opacity: 0; }
.px-burger.is-open span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

/* Mobile menu */
.px-mobilenav {
	position: fixed; inset: 0; z-index: 990;
	background: rgba(11,16,30,.96);
	backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
	opacity: 0; transform: translateY(-8px); pointer-events: none;
	transition: opacity .3s, transform .35s var(--ease);
	padding: var(--header-h) 24px 48px;
}
.px-mobilenav.is-open { opacity: 1; transform: none; pointer-events: auto; }
.px-mobilenav__list { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.px-mobilenav .px-nav__link { font-family: var(--font-display); font-size: clamp(1.6rem, 1.25rem + 1.7vw, 2rem); color: var(--text); padding: .35em 0; }
.px-mobilenav .px-nav__link::after { display: none; }
.px-mobilenav__cta { margin-top: 24px; }

/* ===================================================================
   5. Hero / slider
   =================================================================== */
.px-hero {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	display: flex;
	align-items: center;
	overflow: hidden;
	isolation: isolate;
}
.px-hero__slides { position: absolute; inset: 0; z-index: 0; }
.px-slide {
	position: absolute; inset: 0;
	opacity: 0; visibility: hidden;
	transition: opacity 1.1s ease, visibility 1.1s;
}
.px-slide.is-active { opacity: 1; visibility: visible; }
.px-slide__media { position: absolute; inset: 0; overflow: hidden; }
.px-slide__media picture { display: block; width: 100%; height: 100%; }
.px-slide__media img { display: block; width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); }
.px-slide.is-active .px-slide__media img { animation: pxKenburns 9s var(--ease) forwards; }
@keyframes pxKenburns { from { transform: scale(1.05); } to { transform: scale(1.14); } }

.px-hero__scrim {
	position: absolute; inset: 0; z-index: 1;
	/* Symmetric darkening: stronger top (header) and bottom (controls/CTA),
	   even left-to-right. Text legibility is handled by a subtle text-shadow. */
	background:
		linear-gradient(180deg, rgba(11,16,30,.58) 0%, rgba(11,16,30,.22) 30%, rgba(11,16,30,.34) 60%, rgba(11,16,30,.84) 100%),
		rgba(16,22,41,.20);
}

.px-hero__content { position: relative; z-index: 2; max-width: 760px; padding-block: 120px 160px; }
.px-hero__captions { display: grid; }
.px-hero__caption { grid-area: 1 / 1; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .6s ease; }
.px-hero__caption.is-active { opacity: 1; visibility: visible; pointer-events: auto; }
.px-hero__eyebrow { margin-bottom: 1.3rem; }
.px-hero__title {
	font-family: var(--font-display);
	font-weight: 500;
	line-height: 1.04;
	letter-spacing: .004em;
	font-size: clamp(2.4rem, 1.5rem + 4.2vw, 4.4rem);
	color: #fff;
	text-wrap: balance;
	text-shadow: 0 1px 2px rgba(8,12,24,.5), 0 2px 30px rgba(8,12,24,.62);
}
.px-hero__sub {
	margin-top: 1.4rem;
	font-size: clamp(1.05rem, 1rem + .5vw, 1.35rem);
	color: rgba(255,255,255,.92);
	max-width: 54ch;
	text-shadow: 0 1px 2px rgba(8,12,24,.6), 0 2px 20px rgba(8,12,24,.7);
}
.px-hero__eyebrow { text-shadow: 0 1px 10px rgba(8,12,24,.55); }
.px-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 2.4rem; }

.px-hero__caption.is-active .px-hero__eyebrow { animation: pxSwap .6s both; }
.px-hero__caption.is-active .px-hero__title   { animation: pxSwap .6s .05s both; }
.px-hero__caption.is-active .px-hero__sub     { animation: pxSwap .6s .1s both; }
@keyframes pxSwap { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

/* Hero controls */
.px-hero__controls {
	position: absolute; left: 50%; transform: translateX(-50%);
	bottom: clamp(24px, 4vw, 48px); z-index: 3;
	display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.px-dots { display: flex; align-items: center; gap: 14px; }
.px-dots__dot { width: 46px; height: 16px; display: flex; align-items: center; }
.px-dots__bar { display: block; width: 100%; height: 2px; background: rgba(255,255,255,.25); position: relative; overflow: hidden; border-radius: 2px; transition: background-color .3s; }
.px-dots__dot.is-active .px-dots__bar { background: rgba(255,255,255,.35); }
.px-dots__bar::after {
	content: ""; position: absolute; inset: 0; width: 100%; transform-origin: left; transform: scaleX(0);
	background: var(--accent);
}
.px-dots.is-playing .px-dots__dot.is-active .px-dots__bar::after { animation: pxDot 6.5s linear forwards; }
.px-dots__dot.is-active .px-dots__bar::after { transform: scaleX(1); }
@keyframes pxDot { from { transform: scaleX(0); } to { transform: scaleX(1); } }

.px-hero__arrows { display: flex; gap: 10px; }
.px-arrow {
	width: 48px; height: 48px; border: 1px solid var(--line-strong); border-radius: 50%;
	color: #fff; display: grid; place-items: center;
	transition: background-color .3s, border-color .3s, transform .3s;
}
.px-arrow svg { width: 20px; }
.px-arrow:hover { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); transform: translateY(-2px); }

.px-hero__scroll {
	position: absolute; left: 50%; transform: translateX(-50%); bottom: 14px; z-index: 2;
	display: none; flex-direction: column; align-items: center; gap: 4px;
	font-size: clamp(.6rem, .58rem + .1vw, .66rem); letter-spacing: .24em; text-transform: uppercase; color: var(--text-mut);
}
.px-hero__scroll svg { width: 20px; animation: pxBob 1.8s ease-in-out infinite; }
@keyframes pxBob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(5px); } }

/* ===================================================================
   6. About
   =================================================================== */
.px-about { padding-top: clamp(80px, 11vw, 150px); }
.px-about__grid { display: grid; grid-template-columns: 1fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
.px-about__media { position: relative; }
.px-about__frame { position: relative; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow); border: 1px solid var(--line); }
.px-about__frame img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.px-about__accent {
	position: absolute; inset: auto -12px -12px auto; width: 48%; height: 48%; z-index: -1;
	border: 1px solid var(--accent); border-radius: var(--r-lg); opacity: .35;
}
.px-about__p { color: var(--text-read); font-size: clamp(1.02rem, .98rem + .3vw, 1.18rem); margin-top: 1.1rem; max-width: 62ch; }
.px-about__rte { max-width: 62ch; }
.px-about__rte p { color: var(--text-read); font-size: clamp(1.02rem, .98rem + .3vw, 1.18rem); margin-top: 1.1rem; }
.px-about__rte p:first-child { margin-top: 0; }
.px-about__rte strong { color: var(--text); font-weight: 500; }
.px-about__body .px-eyebrow { margin-bottom: .2rem; }
/* Tame the section title in the narrower About column + add breathing room. */
.px-about__body .px-section__title { font-size: clamp(1.8rem, 1.2rem + 1.9vw, 2.6rem); line-height: 1.14; margin-bottom: 1.5rem; }

/* Stats */
.px-stats {
	display: grid; grid-template-columns: 1fr; gap: clamp(28px, 4vw, 48px);
	margin-top: clamp(48px, 6vw, 80px); padding-top: clamp(40px, 5vw, 60px);
	border-top: 1px solid var(--line);
}
.px-stat { text-align: left; }
.px-stat__num {
	display: block; font-family: var(--font-display); font-weight: 600;
	font-size: clamp(2.8rem, 1.8rem + 4vw, 4.6rem); line-height: 1; color: var(--accent-2);
	font-variant-numeric: tabular-nums;
}
.px-stat__label { display: block; margin-top: .6rem; color: var(--text-soft); font-size: .95rem; max-width: 24ch; }

/* ===================================================================
   7. Services
   =================================================================== */
.px-grid { display: grid; gap: clamp(18px, 2vw, 26px); }
.px-grid--services { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 640px) { .px-grid--services { grid-template-columns: 1fr; } }

/* Halvány "tervrajz" háttér: a DJI vázszerkezet-fotó élkereséssel világoskék
   vonalrajzzá alakítva (lásd tools/make-blueprint.py). Tisztán dekoratív –
   a kártyák átlátszatlanul ülnek fölötte, a szöveg olvashatósága nem romlik.
   Erősség: az opacity hangolja. */
.px-services { isolation: isolate; }
.px-services::before {
	content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
	background: url(assets/img/blueprint-services-1600.webp) center / cover no-repeat;
	opacity: .2;
	-webkit-mask-image: linear-gradient(180deg, transparent 0, #000 16%, #000 84%, transparent 100%);
	        mask-image: linear-gradient(180deg, transparent 0, #000 16%, #000 84%, transparent 100%);
}
@media (max-width: 640px) { .px-services::before { opacity: .13; } }

.px-card {
	position: relative; background: var(--surface); border: 1px solid var(--line);
	border-radius: var(--r); padding: clamp(26px, 3vw, 36px); overflow: hidden;
	transition: transform .4s var(--ease), border-color .4s, background-color .4s, box-shadow .4s;
}
.px-card::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
	background: linear-gradient(90deg, transparent, var(--accent) 25%, var(--accent-2) 75%, transparent);
	transform: scaleX(0); transform-origin: center; transition: transform .55s var(--ease);
}
.px-card:hover { transform: translateY(-6px); border-color: var(--line-strong); background: #18213c; box-shadow: var(--shadow-sm); }
.px-card:hover::before { transform: scaleX(1); }
.px-card__icon {
	width: 56px; height: 56px; border-radius: 12px; display: grid; place-items: center;
	color: var(--accent-2); background: rgba(61,123,66,.1); border: 1px solid var(--line);
	margin-bottom: 1.4rem;
	transition: background-color .55s var(--ease), border-color .55s var(--ease);
}
.px-card:hover .px-card__icon { background: var(--accent-glow); border-color: var(--accent-deep); }
.px-card__icon svg { width: 28px; }
.px-card__title { font-family: var(--font-display); font-weight: 500; font-size: clamp(1.25rem, 1.08rem + .8vw, 1.5rem); line-height: 1.15; color: var(--text); }
.px-card__desc { color: var(--text-soft); font-size: clamp(.9rem, .87rem + .18vw, .96rem); margin-top: .8rem; }

/* Services: ikon a szöveg mellett (vízszintes elrendezés) nagy képernyőn;
   az ikon átfogja a cím + leírás magasságát, a tetejükhöz igazítva. */
.px-card--service { display: grid; grid-template-columns: auto 1fr; align-items: start; column-gap: clamp(18px, 2vw, 24px); }
.px-card--service .px-card__icon { grid-row: 1 / 3; margin-bottom: 0; }
.px-card--service .px-card__title,
.px-card--service .px-card__desc { grid-column: 2; }
@media (max-width: 640px) {
	.px-card--service { display: block; }
	.px-card--service .px-card__icon { margin-bottom: 1.4rem; }
}

/* Services: refined, sequential card entrance (animation-driven so the
   stagger delay never leaks into the hover transition). */
.px-card--service[data-reveal] { opacity: 0; transform: none; filter: none; transition-delay: 0ms !important; }
.px-card--service[data-reveal].is-in {
	opacity: 1;
	animation: pxCardIn 1.25s var(--ease) backwards;
	animation-delay: var(--reveal-delay, 0ms);
}
@keyframes pxCardIn {
	0%   { opacity: 0; transform: translateY(48px) scale(.95); filter: blur(10px); }
	60%  { filter: blur(0); }
	100% { opacity: 1; transform: none; filter: blur(0); }
}

/* ===================================================================
   8. Projects — feature carousel (one project at a time, image-led)
   =================================================================== */
/* --projcar-out: how long the OUTGOING slide takes to fade out.
   --projcar-in:  how long the INCOMING slide takes to fade in (50% faster than
                  the previous 1.4s, i.e. 1.4s / 1.5 ≈ .93s).
   --projcar-in-delay: when the incoming slide starts — 0.5s before the out
                  finishes, so in/out briefly overlap and there is no dead gap. */
.px-projcar {
	position: relative;
	--projcar-out: 1s;
	--projcar-in: calc(1.4s / 1.5);
	--projcar-in-delay: calc(var(--projcar-out) - .5s);
}

/* Soft accent wash for the whole Projects section (full-bleed), lifted up to the
   section so it spans the full width instead of being boxed to the container.
   The container content is raised above it via z-index. */
.px-projects { isolation: isolate; }
.px-projects__wash {
	position: absolute; inset: 0; z-index: 0; pointer-events: none;
	background: radial-gradient(60% 70% at 78% 50%, var(--accent-glow), transparent 72%);
	opacity: .45;
}
.px-projects > .px-container { position: relative; z-index: 1; }

/* All slides share one grid cell, so the viewport is as tall as the tallest
   slide and never jumps when switching. Inactive slides cross-fade out. */
.px-projcar__viewport { position: relative; z-index: 1; display: grid; }
.px-projcar__slide {
	grid-area: 1 / 1; display: grid; grid-template-columns: 1fr;
	gap: clamp(28px, 4vw, 56px); align-items: center;
	opacity: 0; visibility: hidden; pointer-events: none;
	/* Near-sequential hand-off. The OUTGOING slide fades out over --projcar-out
	   (visibility held until then so it isn't clipped away). The INCOMING slide
	   (active rule below) holds its fade-in back by --projcar-in-delay and stays
	   hidden until then, so it only starts near the end of the outgoing fade
	   (a small overlap, no dead gap). */
	transition: opacity var(--projcar-out) var(--ease), visibility 0s var(--projcar-out);
}
.px-projcar__slide.is-active {
	opacity: 1; visibility: visible; pointer-events: auto;
	transition: opacity var(--projcar-in) var(--ease) var(--projcar-in-delay), visibility 0s var(--projcar-in-delay);
}

/* Text panel */
.px-projcar__panel { min-width: 0; display: flex; flex-direction: column; align-items: flex-start; }
.px-projcar__num {
	display: flex; align-items: center; gap: 14px;
	font-size: .78rem; letter-spacing: .22em; text-transform: uppercase;
	color: var(--text-mut); font-variant-numeric: tabular-nums;
}
.px-projcar__numline { display: block; width: 42px; height: 1px; background: var(--accent); opacity: .85; }
.px-projcar__numtot { opacity: .7; }
.px-projcar__title {
	font-family: var(--font-display); font-weight: 500; line-height: 1.05;
	font-size: clamp(2rem, 1.3rem + 2.6vw, 3.2rem); color: var(--text);
	margin-top: 1.1rem; text-wrap: balance;
}
.px-projcar__meta {
	margin-top: .9rem; font-size: clamp(.82rem, .78rem + .2vw, .96rem);
	letter-spacing: .08em; color: var(--accent-2); font-variant-numeric: tabular-nums;
}
.px-projcar__desc {
	margin-top: 1.3rem; color: var(--text-read);
	font-size: clamp(.95rem, .9rem + .25vw, 1.08rem); line-height: 1.7; max-width: 48ch;
}
.px-projcar__tags {
	align-self: stretch; margin-top: 1.6rem; padding-top: 1.2rem; border-top: 1px solid var(--line);
	font-size: clamp(.68rem, .66rem + .1vw, .74rem); letter-spacing: .16em; text-transform: uppercase; color: var(--accent);
}

/* Swap motion for the slide's text. Driven by state TRANSITIONS (not entry-only
   animations) so the exact same motion plays in reverse on exit: the outgoing
   lines slide back down while the slide cross-fades out, mirroring the entry.
   Opacity is owned by the slide's cross-fade; here we only move the lines.
   Entry is staggered AND held back by --projcar-in-delay, so the incoming lines
   slide up near the end of the outgoing fade; exit reverts to the base 0s delay,
   so the leaving text glides out immediately as the slide fades. */
.px-projcar__num,
.px-projcar__title,
.px-projcar__meta,
.px-projcar__desc,
.px-projcar__tags { transform: translateY(16px); transition: transform .7s var(--ease); }
.px-projcar__slide.is-active .px-projcar__num   { transform: none; transition-delay: var(--projcar-in-delay); }
.px-projcar__slide.is-active .px-projcar__title { transform: none; transition-delay: calc(var(--projcar-in-delay) + .06s); }
.px-projcar__slide.is-active .px-projcar__meta  { transform: none; transition-delay: calc(var(--projcar-in-delay) + .1s); }
.px-projcar__slide.is-active .px-projcar__desc  { transform: none; transition-delay: calc(var(--projcar-in-delay) + .14s); }
.px-projcar__slide.is-active .px-projcar__tags  { transform: none; transition-delay: calc(var(--projcar-in-delay) + .18s); }

/* Figure — the dominant element. .px-proj__open / __media / __zoom names are
   kept so the existing lightbox JS (querySelectorAll('.px-proj__open')) binds. */
.px-projcar__figure { position: relative; min-width: 0; }
.px-proj__open {
	display: block; width: 100%; position: relative; overflow: hidden; cursor: zoom-in;
	aspect-ratio: 16 / 11; border-radius: var(--r); border: 1px solid var(--line);
	background: var(--surface); box-shadow: var(--shadow);
}
/* The swap scale lives on the media WRAPPER (not the <img>) so it can carry its
   own delayed transition without clashing with the img's instant hover zoom. */
.px-proj__media { position: absolute; inset: 0; transform: scale(.92); transition: transform var(--projcar-out) var(--ease); }
.px-proj__media picture { display: block; width: 100%; height: 100%; }
.px-proj__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .9s var(--ease); }
/* Blink swap: the image shrinks back as its slide fades out, and the incoming
   image grows from that same smaller size — but the grow is held back by
   transition-delay so it only starts after the OUTGOING slide has finished
   fading out (sequential hand-off). The hover zoom on the inner <img> stays
   instant, unaffected by that delay. */
.px-projcar__slide.is-active .px-proj__media { transform: scale(1); transition: transform var(--projcar-in) var(--ease) var(--projcar-in-delay); }
.px-projcar__figure:hover .px-proj__media img { transform: scale(1.05); }
.px-proj__open::after {
	content: ""; position: absolute; inset: 0; pointer-events: none; transition: opacity .4s; opacity: .85;
	background:
		linear-gradient(135deg, var(--accent-glow) 0%, transparent 46%),
		linear-gradient(0deg, rgba(11,16,30,.5), rgba(11,16,30,0) 55%);
}
.px-proj__open:hover::after { opacity: .55; }
.px-proj__zoom {
	position: absolute; top: 16px; right: 16px; z-index: 1;
	width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center;
	background: rgba(11,16,30,.55); color: #fff; border: 1px solid var(--line-strong);
	opacity: 0; transform: scale(.85); transition: opacity .35s, transform .35s var(--ease);
	backdrop-filter: blur(4px);
}
.px-proj__zoom svg { width: 20px; }
.px-proj__open:hover .px-proj__zoom, .px-proj__open:focus-visible .px-proj__zoom { opacity: 1; transform: scale(1); }

/* Decorative frame corners (accent). */
.px-projcar__corner { position: absolute; width: 34px; height: 34px; z-index: 2; pointer-events: none; }
.px-projcar__corner--tl { top: -7px; left: -7px; border-top: 2px solid var(--accent); border-left: 2px solid var(--accent); border-top-left-radius: 8px; }
.px-projcar__corner--br { bottom: -7px; right: -7px; border-bottom: 2px solid var(--accent); border-right: 2px solid var(--accent); border-bottom-right-radius: 8px; }

/* Controls: progress bars (one per project) + arrows */
.px-projcar__controls {
	position: relative; z-index: 1; margin-top: clamp(28px, 4vw, 48px);
	display: flex; align-items: flex-end; justify-content: space-between; gap: 28px; flex-wrap: wrap;
}
.px-projcar__dots { display: flex; align-items: flex-start; gap: 12px; flex: 1 1 320px; min-width: 0; flex-wrap: wrap; }
.px-projcar__dot {
	flex: 1 1 90px; min-width: 0; max-width: 220px;
	display: flex; flex-direction: column; gap: 10px; text-align: left;
	opacity: .55; transition: opacity .3s;
}
.px-projcar__dot:hover, .px-projcar__dot.is-active { opacity: 1; }
.px-projcar__track { display: block; width: 100%; height: 2px; background: rgba(255,255,255,.18); position: relative; overflow: hidden; border-radius: 2px; }
.px-projcar__fill { position: absolute; inset: 0; transform-origin: left; transform: scaleX(0); background: var(--accent); }
.px-projcar__dot.is-active .px-projcar__fill { transform: scaleX(1); }
/* While autoplaying, the active bar fills over the slide duration (kept in
   sync with DURATION in main.js — 6s). */
.px-projcar.is-playing .px-projcar__dot.is-active .px-projcar__fill { transform: scaleX(0); animation: pxProjcar 6s linear forwards; }
@keyframes pxProjcar { from { transform: scaleX(0); } to { transform: scaleX(1); } }
.px-projcar__dotlabel {
	font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-soft);
	max-width: 100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.px-projcar__dot.is-active .px-projcar__dotlabel { color: var(--text); }
.px-projcar__arrows { display: flex; gap: 10px; flex-shrink: 0; }

/* Desktop split: the figure gets the larger share so the image dominates. */
@media (min-width: 900px) {
	.px-projcar__slide { grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr); }
}
@media (max-width: 899px) {
	.px-projcar__figure { order: -1; }   /* image leads on the stacked layout */
}
@media (max-width: 600px) {
	.px-projcar__dotlabel { display: none; }
	.px-projcar__dot { flex-basis: 0; }
}

/* ===================================================================
   9. Contact + form
   =================================================================== */
.px-contact { background:
	radial-gradient(120% 80% at 100% 0%, rgba(61,123,66,.07), transparent 60%),
	var(--bg);
}
.px-contact__grid { display: grid; grid-template-columns: 1fr; gap: clamp(40px, 5vw, 72px); align-items: start; }
.px-contact__list { margin-top: 2.4rem; display: grid; gap: 1.5rem; }
.px-contact__item { display: flex; align-items: flex-start; gap: 16px; }
.px-contact__ico { flex: none; width: 46px; height: 46px; border-radius: 10px; display: grid; place-items: center; color: var(--accent-2); background: rgba(61,123,66,.1); border: 1px solid var(--line); transition: background-color .55s var(--ease), border-color .55s var(--ease); }
/* Ikon-kiemelés a tételre húzva — ugyanaz mint a szolgáltatás-kártya .px-card__icon hovere. */
.px-contact__item:hover .px-contact__ico { background: var(--accent-glow); border-color: var(--accent-deep); }
.px-contact__ico svg { width: 22px; }
.px-contact__text { display: flex; flex-direction: column; }
.px-contact__label { font-size: clamp(.66rem, .64rem + .1vw, .72rem); letter-spacing: .16em; text-transform: uppercase; color: var(--text-mut); }
.px-contact__value { color: var(--text); font-size: clamp(.98rem, .94rem + .22vw, 1.06rem); margin-top: .15em; transition: color .3s; }
a.px-contact__value:hover { color: var(--accent-2); }

/* Az űrlap-doboz ugyanazt a hover-effektet kapja, mint a .px-card--service kártyák:
   felső akcentus-vonal besöprés, erősebb keret, mélyebb háttér, finom megemelés.
   Az opacity .8s a transitionben marad, hogy a [data-reveal] beúszó-fade ne sérüljön. */
.px-contact__formwrap {
	position: relative; overflow: hidden;
	background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
	padding: clamp(26px, 3.4vw, 44px); box-shadow: var(--shadow-sm);
	transition: opacity .8s var(--ease), transform .4s var(--ease), border-color .4s, background-color .4s, box-shadow .4s;
}
.px-contact__formwrap::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
	background: linear-gradient(90deg, transparent, var(--accent) 25%, var(--accent-2) 75%, transparent);
	transform: scaleX(0); transform-origin: center; transition: transform .55s var(--ease);
}
.px-contact__formwrap:hover { transform: translateY(-6px); border-color: var(--line-strong); background: #18213c; box-shadow: var(--shadow-sm); }
.px-contact__formwrap:hover::before { transform: scaleX(1); }

.px-form { display: grid; gap: 1.2rem; }
.px-form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.px-field { display: grid; gap: .5rem; }
.px-field label { font-size: clamp(.7rem, .68rem + .12vw, .76rem); letter-spacing: .12em; text-transform: uppercase; color: var(--text-soft); }
.px-req { color: var(--accent-2); }
.px-opt { color: var(--text-mut); letter-spacing: .04em; text-transform: none; font-size: clamp(.66rem, .64rem + .1vw, .72rem); }
.px-field input, .px-field textarea {
	width: 100%; background: var(--bg-2); color: var(--text);
	border: 1px solid var(--line-strong); border-radius: var(--r-sm);
	padding: .85em 1em; font-size: 1rem; font-family: inherit;
	transition: border-color .3s, box-shadow .3s, background-color .3s;
	min-height: 48px;
}
.px-field textarea { resize: vertical; min-height: 130px; }
.px-field input::placeholder, .px-field textarea::placeholder { color: var(--text-mut); }
.px-field input:focus, .px-field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(61,123,66,.18); background: #0e1426; }

.px-form__submit { margin-top: .4rem; position: relative; }
.px-form__submit.is-loading { opacity: .85; }
.px-form__spinner { width: 16px; height: 16px; border: 2px solid rgba(8,19,13,.35); border-top-color: var(--accent-ink); border-radius: 50%; display: none; }
.px-form__submit.is-loading .px-form__spinner { display: inline-block; animation: pxSpin .7s linear infinite; }
@keyframes pxSpin { to { transform: rotate(360deg); } }
.px-form__consent { font-size: clamp(.74rem, .72rem + .12vw, .8rem); color: var(--text-mut); margin-top: .2rem; }

.px-alert { border-radius: var(--r-sm); padding: 1em 1.2em; margin-bottom: 1.4rem; font-size: clamp(.88rem, .85rem + .18vw, .95rem); border: 1px solid; }
.px-alert--ok { color: #cfeede; background: rgba(61,123,66,.12); border-color: rgba(61,123,66,.5); }
.px-alert--error { color: #ffd6d6; background: rgba(220,90,90,.12); border-color: rgba(220,90,90,.5); }

/* ---- Fluent Forms, themed to match the dark contact card ---- */
.px-contact__formwrap .fluentform { margin: 0; }
.px-contact__formwrap .fluentform .ff-el-group { margin-bottom: 1.2rem; }
.px-contact__formwrap .fluentform .ff-el-input--label label,
.px-contact__formwrap .fluentform .ff-el-input--label { font-size: clamp(.7rem, .68rem + .12vw, .76rem); letter-spacing: .12em; text-transform: uppercase; color: var(--text-soft); margin-bottom: .5rem; font-weight: 500; }
.px-contact__formwrap .fluentform .ff-el-is-required > label::after,
.px-contact__formwrap .fluentform label .ff-el-is-required,
.px-contact__formwrap .fluentform .ff-el-is-required { color: var(--accent-2); }
.px-contact__formwrap .fluentform input.ff-el-form-control,
.px-contact__formwrap .fluentform textarea.ff-el-form-control,
.px-contact__formwrap .fluentform select.ff-el-form-control {
	width: 100%; background: var(--bg-2); color: var(--text);
	border: 1px solid var(--line-strong); border-radius: var(--r-sm);
	padding: .85em 1em; font-size: 1rem; min-height: 48px; font-family: inherit; box-shadow: none;
	transition: border-color .3s, box-shadow .3s, background-color .3s;
}
.px-contact__formwrap .fluentform textarea.ff-el-form-control { min-height: 130px; }
.px-contact__formwrap .fluentform .ff-el-form-control::placeholder { color: var(--text-mut); }
.px-contact__formwrap .fluentform .ff-el-form-control:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(61,123,66,.18); background: #0e1426; }
.px-contact__formwrap .fluentform .ff-btn-submit {
	background: var(--accent) !important; color: var(--accent-ink) !important;
	border: none !important; border-radius: 6px !important;
	padding: .95em 1.7em !important; font-size: clamp(.72rem, .69rem + .14vw, .78rem) !important; font-weight: 500 !important;
	letter-spacing: .16em; text-transform: uppercase; cursor: pointer;
	transition: transform .35s var(--ease), background-color .3s, box-shadow .3s;
	box-shadow: 0 14px 30px -16px var(--accent-glow);
}
.px-contact__formwrap .fluentform .ff-btn-submit:hover { background: var(--accent-deep) !important; transform: translateY(-2px); }
.px-contact__formwrap .fluentform .text-danger,
.px-contact__formwrap .fluentform .error-text,
.px-contact__formwrap .fluentform .ff-el-is-error .text-danger { color: #ffb3b3; font-size: clamp(.8rem, .78rem + .12vw, .85rem); margin-top: .35rem; }
.px-contact__formwrap .fluentform input.ff-el-is-error,
.px-contact__formwrap .fluentform textarea.ff-el-is-error { border-color: rgba(220,90,90,.6); }
.px-contact__formwrap .ff-message-success {
	color: #cfeede; background: rgba(61,123,66,.12);
	border: 1px solid rgba(61,123,66,.5); border-radius: var(--r-sm); padding: 1em 1.2em;
}

/* ===================================================================
   10. Lightbox
   =================================================================== */
.px-lightbox {
	position: fixed; inset: 0; z-index: 2000; display: flex; align-items: center; justify-content: center;
	padding: clamp(20px, 5vw, 60px);
	background: rgba(7,11,20,.93); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
	opacity: 0; pointer-events: none; transition: opacity .3s;
}
.px-lightbox[hidden] { display: none; }
.px-lightbox.is-open { opacity: 1; pointer-events: auto; }
.px-lightbox__figure { max-width: min(1100px, 92vw); display: flex; flex-direction: column; gap: 1rem; }
.px-lightbox__img { width: 100%; max-height: 80vh; object-fit: contain; border-radius: var(--r); box-shadow: var(--shadow); opacity: 0; transition: opacity .25s ease; }
.px-lightbox__img.is-ready { opacity: 1; }
.px-lightbox__cap { text-align: center; color: var(--text-soft); font-family: var(--font-display); font-size: clamp(1.1rem, 1rem + .45vw, 1.3rem); }
.px-lightbox__close {
	position: absolute; top: clamp(16px, 3vw, 32px); right: clamp(16px, 3vw, 32px);
	width: 50px; height: 50px; border-radius: 50%; border: 1px solid var(--line-strong); color: #fff;
	display: grid; place-items: center; transition: background-color .3s, transform .3s; z-index: 2;
}
.px-lightbox__close:hover { background: var(--accent); color: var(--accent-ink); transform: rotate(90deg); }
.px-lightbox__close svg { width: 22px; }
.px-lightbox__nav {
	position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
	width: clamp(46px, 4vw, 54px); height: clamp(46px, 4vw, 54px); border-radius: 50%;
	border: 1px solid var(--line-strong); color: #fff; display: grid; place-items: center;
	background: rgba(16,22,41,.5); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
	transition: background-color .3s, color .3s, transform .3s;
}
.px-lightbox__nav[hidden] { display: none; }
.px-lightbox__nav svg { width: 24px; }
.px-lightbox__nav--prev { left: clamp(10px, 3vw, 32px); }
.px-lightbox__nav--next { right: clamp(10px, 3vw, 32px); }
.px-lightbox__nav:hover { background: var(--accent); color: var(--accent-ink); }
.px-lightbox__nav--prev:hover { transform: translateY(-50%) translateX(-3px); }
.px-lightbox__nav--next:hover { transform: translateY(-50%) translateX(3px); }

/* ===================================================================
   11. Footer + back to top
   =================================================================== */
.px-footer { background: var(--bg-2); border-top: 1px solid var(--line); padding-top: clamp(48px, 6vw, 80px); }
.px-footer__grid { display: grid; grid-template-columns: 1fr; gap: clamp(32px, 4vw, 56px); padding-bottom: clamp(36px, 4vw, 56px); }
.px-brand--footer .px-brand__mark { width: 38px; color: var(--accent); }
.px-footer__tagline { color: var(--text-soft); margin-top: 1.2rem; max-width: 38ch; font-size: clamp(.9rem, .87rem + .18vw, .96rem); }
.px-footer__col { display: flex; flex-direction: column; gap: .7rem; }
.px-footer__title { font-size: clamp(.72rem, .7rem + .1vw, .78rem); letter-spacing: .16em; text-transform: uppercase; color: var(--text-mut); margin-bottom: .4rem; font-weight: 500; }
.px-footer__col a { color: var(--text-soft); transition: color .3s; width: fit-content; }
.px-footer__col a:hover { color: var(--accent-2); }
.px-footer__nav { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .7rem; }
.px-footer__nav li { margin: 0; }
.px-footer__muted { color: var(--text-mut); font-size: clamp(.86rem, .83rem + .16vw, .92rem); }

.px-footer__bar {
	display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
	padding-block: 24px; border-top: 1px solid var(--line); margin-top: 8px;
}
.px-footer__copy { color: var(--text-mut); font-size: clamp(.8rem, .78rem + .14vw, .86rem); }

.px-totop {
	position: fixed; right: clamp(16px, 3vw, 32px); bottom: clamp(16px, 3vw, 32px); z-index: 900;
	width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--line-strong);
	background: rgba(11,16,30,.7); color: var(--accent-2); display: grid; place-items: center;
	opacity: 0; transform: translateY(12px); pointer-events: none;
	transition: opacity .35s, transform .35s var(--ease), background-color .3s;
	backdrop-filter: blur(6px);
}
.px-totop svg { width: 20px; }
.px-totop.is-visible { opacity: 1; transform: none; pointer-events: auto; }
.px-totop:hover { background: var(--accent); color: var(--accent-ink); }

/* ===================================================================
   11b. Inner pages (hero + title + content)
   =================================================================== */
.px-page-hero {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: clamp(300px, 44vh, 500px);
	padding-top: calc(var(--header-h) + var(--trp-ald-h, 0px) + clamp(40px, 8vw, 96px));
	padding-bottom: clamp(36px, 6vw, 76px);
	overflow: hidden;
	isolation: isolate;
	background:
		radial-gradient(130% 120% at 78% 0%, rgba(61,123,66,.12), transparent 60%),
		linear-gradient(180deg, var(--bg-2), var(--bg));
}
.px-page-hero__media { position: absolute; inset: 0; z-index: -2; }
.px-page-hero__media picture { display: block; width: 100%; height: 100%; }
.px-page-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.px-page-hero__scrim {
	position: absolute; inset: 0; z-index: -1;
	background:
		linear-gradient(180deg, rgba(11,16,30,.55) 0%, rgba(11,16,30,.30) 35%, rgba(11,16,30,.84) 100%),
		rgba(16,22,41,.20);
}
.px-page-hero__inner { position: relative; z-index: 1; max-width: 820px; }
.px-page-hero__eyebrow { margin-bottom: 1.1rem; }
.px-page-hero__title {
	font-family: var(--font-display);
	font-weight: 500;
	line-height: 1.06;
	letter-spacing: .004em;
	font-size: clamp(2.2rem, 1.4rem + 3.6vw, 3.8rem);
	color: #fff;
	text-wrap: balance;
}
.px-page-hero.has-image .px-page-hero__title {
	text-shadow: 0 1px 2px rgba(8,12,24,.5), 0 2px 30px rgba(8,12,24,.62);
}
.px-page-hero__sub {
	margin-top: 1.2rem;
	font-size: clamp(1.02rem, .98rem + .45vw, 1.3rem);
	color: rgba(255,255,255,.92);
	max-width: 56ch;
}
.px-page-hero.has-image .px-page-hero__sub {
	text-shadow: 0 1px 2px rgba(8,12,24,.6), 0 2px 20px rgba(8,12,24,.7);
}

.px-page-content { padding-top: clamp(48px, 7vw, 88px); }
.px-page-content__inner { max-width: 820px; }

/* Long-form prose rendered from the page editor (the_content). */
.px-prose { color: var(--text-read); font-size: clamp(1rem, .97rem + .3vw, 1.12rem); }
.px-prose > * + * { margin-top: 1.1em; }
.px-prose h2 {
	font-family: var(--font-display); font-weight: 500; color: var(--text);
	font-size: clamp(1.6rem, 1.2rem + 1.6vw, 2.3rem); line-height: 1.16;
	letter-spacing: .005em; margin-top: 1.8em;
}
.px-prose h3 {
	font-family: var(--font-display); font-weight: 600; color: var(--text);
	font-size: clamp(1.3rem, 1.1rem + .9vw, 1.7rem); line-height: 1.2; margin-top: 1.6em;
}
.px-prose h4 { font-weight: 600; color: var(--text); font-size: 1.1rem; margin-top: 1.4em; }
.px-prose a { color: var(--accent-2); text-decoration: underline; text-underline-offset: .18em; text-decoration-thickness: 1px; }
.px-prose a:hover { color: var(--accent); }
.px-prose strong, .px-prose b { color: var(--text); font-weight: 600; }
.px-prose ul, .px-prose ol { padding-left: 1.3em; }
.px-prose ul { list-style: disc; }
.px-prose ol { list-style: decimal; }
.px-prose li + li { margin-top: .4em; }
.px-prose li::marker { color: var(--accent); }
.px-prose blockquote {
	border-left: 2px solid var(--accent); padding-left: 1.1em; margin-left: 0;
	color: var(--text-soft); font-style: italic;
}
.px-prose img { border-radius: var(--r); margin-block: 1.4em; }
.px-prose hr { border: 0; border-top: 1px solid var(--line); margin-block: 2em; }
.px-prose :where(h2, h3, h4):first-child { margin-top: 0; }

/* ===================================================================
   12. Responsive
   =================================================================== */
@media (min-width: 700px) {
	.px-stats { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 900px) {
	.px-about__grid { grid-template-columns: 1fr 1.06fr; }
	.px-contact__grid { grid-template-columns: 1fr 1.05fr; }
	.px-footer__grid { grid-template-columns: 1.4fr 1fr 1fr; }
}
@media (max-width: 900px) {
	.px-nav, .px-header__cta { display: none; }
	.px-burger { display: block; }
	.px-hero__scroll { display: flex; }
}
@media (max-width: 600px) {
	.px-hero__controls { flex-direction: column-reverse; align-items: flex-start; gap: 16px; left: clamp(20px, 5vw, 48px); transform: none; }
	.px-hero__content { padding-block: 110px 200px; }
	.px-dots__dot { width: 36px; }
}

/* ===================================================================
   13. Reduced motion
   =================================================================== */
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
	.px-slide__media img { animation: none; transform: scale(1.03); }
	[data-reveal] { opacity: 1 !important; transform: none !important; }
	.px-hero__scroll svg { animation: none; }
}

/* ===================================================================
   14. TranslatePress — automatic language-detection bar
   Re-styled to match the theme and lifted above the fixed header so the
   menu no longer covers it. The fixed header is pushed down by the bar's
   measured height (--trp-ald-h, set in main.js).
   =================================================================== */

/* Push the fixed header (and its smooth slide) below the bar. */
.px-header {
	top: var(--trp-ald-h, 0px);
	transition: top .4s var(--ease), background-color .4s, box-shadow .4s, backdrop-filter .4s;
}

/* The bar itself: full-bleed, fixed, above the header (header z-index = 1000). */
#trp_no_text_popup_wrap {
	position: fixed !important;
	inset: 0 0 auto 0 !important;
	z-index: 1100 !important;
	background: rgba(11,16,30,.92) !important;
	backdrop-filter: blur(14px) saturate(1.35);
	-webkit-backdrop-filter: blur(14px) saturate(1.35);
	border-bottom: 1px solid var(--line);
	box-shadow: 0 16px 40px -28px rgba(0,0,0,.85);
	font-family: var(--font-sans);
}
/* Accent hairline along the very top edge. */
#trp_no_text_popup_wrap::before {
	content: "";
	position: absolute; inset: 0 0 auto 0; height: 2px;
	background: linear-gradient(90deg, transparent, var(--accent) 28%, var(--accent-2) 72%, transparent);
	opacity: .85;
}

/* Inner content row: constrained to the header's container, centered. */
#trp_no_text_popup.trp_ald_no_text_popup {
	display: flex; align-items: center; gap: clamp(12px, 2vw, 22px);
	max-width: 1320px; margin-inline: auto;
	padding: 10px clamp(20px, 5vw, 48px);
	background: transparent;
	position: relative;
	border: none;
}

#trp_ald_not_text_popup_ls_and_button {
	display: flex; align-items: center; justify-content: center;
	flex: 1 1 auto; flex-wrap: wrap;
	gap: clamp(10px, 1.6vw, 18px);
}

#trp_ald_no_text_popup_div { display: flex; align-items: center; }
#trp_ald_no_text_popup_text {
	color: var(--text-soft);
	font-size: clamp(.82rem, .8rem + .12vw, .9rem);
	letter-spacing: .01em; line-height: 1.4;
}

/* Re-enable the switcher inside the popup (we hide TP's switcher elsewhere). */
#trp_no_text_popup_wrap .trp-language-switcher-container { display: inline-block !important; }

#trp_no_text_popup_wrap .trp-flag-image {
	width: 18px; height: 14px; border-radius: 2px; flex: none;
}

#trp_ald_no_text_select { position: relative; }
#trp_ald_no_text_select .trp-ls-shortcode-current-language {
	display: inline-flex; align-items: center; gap: .5em;
	padding: .42em .85em;
	background: var(--bg-2); color: var(--text);
	border: 1px solid var(--line-strong); border-radius: 999px;
	font-size: clamp(.76rem, .74rem + .12vw, .84rem); white-space: nowrap; cursor: pointer;
	transition: border-color .3s, background-color .3s;
}
#trp_ald_no_text_select .trp-ls-shortcode-current-language:hover {
	border-color: var(--accent-deep); background: var(--surface);
}

/* Dropdown list (TP toggles its visibility on hover). */
#trp_no_text_popup_wrap .trp-ls-shortcode-language {
	background: var(--surface); border: 1px solid var(--line);
	border-radius: 12px; box-shadow: var(--shadow-sm);
	padding: 6px; margin-top: 8px; min-width: 168px; overflow: hidden; z-index: 5;
}
#trp_no_text_popup_wrap .trp-ald-popup-select {
	display: flex; align-items: center; gap: .55em;
	padding: .5em .7em; border-radius: 8px;
	color: var(--text-soft); font-size: .82rem; white-space: nowrap; cursor: pointer;
	transition: background-color .25s, color .25s;
}
#trp_no_text_popup_wrap .trp-ald-popup-select:hover {
	background: var(--surface-2); color: var(--text);
}

/* "Change Language" — accent pill, like the theme's primary button. */
#trp_ald_no_text_popup_change_language {
	display: inline-flex; align-items: center;
	padding: .52em 1.2em; border-radius: 999px;
	background: var(--accent); color: var(--accent-ink) !important;
	font-size: clamp(.76rem, .74rem + .12vw, .84rem); font-weight: 500; letter-spacing: .03em;
	white-space: nowrap; text-decoration: none;
	box-shadow: 0 12px 26px -16px var(--accent-glow);
	transition: background-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
#trp_ald_no_text_popup_change_language:hover {
	background: var(--accent-deep); transform: translateY(-1px);
	box-shadow: 0 16px 32px -16px var(--accent-glow);
}

/* Close button: outlined circle with an × (the TP button ships empty). */
#trp_ald_no_text_popup_x { flex: none; display: flex; align-items: center; position: static; inset: auto; margin: 0; }
#trp_close {
	width: 30px; height: 30px; padding: 0;
	display: grid; place-items: center;
	background: transparent; background-image: none;
	border: 1px solid var(--line); border-radius: 50%;
	color: var(--text-mut); line-height: 0;
	transition: color .3s, border-color .3s, background-color .3s, transform .3s var(--ease);
}
#trp_close::before { content: "\00d7"; font-size: 20px; line-height: 1; font-family: var(--font-sans); }
#trp_close:hover {
	color: var(--accent-ink) !important; 
	background: var(--accent) !important;
	border-color: var(--accent) !important; 
	
}

@media (max-width: 600px) {
	#trp_no_text_popup.trp_ald_no_text_popup { gap: 12px; align-items: flex-start; padding: 25px 12px !important; }
	#trp_ald_not_text_popup_ls_and_button { justify-content: flex-start; }
	#trp_ald_no_text_popup_text { font-size: .8rem; }
}

/* -------------------------------------------------------------------
   14b. TranslatePress ALD — "popup window" (modal) variant.
   TranslatePress keeps the layout/position; we only recolor the modal
   from its bright admin-blue defaults (#F0F0EE box, #2271b1 button,
   #0085ba close) to the theme's dark palette.
   ------------------------------------------------------------------- */

/* Backdrop scrim (TP keeps pointer-events:none here). */
#trp_ald_modal_container {
	background-color: rgba(8,12,24,.6) !important;
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(3px);
}

/* The modal box. */
#trp_ald_modal_popup {
	background-color: var(--surface) !important;
	color: var(--text);
	border: 1px solid var(--line) !important;
	border-radius: var(--r);
	box-shadow: var(--shadow) !important;
	font-family: var(--font-sans);
}
#trp_ald_popup_text { color: var(--text); }

/* Re-enable the switcher inside the modal (the header hides it globally). */
#trp_ald_modal_popup .trp-language-switcher-container { display: block !important; }
#trp_ald_modal_popup .trp-flag-image { border-radius: 2px; }

/* Current-language field + dropdown. */
#trp_ald_modal_popup .trp-ls-shortcode-current-language,
#trp_ald_modal_popup [special-selector="trp_ald_popup_current_language"] {
	background: var(--bg-2); color: var(--text);
	border-color: var(--line-strong);
	border-radius: var(--r-sm);
}
#trp_ald_modal_popup .trp-ls-shortcode-current-language:hover { border-color: var(--accent-deep); }
#trp_ald_modal_popup .trp-ls-shortcode-language {
	background: var(--surface); color: var(--text);
	border-color: var(--line-strong);
	border-radius: var(--r-sm);
}
#trp_ald_modal_popup .trp-ald-popup-select { color: var(--text-soft); }
#trp_ald_modal_popup .trp-ls-shortcode-language > div:hover {
	background: var(--accent); color: var(--accent-ink);
}
/* No dropdown-caret triangle (TP draws it with two gradients). */
#trp_ald_modal_popup .trp-language-switcher-container > div { background-image: none; }

/* "Change Language" — accent button. */
#trp_ald_popup_change_language {
	background: var(--accent) !important;
	border-color: var(--accent) !important;
	color: var(--accent-ink) !important;
	border-radius: 6px;
	box-shadow: 0 14px 30px -16px var(--accent-glow);
}
#trp_ald_popup_change_language:hover {
	background: var(--accent-deep) !important;
	border-color: var(--accent-deep) !important;
	color: var(--accent-ink) !important;
}

/* Close ("× / Close and do not switch language"). */
#trp_ald_x_button_and_textarea,
#trp_ald_x_button_textarea { color: var(--text-mut) !important; }
#trp_ald_x_button_and_textarea:hover,
#trp_ald_x_button_and_textarea:hover #trp_ald_x_button_textarea { color: var(--accent-2) !important; }
#trp_ald_modal_popup #trp_ald_x_button::before { color: var(--text-mut) !important; }
#trp_ald_x_button_and_textarea:hover #trp_ald_x_button::before { color: var(--accent-2) !important; }
