[data-lucide], .lucide {
	width: 1.1em;
	height: 1.1em;
	stroke-width: 2;
	flex-shrink: 0;
	vertical-align: -0.15em;
}

.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 2000;
	background: var(--accent);
	color: var(--on-accent);
	padding: 12px 20px;
	border-radius: 0 0 var(--r-sm) 0;
	font-weight: 600;
}
.skip-link:focus { left: 0; }

.pill {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 6px 13px;
	border-radius: var(--r-pill);
	font-family: var(--font-display);
	font-size: 0.8rem;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.01em;
	background: var(--surface-3);
	color: var(--text);
	border: 1px solid transparent;
	white-space: nowrap;
}
.pill svg { width: 15px; height: 15px; }
.pill--primary { background: var(--primary-soft); color: var(--primary); }
.pill--accent { background: var(--accent-soft); color: var(--accent); }
.pill--success { background: var(--success-soft); color: var(--success); }
.pill--warning { background: var(--warning-soft); color: var(--warning); }
.pill--danger { background: var(--danger-soft); color: var(--danger); }
.pill--info { background: var(--info-soft); color: var(--info); }
.pill--outline { background: transparent; border-color: var(--border-strong); color: var(--muted); }
.pill--lg { padding: 9px 18px; font-size: 0.88rem; }
.pill--glass {
	background: var(--glass-dark);
	backdrop-filter: blur(var(--blur));
	-webkit-backdrop-filter: blur(var(--blur));
	border-color: var(--glass-dark-border);
	color: #fff;
}
.pill--glass svg { color: var(--hivis); }
a.pill { transition: transform var(--t-fast) var(--ease); }
a.pill:hover { transform: translateY(-2px); }

.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 6px 14px;
	border-radius: var(--r-pill);
	background: var(--primary-soft);
	color: var(--primary);
	font-family: var(--font-display);
	font-size: 0.73rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}
.eyebrow svg { width: 14px; height: 14px; }
.band-dark .eyebrow, .hero .eyebrow {
	background: rgba(255, 255, 255, 0.1);
	color: var(--hivis);
	border: 1px solid rgba(255, 255, 255, 0.2);
	backdrop-filter: blur(var(--blur-sm));
	-webkit-backdrop-filter: blur(var(--blur-sm));
}

.pill-row { display: flex; flex-wrap: wrap; gap: 8px; }

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 0.95rem;
	line-height: 1;
	padding: 13px 22px;
	border-radius: var(--r-sm);
	border: 1.5px solid transparent;
	white-space: nowrap;
	transition: transform var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn svg { width: 1.05em; height: 1.05em; }

.btn--accent { background: var(--accent); color: var(--on-accent); box-shadow: var(--shadow-glow); }
.btn--accent:hover { background: var(--accent-hover); color: var(--on-accent); }
.btn--primary { background: var(--primary); color: var(--on-primary); }
.btn--primary:hover { background: var(--primary-strong); color: var(--on-primary); }
.btn--outline { background: transparent; border-color: var(--border-strong); color: var(--text); }
.btn--outline:hover { border-color: var(--primary); color: var(--primary); }
.btn--ghost { background: var(--surface-3); color: var(--text); }
.btn--ghost:hover { background: var(--primary-soft); color: var(--primary); }
.btn--light { background: #fff; color: var(--ink-900); }
.btn--light:hover { background: #fff; color: var(--accent-hover); }
.btn--glass {
	background: var(--glass-dark);
	backdrop-filter: blur(var(--blur));
	-webkit-backdrop-filter: blur(var(--blur));
	border-color: rgba(255, 255, 255, 0.5);
	color: #fff;
}
.btn--glass:hover { background: rgba(10, 11, 12, 0.72); border-color: var(--hivis); color: #fff; }
.btn--lg { padding: 16px 30px; font-size: 1.02rem; }
.btn--sm { padding: 9px 15px; font-size: 0.85rem; }
.btn--block { display: flex; width: 100%; }

.site-header {
	position: fixed;
	top: 16px;
	left: 50%;
	transform: translateX(-50%);
	width: min(1200px, calc(100% - 32px));
	z-index: 1000;
	border-radius: 16px;
	background: var(--glass-bg);
	backdrop-filter: blur(26px) saturate(180%);
	-webkit-backdrop-filter: blur(26px) saturate(180%);
	border: 1px solid var(--glass-border);
	box-shadow: var(--shadow-sm), inset 0 1px 0 rgba(255, 255, 255, 0.18);
	transition: box-shadow var(--t-med) var(--ease), background-color var(--t-med) var(--ease), border-color var(--t-med) var(--ease), top var(--t-med) var(--ease);
}
.site-header.is-scrolled { top: 10px; box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255, 255, 255, 0.18); background: var(--glass-bg-strong); border-color: var(--border); }

.header-bar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); height: 60px; padding: 0 12px 0 18px; }
.brand { display: inline-flex; align-items: center; transition: opacity var(--t-fast) var(--ease); }
.brand:hover { opacity: 0.82; }
.brand img { height: 30px; width: auto; filter: var(--logo-filter); }

.nav { display: flex; }
.nav__list {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 5px;
	border-radius: 13px;
	background: color-mix(in srgb, var(--heading) 5%, transparent);
	border: 1px solid color-mix(in srgb, var(--heading) 6%, transparent);
}
.nav__item { position: relative; }
.nav__link {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: 9px;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 0.88rem;
	letter-spacing: 0.005em;
	color: var(--text);
	white-space: nowrap;
	transition: color var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease);
}
.nav__link:hover { color: var(--heading); background: color-mix(in srgb, var(--heading) 8%, transparent); }
.nav__item.is-active > .nav__link { color: var(--surface); background: var(--heading); }
.nav__item.has-dropdown > .nav__link svg { width: 15px; height: 15px; color: currentColor; opacity: 0.7; transition: transform var(--t-med) var(--ease); }
.nav__item.has-dropdown:hover > .nav__link svg { transform: rotate(180deg); }

.dropdown {
	position: absolute;
	top: calc(100% + 14px);
	left: 50%;
	transform: translateX(-50%) translateY(10px) scale(0.97);
	transform-origin: top center;
	min-width: 360px;
	background: color-mix(in srgb, var(--elevated) 96%, transparent);
	backdrop-filter: blur(24px) saturate(180%);
	-webkit-backdrop-filter: blur(24px) saturate(180%);
	border: 1px solid var(--border);
	border-radius: 18px;
	box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255, 255, 255, 0.12);
	padding: 7px;
	display: grid;
	gap: 2px;
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--t-med) var(--ease), transform var(--t-med) var(--ease), visibility var(--t-med);
}
.dropdown::before { content: ""; position: absolute; top: -14px; left: 0; right: 0; height: 14px; }
.nav__item.has-dropdown:hover .dropdown,
.nav__item.has-dropdown:focus-within .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0) scale(1); }
.dropdown__label { padding: 9px 12px 7px; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--faint); }
.dropdown a { position: relative; display: flex; align-items: center; gap: 13px; padding: 10px 12px; border-radius: 12px; color: var(--text); transition: background-color var(--t-fast) var(--ease); }
.dropdown a:hover { background: color-mix(in srgb, var(--heading) 6%, transparent); }
.dropdown .ico {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 11px;
	background: var(--accent-soft);
	color: var(--accent);
	border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
	flex-shrink: 0;
	transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.dropdown a:hover .ico { background: var(--accent); color: var(--on-accent); border-color: var(--accent); transform: scale(1.05); }
.dropdown .ico svg { width: 19px; height: 19px; }
.dropdown .txt { flex: 1; min-width: 0; }
.dropdown .txt strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 0.92rem; color: var(--heading); margin-bottom: 1px; }
.dropdown .txt span { display: block; font-size: 0.8rem; line-height: 1.4; color: var(--muted); }
.dropdown .go-ico { width: 17px; height: 17px; color: var(--faint); opacity: 0; transform: translateX(-4px); transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), color var(--t-fast) var(--ease); flex-shrink: 0; }
.dropdown a:hover .go-ico { opacity: 1; transform: none; color: var(--accent); }

.header-actions { display: flex; align-items: center; gap: 8px; }
.header-actions .btn { height: 40px; padding-block: 0; padding-inline: 18px; border-radius: 10px; }
.theme-toggle {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px;
	border-radius: 11px;
	border: 1px solid color-mix(in srgb, var(--heading) 10%, transparent);
	background: color-mix(in srgb, var(--heading) 4%, transparent);
	color: var(--text);
	transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease);
}
.theme-toggle:hover { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent); background: var(--accent-soft); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .icon-sun { display: none; }
:root[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
:root[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

.hamburger { display: none; align-items: center; justify-content: center; width: 42px; height: 42px; color: var(--text); border-radius: 11px; border: 1px solid color-mix(in srgb, var(--heading) 10%, transparent); background: color-mix(in srgb, var(--heading) 4%, transparent); }
.hamburger svg { width: 22px; height: 22px; }

.drawer { position: fixed; inset: 0; z-index: 1100; visibility: hidden; }
.drawer.is-open { visibility: visible; }
.drawer__overlay { position: absolute; inset: 0; background: var(--overlay); opacity: 0; transition: opacity var(--t-med) var(--ease); }
.drawer.is-open .drawer__overlay { opacity: 1; }
.drawer__panel {
	position: absolute; top: 0; right: 0; height: 100%; width: min(380px, 90vw);
	background: var(--glass-bg-strong);
	backdrop-filter: blur(28px) saturate(180%);
	-webkit-backdrop-filter: blur(28px) saturate(180%);
	border-left: 1px solid var(--glass-border);
	box-shadow: var(--shadow-lg);
	padding: var(--space-5) var(--space-4); overflow-y: auto;
	transform: translateX(100%); transition: transform var(--t-med) var(--ease);
	display: flex; flex-direction: column;
}
.drawer.is-open .drawer__panel { transform: translateX(0); }
.drawer__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-5); padding-inline: 6px; }
.drawer__head img { height: 32px; filter: var(--logo-filter); }
.drawer__close { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; border-radius: 11px; color: var(--text); border: 1px solid color-mix(in srgb, var(--heading) 10%, transparent); background: color-mix(in srgb, var(--heading) 4%, transparent); transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); }
.drawer__close:hover { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent); }
.drawer-nav { display: grid; gap: 2px; }
.drawer-nav > li > a, .drawer-nav .drawer-sub-toggle {
	display: flex; align-items: center; gap: 13px; width: 100%;
	padding: 13px 14px; border-radius: 12px;
	font-family: var(--font-display); font-weight: 600; font-size: 1rem; color: var(--text);
	text-align: left; transition: color var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease);
}
.drawer-nav > li > a svg, .drawer-nav .drawer-sub-toggle .lbl svg { width: 19px; height: 19px; color: var(--muted); flex-shrink: 0; transition: color var(--t-fast) var(--ease); }
.drawer-nav > li > a:hover, .drawer-nav .drawer-sub-toggle:hover { color: var(--heading); background: color-mix(in srgb, var(--heading) 6%, transparent); }
.drawer-nav > li > a:hover svg, .drawer-nav .drawer-sub-toggle:hover .lbl svg { color: var(--accent); }
.drawer-nav > li > a.is-active { color: var(--surface); background: var(--heading); }
.drawer-nav > li > a.is-active svg { color: var(--surface); }
.drawer-sub-toggle { justify-content: space-between; }
.drawer-sub-toggle .lbl { display: inline-flex; align-items: center; gap: 13px; }
.drawer-sub-toggle .chev { width: 18px; height: 18px; margin-left: auto; color: var(--muted); transition: transform var(--t-fast) var(--ease), color var(--t-fast) var(--ease); }
.drawer-sub-toggle.is-open .chev { transform: rotate(180deg); color: var(--accent); }
.drawer-sub-toggle.is-current { color: var(--heading); }
.drawer-sub-toggle.is-current .lbl svg { color: var(--accent); }
.drawer-sub { max-height: 0; overflow: hidden; transition: max-height var(--t-med) var(--ease); }
.drawer-sub.is-open { max-height: 420px; margin: 4px 0 6px 22px; }
.drawer-sub a { display: block; padding: 10px 14px; border-radius: 9px; color: var(--muted); font-weight: 500; border-left: 2px solid var(--border); transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease); }
.drawer-sub a:hover { color: var(--heading); border-color: var(--accent); background: color-mix(in srgb, var(--heading) 5%, transparent); }
.drawer__actions { margin-top: auto; padding-top: var(--space-5); display: grid; gap: var(--space-3); }

@media (max-width: 992px) {
	.nav, .header-actions .btn { display: none; }
	.hamburger { display: inline-flex; }
}

.hero {
	position: relative;
	min-height: 94vh;
	display: flex;
	align-items: center;
	padding-top: calc(var(--header-h) + 54px);
	padding-bottom: var(--space-8);
	color: #fff;
	overflow: hidden;
	background: var(--grad-hero);
}
.hero__bg { position: absolute; inset: -15% 0; z-index: 0; opacity: 0.5; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.hero::after { content: ""; position: absolute; inset: 0; z-index: 1; background: var(--glow-primary), var(--glow-soft), linear-gradient(180deg, rgba(5, 7, 9, 0.18) 0%, rgba(5, 7, 9, 0.62) 100%); }
.hero__inner { position: relative; z-index: 2; width: 100%; }
.hero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: var(--space-8); align-items: center; }
.hero__content { max-width: 600px; }
.hero h1 { color: #fff; margin-top: var(--space-4); font-size: clamp(2.2rem, 1.5rem + 2.8vw, 3.4rem); }
.hero h1 .text-gradient { background: linear-gradient(120deg, #FF9D45, #D9741B); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero__text { margin-top: var(--space-4); font-size: 1.12rem; color: rgba(255, 255, 255, 0.88); max-width: 520px; }
.hero__cta { margin-top: var(--space-6); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hero__stats { margin-top: var(--space-7); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.stat-pill { display: inline-flex; flex-direction: column; gap: 2px; padding: 12px 18px; border-radius: var(--r-md); background: var(--glass-dark); border: 1px solid var(--glass-dark-border); backdrop-filter: blur(var(--blur)); -webkit-backdrop-filter: blur(var(--blur)); }
.stat-pill .num { font-family: var(--font-display); font-size: 1.5rem; font-weight: 800; color: #fff; line-height: 1; }
.stat-pill .num span { color: var(--hivis); }
.stat-pill .label { font-size: 0.78rem; color: rgba(255, 255, 255, 0.74); }

.track-card { padding: var(--space-6); border-radius: var(--r-lg); background: var(--glass-dark); backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px); border: 1px solid var(--glass-dark-border); box-shadow: var(--shadow-lg); }
.track-card h3 { color: #fff; }
.track-card p { color: rgba(255, 255, 255, 0.82); margin-top: var(--space-2); margin-bottom: var(--space-5); }
.track-card .field-icon input { background: rgba(255, 255, 255, 0.12); border-color: rgba(255, 255, 255, 0.28); color: #fff; }
.track-card .field-icon input::placeholder { color: rgba(255, 255, 255, 0.7); }
.track-card .field-icon > svg { color: rgba(255, 255, 255, 0.82); }

.hero-assure { padding: var(--space-6); border-radius: var(--r-lg); background: var(--glass-dark); backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px); border: 1px solid var(--glass-dark-border); box-shadow: var(--shadow-lg); }
.hero-assure h3 { color: #fff; font-size: 1.18rem; }
.hero-assure .assure-list { display: grid; gap: var(--space-3); margin-top: var(--space-4); }
.hero-assure .assure-list li { display: flex; align-items: flex-start; gap: 12px; color: rgba(255, 255, 255, 0.9); font-size: 0.95rem; line-height: 1.45; }
.hero-assure .assure-list svg { width: 19px; height: 19px; color: var(--hivis); margin-top: 2px; flex-shrink: 0; }
.hero-assure .assure-foot { margin-top: var(--space-5); padding-top: var(--space-5); border-top: 1px solid rgba(255, 255, 255, 0.14); display: flex; align-items: center; gap: var(--space-3); }
.hero-assure .assure-foot .r { color: rgba(255, 255, 255, 0.78); font-size: 0.88rem; }
.hero-assure .assure-foot .r strong { color: #fff; }
.rating-stars { display: inline-flex; gap: 2px; }
.rating-stars svg { width: 17px; height: 17px; color: var(--hivis); fill: var(--hivis); }

@media (max-width: 992px) {
	.hero { min-height: auto; }
	.hero__grid { grid-template-columns: 1fr; gap: var(--space-7); }
}

.trust-bar { border-bottom: 1px solid var(--border); background: var(--surface); }
.trust-bar__inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.trust-item { display: flex; align-items: center; gap: 14px; }
.trust-item .ic { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: var(--r-sm); background: var(--primary-soft); color: var(--primary); flex-shrink: 0; }
.trust-item .ic svg { width: 22px; height: 22px; }
.trust-item strong { display: block; font-family: var(--font-display); font-size: 0.96rem; color: var(--heading); line-height: 1.25; }
.trust-item span { font-size: 0.84rem; color: var(--muted); }
@media (max-width: 860px) { .trust-bar__inner { grid-template-columns: 1fr 1fr; gap: var(--space-4) var(--space-5); } }
@media (max-width: 520px) { .trust-bar__inner { grid-template-columns: 1fr; } }

.page-hero { position: relative; padding-top: calc(var(--header-h) + 56px); padding-bottom: var(--space-7); background: var(--grad-band); color: #fff; overflow: hidden; }
.page-hero::after { content: ""; position: absolute; inset: 0; background: var(--glow-primary), var(--glow-soft); }
.page-hero.has-image .page-hero__bg { position: absolute; inset: 0; opacity: 0.34; }
.page-hero.has-image .page-hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.page-hero__inner { position: relative; z-index: 1; }
.page-hero h1 { color: #fff; margin-top: var(--space-3); }
.page-hero p { color: rgba(255, 255, 255, 0.82); margin-top: var(--space-3); max-width: 620px; }
.crumbs { display: inline-flex; align-items: center; gap: 8px; font-size: 0.82rem; padding: 6px 14px; border-radius: var(--r-pill); background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); color: rgba(255, 255, 255, 0.86); }
.crumbs a { color: rgba(255, 255, 255, 0.86); }
.crumbs a:hover { color: var(--hivis); }
.crumbs svg { width: 14px; height: 14px; }

.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--space-6); box-shadow: var(--shadow-sm); }
.card--flat { box-shadow: none; }
.card--pad-sm { padding: var(--space-5); }
.hover-card { transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease), border-color var(--t-med) var(--ease); }
.hover-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--border-strong); }
.glass { background: var(--glass-bg); backdrop-filter: blur(var(--blur)); -webkit-backdrop-filter: blur(var(--blur)); border: 1px solid var(--glass-border); border-radius: var(--r-lg); }

.icon-badge { display: inline-flex; align-items: center; justify-content: center; width: 54px; height: 54px; border-radius: var(--r-md); background: var(--primary-soft); color: var(--primary); margin-bottom: var(--space-4); }
.icon-badge svg { width: 26px; height: 26px; }
.icon-badge--accent { background: var(--accent-soft); color: var(--accent); }

.bento { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-4); grid-auto-flow: dense; }
.bento-tile { position: relative; border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--space-5); background: var(--surface); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease); }
.bento-tile:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.bento-tile h4 { font-size: 1.15rem; }
.bento-tile p { color: var(--muted); margin-top: var(--space-2); font-size: 0.94rem; }
.bento-tile--image { padding: 0; min-height: 240px; color: #fff; display: flex; flex-direction: column; justify-content: flex-end; }
.bento-tile--image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; transition: transform var(--t-slow) var(--ease); }
.bento-tile--image::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(4, 24, 30, 0) 28%, rgba(4, 24, 30, 0.5) 64%, rgba(4, 24, 30, 0.86) 100%); z-index: 1; }
.bento-tile--image:hover img { transform: scale(1.06); }
.bento-tile--image .tile-body { position: relative; z-index: 2; padding: var(--space-5); }
.bento-tile--image h4 { color: #fff; }
.bento-tile--image p { color: rgba(255, 255, 255, 0.85); }
.bento-tile--accent { background: var(--grad-accent); border-color: transparent; color: #fff; }
.bento-tile--accent h4, .bento-tile--accent .num { color: #fff; }
.bento-tile--accent p { color: rgba(255, 255, 255, 0.92); }
.bento-tile .num { font-family: var(--font-display); font-size: 2.4rem; font-weight: 800; line-height: 1; color: var(--heading); }

.feature-card .icon-badge { margin-bottom: var(--space-4); }
.feature-card h6 { font-size: 1.05rem; margin-bottom: var(--space-2); }
.feature-card p { color: var(--muted); font-size: 0.93rem; }

.howto-step { position: relative; padding: var(--space-6) var(--space-5) var(--space-5); border-radius: var(--r-lg); background: var(--surface); border: 1px solid var(--border); box-shadow: var(--shadow-sm); overflow: hidden; }
.howto-step .step-num { position: absolute; top: -10px; right: 6px; font-family: var(--font-display); font-size: 4rem; font-weight: 800; color: var(--surface-3); line-height: 1; z-index: 0; }
.howto-step .icon-badge, .howto-step h5, .howto-step p { position: relative; z-index: 1; }
.howto-step h5 { margin-bottom: var(--space-2); }
.howto-step p { color: var(--muted); font-size: 0.94rem; }

.service-card, .sold-card { overflow: hidden; padding: 0; }
.service-card .img, .sold-card .img { overflow: hidden; }
.service-card .img { aspect-ratio: 16 / 10; }
.sold-card .img { aspect-ratio: 4 / 3; position: relative; }
.sold-badge { position: absolute; left: 12px; top: 12px; z-index: 2; display: inline-flex; align-items: center; gap: 5px; padding: 6px 11px; border-radius: var(--r-pill); background: var(--success); color: #fff; font-family: var(--font-display); font-size: 0.74rem; font-weight: 600; letter-spacing: 0.02em; box-shadow: var(--shadow-sm); }
.sold-badge svg { width: 13px; height: 13px; }
.sold-loc { display: inline-flex; align-items: center; gap: 6px; margin-top: var(--space-3); color: var(--muted); font-size: 0.84rem; }
.sold-loc svg { width: 14px; height: 14px; color: var(--primary); }
.service-card .img img, .sold-card .img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease); }
.service-card:hover .img img, .sold-card:hover .img img { transform: scale(1.06); }
.service-card .body { padding: var(--space-5); }
.sold-card .body { padding: var(--space-4) var(--space-5); }
.service-card h4 { font-size: 1.15rem; }
.service-card p { color: var(--muted); margin-top: var(--space-2); font-size: 0.94rem; }
.sold-card h4 { font-size: 1.02rem; }
.sold-card .meta { display: flex; gap: 8px; margin-top: var(--space-3); }

.cat-card { display: block; overflow: hidden; padding: 0; height: 100%; }
.cat-card .img { aspect-ratio: 16 / 10; background: radial-gradient(circle at 50% 35%, var(--surface), var(--band-tint)); display: flex; align-items: center; justify-content: center; padding: var(--space-5); }
.cat-card .img img { max-height: 100%; width: auto; object-fit: contain; transition: transform var(--t-med) var(--ease); }
.cat-card:hover .img img { transform: scale(1.06); }
.cat-card .body { padding: var(--space-4) var(--space-5); display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.cat-card h5 { font-size: 1rem; }
.cat-card .go { color: var(--accent); display: inline-flex; transition: transform var(--t-fast) var(--ease); }
.cat-card:hover .go { transform: translateX(4px); }

.testimonial-card { display: flex; flex-direction: column; height: 100%; }
.testimonial-card .quote { color: var(--accent); opacity: 0.45; }
.testimonial-card .quote svg { width: 34px; height: 34px; }
.testimonial-card .body { color: var(--text); margin-top: var(--space-3); font-size: 0.96rem; }
.testimonial-card .author { margin-top: var(--space-5); }
.testimonial-card .author h6 { font-size: 0.98rem; }
.testimonial-card .author .role { color: var(--muted); font-size: 0.85rem; }

.rating-summary { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; margin-bottom: var(--space-5); padding-bottom: var(--space-5); border-bottom: 1px solid var(--border); }
.rating-summary .left { display: flex; align-items: center; gap: var(--space-3); }
.rating-summary .left h3 { font-size: 1.4rem; }
.rating-summary img { height: 26px; width: auto; }
.rating-summary .right { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.rating-summary .right img { height: 28px; }
.rating-summary .right a { font-size: 0.82rem; color: var(--muted); text-decoration: underline; }

.review-card { display: flex; flex-direction: column; gap: var(--space-2); cursor: pointer; height: 100%; transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease), border-color var(--t-med) var(--ease); }
.review-card .head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.review-card .stars { height: 20px; width: auto; }
.review-card h6 { font-size: 0.98rem; }
.review-card .text { color: var(--muted); font-size: 0.9rem; }
.review-card .by { color: var(--faint); font-size: 0.82rem; margin-top: auto; }
.review-card .more { display: inline-flex; align-items: center; gap: 6px; color: var(--primary); font-weight: 600; font-size: 0.82rem; margin-top: var(--space-3); }
.review-card .more svg { width: 14px; height: 14px; }
.review-card:hover .more { color: var(--accent); }
.review-card small { color: var(--faint); font-size: 0.82rem; margin-top: auto; }
.review-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.review-card h6 { line-height: 1.35; }
.review-card .text { line-height: 1.6; }
.review-card .by-row { display: flex; align-items: center; gap: 12px; margin-top: auto; padding-top: var(--space-4); }
.review-card .avatar { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; background: var(--primary-soft); color: var(--primary); font-family: var(--font-display); font-weight: 700; font-size: 1rem; flex-shrink: 0; }
.review-card .by-row .by { display: flex; flex-direction: column; line-height: 1.3; margin: 0; }
.review-card .by-row .by strong { font-family: var(--font-display); font-size: 0.92rem; color: var(--heading); }
.review-card .by-row .by span { font-size: 0.8rem; color: var(--faint); }
.review-card .by-row .more-ico { margin-left: auto; width: 17px; height: 17px; color: var(--muted); transition: color var(--t-fast) var(--ease); }
.review-card:hover .by-row .more-ico { color: var(--accent); }

.location-card { text-align: center; max-width: 720px; margin-inline: auto; }
.location-card .post-info { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-3); margin-top: var(--space-4); }

.prose { max-width: 760px; }
.prose > * + * { margin-top: var(--space-4); }
.prose h2 { margin-top: var(--space-7); font-size: clamp(1.35rem, 1.1rem + 1vw, 1.8rem); }
.prose h3 { margin-top: var(--space-5); font-size: 1.2rem; }
.prose h4 { margin-top: var(--space-4); font-size: 1.05rem; }
.prose p, .prose li { color: var(--text); }
.prose ul { display: grid; gap: 10px; }
.prose ul li { position: relative; padding-left: 28px; }
.prose ul li::before { content: ""; position: absolute; left: 4px; top: 0.62em; width: 8px; height: 8px; border-radius: 2px; background: var(--accent); transform: rotate(45deg); }
.prose ul ul { margin-top: 10px; }
.prose a { color: var(--accent); font-weight: 600; }
.prose a:hover { color: var(--accent-hover); }

.check-list { display: grid; gap: var(--space-3); }
.check-list li { display: flex; align-items: flex-start; gap: 12px; color: var(--text); }
.check-list li svg { color: var(--success); margin-top: 3px; flex-shrink: 0; }

.toc { position: sticky; top: calc(var(--header-h) + 20px); align-self: start; padding: var(--space-5); border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--surface); }
.toc h6 { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--faint); margin-bottom: var(--space-3); }
.toc a { display: block; padding: 7px 0; color: var(--muted); font-size: 0.9rem; font-weight: 500; }
.toc a:hover { color: var(--accent); }
.legal-layout { display: grid; grid-template-columns: 240px 1fr; gap: var(--space-7); align-items: start; }
@media (max-width: 900px) { .legal-layout { grid-template-columns: 1fr; } .toc { position: static; } }

.field { margin-bottom: var(--space-4); }
.field > label { display: block; font-weight: 600; font-size: 0.9rem; margin-bottom: 8px; color: var(--heading); }
.input, input[type="text"].input, textarea.input, select.input {
	width: 100%; background: var(--surface); border: 1.5px solid var(--border); border-radius: var(--r-sm);
	padding: 12px 15px; font-size: 0.97rem; color: var(--text);
	transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.input::placeholder { color: var(--faint); }
.input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 4px var(--ring); }
textarea.input { min-height: 130px; resize: vertical; }
.input.is-invalid { border-color: var(--danger); }
.field-error, .error-message { display: block; color: var(--danger); font-size: 0.83rem; margin-top: 6px; }

.field-icon { position: relative; display: flex; align-items: center; }
.field-icon > svg { position: absolute; left: 14px; color: var(--muted); pointer-events: none; }
.field-icon input.input, .field-icon .input { padding-left: 44px; text-align: left; }
.field-icon .input.with-btn { padding-right: 124px; }
.field-icon .inset-btn { position: absolute; right: 5px; }

.choice { display: flex; align-items: flex-start; gap: 12px; cursor: pointer; padding: 13px 15px; border: 1.5px solid var(--border); border-radius: var(--r-sm); background: var(--surface); transition: border-color var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease); }
.choice:hover { border-color: var(--border-strong); }
.choice input { position: absolute; opacity: 0; width: 0; height: 0; }
.choice .box { flex: 0 0 22px; width: 22px; height: 22px; border: 2px solid var(--border-strong); border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; margin-top: 1px; transition: all var(--t-fast) var(--ease); }
.choice.radio .box { border-radius: 50%; }
.choice .box svg { width: 14px; height: 14px; color: #fff; opacity: 0; transform: scale(0.5); transition: all var(--t-fast) var(--ease); }
.choice input:checked + .box { background: var(--accent); border-color: var(--accent); }
.choice input:checked + .box svg { opacity: 1; transform: scale(1); }
.choice input:focus-visible + .box { box-shadow: 0 0 0 4px var(--ring); }
.choice .choice-label { font-size: 0.95rem; color: var(--text); }
.choice.is-checked { border-color: var(--accent); background: var(--accent-soft); }

.dropzone { position: relative; border: 2px dashed var(--border-strong); background: var(--surface-2); border-radius: var(--r-md); padding: var(--space-6) var(--space-5); text-align: center; cursor: pointer; transition: border-color var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease); }
.dropzone:hover { border-color: var(--primary); background: var(--primary-soft); }
.dropzone input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.dropzone .dz-icon { color: var(--primary); display: inline-flex; }
.dropzone .dz-icon svg { width: 36px; height: 36px; }
.dropzone .dz-title { font-weight: 600; color: var(--primary); margin-top: var(--space-2); }
.dropzone .dz-status { font-size: 0.88rem; color: var(--muted); margin-top: var(--space-2); }
.dropzone .dz-status .uploading { color: var(--accent); font-weight: 600; }

.auth-split { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; }
.auth-brand { position: relative; padding: var(--space-8) var(--space-7); color: #fff; background: var(--grad-band); overflow: hidden; display: flex; flex-direction: column; justify-content: space-between; }
.auth-brand::after { content: ""; position: absolute; inset: 0; background: var(--glow-primary), var(--glow-soft); }
.auth-brand > * { position: relative; z-index: 1; }
.auth-brand .brand-logo img { height: 38px; filter: brightness(0) invert(1); }
.auth-brand h2 { color: #fff; margin-top: var(--space-5); }
.auth-brand p { color: rgba(255, 255, 255, 0.82); margin-top: var(--space-3); }
.auth-brand .auth-quote { padding: var(--space-5); border-radius: var(--r-lg); background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.16); backdrop-filter: blur(var(--blur-sm)); -webkit-backdrop-filter: blur(var(--blur-sm)); }
.auth-brand .auth-quote p { color: rgba(255, 255, 255, 0.92); }
.auth-main { display: flex; align-items: center; justify-content: center; padding: calc(var(--header-h) + var(--space-6)) var(--space-5) var(--space-7); background: var(--bg); }
.auth-card { width: 100%; max-width: 420px; }
.auth-card h1 { font-size: 1.6rem; margin-bottom: var(--space-2); }
.auth-card .sub { color: var(--muted); margin-bottom: var(--space-6); }
.auth-alt { text-align: center; margin-top: var(--space-5); color: var(--muted); font-size: 0.92rem; }
.auth-alt a { color: var(--accent); font-weight: 600; }
.recaptcha-wrap { display: flex; justify-content: center; margin-bottom: var(--space-4); }
@media (max-width: 860px) { .auth-split { grid-template-columns: 1fr; } .auth-brand { display: none; } }

.form-narrow { max-width: 560px; margin-inline: auto; }
.content-narrow { max-width: 820px; margin-inline: auto; }
.empty-state { text-align: center; padding: var(--space-7) var(--space-5); }
.empty-state .icon-badge { margin-inline: auto; }

.data-table { width: 100%; border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; box-shadow: var(--shadow-sm); background: var(--surface); }
.data-table table { width: 100%; }
.data-table th, .data-table td { padding: 14px 18px; text-align: left; border-bottom: 1px solid var(--border); }
.data-table th { background: var(--surface-2); color: var(--muted); font-weight: 600; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.04em; width: 38%; vertical-align: top; }
.data-table td { color: var(--text); font-weight: 500; }
.data-table tr:last-child th, .data-table tr:last-child td { border-bottom: 0; }
.data-table a { color: var(--accent); font-weight: 600; }
@media (max-width: 600px) {
	.data-table th, .data-table td { display: block; width: 100%; }
	.data-table th { border-bottom: 0; padding-bottom: 4px; }
	.data-table td { padding-top: 4px; }
}

.alert { display: flex; align-items: flex-start; gap: 12px; padding: 14px 18px; border-radius: var(--r-sm); border: 1px solid transparent; font-size: 0.93rem; margin-bottom: var(--space-4); }
.alert svg { margin-top: 2px; flex-shrink: 0; }
.alert-success { background: var(--success-soft); color: var(--success); border-color: color-mix(in srgb, var(--success) 35%, transparent); }
.alert-danger { background: var(--danger-soft); color: var(--danger); border-color: color-mix(in srgb, var(--danger) 35%, transparent); }
.alert-warning { background: var(--warning-soft); color: var(--warning); border-color: color-mix(in srgb, var(--warning) 35%, transparent); }
.alert-info { background: var(--info-soft); color: var(--info); border-color: color-mix(in srgb, var(--info) 35%, transparent); }
.alert strong { color: inherit; }

.toast-stack {
	position: fixed;
	top: calc(var(--header-h) + 16px);
	right: 18px;
	z-index: 1200;
	display: flex;
	flex-direction: column;
	gap: 12px;
	width: min(390px, calc(100vw - 32px));
	pointer-events: none;
}
.toast {
	pointer-events: auto;
	position: relative;
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 14px 14px 16px 16px;
	border-radius: var(--r-md);
	background: var(--elevated);
	border: 1px solid var(--border);
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	opacity: 0;
	transform: translateX(20px) scale(0.98);
	transition: opacity var(--t-med) var(--ease), transform var(--t-med) var(--ease);
}
.toast.is-in { opacity: 1; transform: none; }
.toast.is-out { opacity: 0; transform: translateX(20px) scale(0.98); }
.toast::before { content: ""; position: absolute; top: 0; bottom: 0; left: 0; width: 4px; background: var(--info); }
.toast--success::before { background: var(--success); }
.toast--error::before { background: var(--danger); }
.toast--warning::before { background: var(--warning); }
.toast--info::before { background: var(--info); }
.toast__ic { flex: none; display: grid; place-items: center; width: 36px; height: 36px; border-radius: 11px; }
.toast__ic svg { width: 19px; height: 19px; }
.toast--success .toast__ic { background: var(--success-soft); color: var(--success); }
.toast--error .toast__ic { background: var(--danger-soft); color: var(--danger); }
.toast--warning .toast__ic { background: var(--warning-soft); color: var(--warning); }
.toast--info .toast__ic { background: var(--info-soft); color: var(--info); }
.toast__msg { flex: 1; min-width: 0; margin: 0; padding-top: 7px; font-size: 0.92rem; line-height: 1.45; font-weight: 500; color: var(--text); word-break: break-word; }
.toast__close { flex: none; display: grid; place-items: center; width: 28px; height: 28px; margin-top: 4px; border-radius: 9px; color: var(--faint); cursor: pointer; transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease); }
.toast__close:hover { background: var(--surface-2); color: var(--heading); }
.toast__close svg { width: 16px; height: 16px; }
.toast__bar { position: absolute; left: 0; right: 0; bottom: 0; height: 3px; transform-origin: left center; transform: scaleX(1); background: color-mix(in srgb, var(--info) 60%, transparent); }
.toast--success .toast__bar { background: color-mix(in srgb, var(--success) 60%, transparent); }
.toast--error .toast__bar { background: color-mix(in srgb, var(--danger) 60%, transparent); }
.toast--warning .toast__bar { background: color-mix(in srgb, var(--warning) 60%, transparent); }
@media (max-width: 560px) {
	.toast-stack { top: calc(var(--header-h) + 10px); left: 14px; right: 14px; width: auto; }
}

.spin { animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.stepper { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-6); }
.step { flex: 1 1 150px; display: flex; flex-direction: column; gap: 6px; padding: var(--space-4); border: 1px solid var(--border); border-radius: var(--r-md); background: var(--surface); box-shadow: var(--shadow-sm); }
.step__top { display: flex; align-items: center; gap: 10px; }
.step__num { width: 30px; height: 30px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: var(--surface-3); color: var(--muted); font-family: var(--font-display); font-weight: 700; font-size: 0.85rem; flex-shrink: 0; }
.step__num svg { width: 16px; height: 16px; }
.step strong { font-family: var(--font-display); font-size: 0.95rem; color: var(--heading); }
.step small { color: var(--muted); font-size: 0.82rem; }
.step.is-done .step__num { background: var(--success-soft); color: var(--success); }
.step.is-active { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.step.is-active .step__num { background: var(--accent); color: var(--on-accent); }
.step.is-upcoming { opacity: 0.6; }

.accordion { display: grid; gap: var(--space-3); }
.accordion-item { border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; background: var(--surface); }
.accordion-trigger { display: flex; align-items: center; gap: 12px; width: 100%; text-align: left; padding: 16px 18px; font-family: var(--font-display); font-weight: 600; font-size: 1rem; color: var(--heading); }
.accordion-trigger .lead-icon { color: var(--accent); }
.accordion-trigger .chev { margin-left: auto; transition: transform var(--t-fast) var(--ease); color: var(--muted); }
.accordion-trigger[aria-expanded="true"] .chev { transform: rotate(180deg); }
.accordion-panel { max-height: 0; overflow: hidden; transition: max-height var(--t-med) var(--ease); }
.accordion-panel__inner { padding: 0 18px 18px; }
.accordion-panel__inner > * + * { margin-top: 10px; }
.accordion-panel__inner p { color: var(--muted); }

.tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: var(--space-6); justify-content: center; }
.tab { padding: 9px 18px; border-radius: var(--r-pill); background: var(--surface-3); color: var(--text); font-family: var(--font-display); font-weight: 600; font-size: 0.88rem; transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease); }
.tab:hover { color: var(--accent); }
.tab.is-active { background: var(--accent); color: var(--on-accent); }
.tab-panel { display: none; }
.tab-panel.is-active { display: block; animation: fade-in var(--t-med) var(--ease); }
@keyframes fade-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

.carousel { position: relative; }
.carousel__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-5); }
.carousel__track { display: grid; grid-auto-flow: column; grid-auto-columns: calc((100% - 2 * var(--space-5)) / 3); gap: var(--space-5); overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding-bottom: var(--space-3); scrollbar-width: none; }
.carousel__track::-webkit-scrollbar { display: none; }
.carousel__track > * { scroll-snap-align: start; }
.carousel__nav { display: flex; gap: 10px; justify-content: flex-end; margin-bottom: var(--space-4); }
.carousel__btn { width: 44px; height: 44px; border-radius: 50%; border: 1.5px solid var(--border-strong); color: var(--text); display: inline-flex; align-items: center; justify-content: center; transition: all var(--t-fast) var(--ease); background: var(--surface); }
.carousel__btn:hover { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.carousel__btn:disabled { opacity: 0.35; cursor: not-allowed; }
.carousel__btn:disabled:hover { background: var(--surface); color: var(--text); border-color: var(--border-strong); }
@media (max-width: 992px) { .carousel__track { grid-auto-columns: calc((100% - var(--space-5)) / 2); } }
@media (max-width: 640px) { .carousel__track { grid-auto-columns: 84%; } }

.media-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width: 768px) { .media-grid { grid-template-columns: 1fr; } }
.media-grid video, .media-grid .gallery-cover img { width: 100%; border-radius: var(--r-md); box-shadow: var(--shadow-sm); }
.gallery-cover { position: relative; display: block; cursor: pointer; overflow: hidden; border-radius: var(--r-md); box-shadow: var(--shadow-sm); }
.gallery-cover img { aspect-ratio: 4 / 3; object-fit: cover; width: 100%; transition: transform var(--t-slow) var(--ease); }
.gallery-cover:hover img { transform: scale(1.05); }
.gallery-cover .count { position: absolute; left: 12px; top: 12px; background: var(--glass-dark); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); color: #fff; padding: 6px 12px; border-radius: var(--r-pill); font-size: 0.8rem; font-weight: 600; display: inline-flex; align-items: center; gap: 6px; }
.gallery-cover .zoom { position: absolute; right: 12px; bottom: 12px; width: 44px; height: 44px; border-radius: 50%; background: var(--glass-dark); border: 1px solid var(--glass-dark-border); color: #fff; display: inline-flex; align-items: center; justify-content: center; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); opacity: 0; transform: translateY(6px); transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease); }
.gallery-cover .zoom svg { width: 20px; height: 20px; }
.gallery-cover:hover .zoom { opacity: 1; transform: none; }
.gallery-cover:hover .zoom { background: var(--accent); border-color: var(--accent); }

.gallery-cover[data-lightbox="equipment"]::after,
.dash-order__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: var(--site-wm, none);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	pointer-events: none;
	z-index: 1;
}
.gallery-cover[data-lightbox="equipment"] .zoom,
.gallery-cover[data-lightbox="equipment"] .count { z-index: 2; }
.home-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 700px) {
	.home-gallery { grid-template-columns: 1fr 1fr; }
	.home-gallery .zoom { width: 36px; height: 36px; right: 10px; bottom: 10px; }
	.home-gallery .zoom svg { width: 16px; height: 16px; }
}

.lightbox { position: fixed; inset: 0; z-index: 1200; background: rgba(2, 10, 13, 0.84); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); display: none; flex-direction: column; padding: clamp(12px, 3vw, 28px); }
.lightbox.is-open { display: flex; }
.lightbox__bar { display: flex; align-items: center; justify-content: space-between; color: #fff; margin-bottom: var(--space-4); }
.lightbox__count { font-family: var(--font-display); font-weight: 600; font-size: 0.9rem; color: rgba(255, 255, 255, 0.82); letter-spacing: 0.04em; }
.lightbox__close { width: 44px; height: 44px; border-radius: 50%; background: rgba(255, 255, 255, 0.12); color: #fff; display: inline-flex; align-items: center; justify-content: center; transition: background var(--t-fast) var(--ease); }
.lightbox__close:hover { background: rgba(255, 255, 255, 0.26); }
.lightbox__body { flex: 1; display: flex; align-items: center; justify-content: center; gap: var(--space-3); min-height: 0; }
.lightbox__stage { flex: 1; display: flex; align-items: center; justify-content: center; min-height: 0; }
.lightbox img, .lightbox video { max-width: min(1100px, 100%); max-height: 78vh; border-radius: var(--r-lg); box-shadow: var(--shadow-lg); }
.lightbox__nav { width: 52px; height: 52px; border-radius: 50%; background: rgba(255, 255, 255, 0.12); color: #fff; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background var(--t-fast) var(--ease); }
.lightbox__nav:hover { background: rgba(255, 255, 255, 0.26); }
.lightbox__caption { text-align: center; color: rgba(255, 255, 255, 0.72); margin-top: var(--space-4); font-size: 0.9rem; min-height: 1.2em; }
.lightbox__media { position: relative; display: inline-flex; }
.lightbox.is-wm .lightbox__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: var(--site-wm, none);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	pointer-events: none;
	border-radius: var(--r-lg);
}
@media (max-width: 640px) {
	.lightbox__body { position: relative; gap: 0; }
	.lightbox__stage { width: 100%; }
	.lightbox__nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; width: 42px; height: 42px; background: rgba(10, 11, 12, 0.5); }
	.lightbox__nav.prev { left: 6px; }
	.lightbox__nav.next { right: 6px; }
	.lightbox img, .lightbox video { max-width: 100%; max-height: 82vh; }
}

.video-frame { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-md); }
.video-frame video { width: 100%; display: block; }

.trk-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.trk-overview { align-items: start; }
.trk-panel { display: flex; flex-direction: column; gap: var(--space-4); }
.trk-panel .rig-trust__list { margin: 0; }
.trk-price { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 22px; border: 1px solid var(--border); border-radius: var(--r-md); background: var(--surface); box-shadow: var(--shadow-sm); }
.trk-price .k { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); }
.trk-price .v { font-family: var(--font-display); font-weight: 900; font-size: clamp(1.7rem, 1.1rem + 2.4vw, 2.5rem); line-height: 1; letter-spacing: -0.02em; color: var(--heading); }
.trk-docs { display: grid; gap: 10px; }
.trk-doc { display: flex; align-items: center; gap: 13px; padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--r-md); background: var(--surface); box-shadow: var(--shadow-sm); transition: border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); }
.trk-doc:hover { border-color: var(--hivis); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.trk-doc__ic { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 11px; background: var(--accent-soft); color: var(--accent); flex-shrink: 0; }
.trk-doc__ic svg { width: 19px; height: 19px; }
.trk-doc__txt { display: flex; flex-direction: column; line-height: 1.3; min-width: 0; }
.trk-doc__txt strong { font-family: var(--font-display); font-size: 0.92rem; color: var(--heading); }
.trk-doc__txt span { font-size: 0.79rem; color: var(--muted); }
.trk-doc__go { margin-left: auto; display: inline-flex; color: var(--faint); flex-shrink: 0; transition: color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); }
.trk-doc__go svg { width: 18px; height: 18px; }
.trk-doc:hover .trk-doc__go { color: var(--hivis); transform: translate(2px, -2px); }
.trk-cta-actions { display: flex; flex-direction: column; gap: 14px; margin-top: 2px; }
.trk-status-row { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.trk-note { display: flex; align-items: flex-start; gap: 9px; font-size: 0.85rem; color: var(--muted); line-height: 1.45; }
.trk-note svg { width: 17px; height: 17px; margin-top: 1px; color: var(--success); flex-shrink: 0; }
.trk-media-empty { display: grid; place-items: center; aspect-ratio: 16 / 9; border: 1px dashed var(--border-strong); border-radius: var(--r-lg); background: var(--surface-2); color: var(--faint); }
.trk-media-empty svg { width: 44px; height: 44px; }
.trk-finder { max-width: 700px; margin: 0 auto; }
.trk-finder__card { position: relative; text-align: center; display: flex; flex-direction: column; align-items: center; padding: clamp(28px, 2rem + 2vw, 52px); border: 1px solid var(--border); border-radius: var(--r-xl); background: var(--surface); box-shadow: var(--shadow-lg); overflow: hidden; }
.trk-finder__card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: repeating-linear-gradient(135deg, var(--accent) 0 16px, transparent 16px 32px); }
.trk-finder__badge { display: inline-grid; place-items: center; width: 76px; height: 76px; border-radius: 22px; background: var(--accent-soft); color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 26%, transparent); }
.trk-finder__badge svg { width: 34px; height: 34px; }
.trk-finder__badge.is-error { background: var(--danger-soft); color: var(--danger); border-color: color-mix(in srgb, var(--danger) 32%, transparent); }
.trk-finder__title { margin-top: 22px; font-family: var(--font-display); font-size: clamp(1.7rem, 1.3rem + 2vw, 2.4rem); text-transform: uppercase; letter-spacing: -0.02em; line-height: 1; color: var(--heading); }
.trk-finder__sub { margin-top: 12px; max-width: 48ch; color: var(--muted); }
.trk-finder__sub strong { color: var(--heading); }
.trk-finder__form { width: 100%; max-width: 480px; margin-top: 26px; }
.trk-finder__field { display: flex; align-items: center; gap: 8px; padding: 6px 6px 6px 16px; border: 1.5px solid var(--border); border-radius: var(--r-pill); background: var(--bg); transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); }
.trk-finder__field:focus-within { border-color: var(--accent); box-shadow: 0 0 0 4px var(--ring); }
.trk-finder__field > svg { width: 20px; height: 20px; color: var(--muted); flex-shrink: 0; }
.trk-finder__field input { flex: 1; min-width: 0; border: 0; background: transparent; color: var(--text); font-size: 1rem; padding: 12px 2px; outline: none; }
.trk-finder__field input::placeholder { color: var(--faint); }
.trk-finder__field .btn { flex-shrink: 0; border-radius: var(--r-pill); }
.trk-finder__hint { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-size: 0.84rem; color: var(--muted); }
.trk-finder__hint svg { width: 16px; height: 16px; color: var(--hivis); flex-shrink: 0; }
.trk-finder__help { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 14px; }
.trk-help-card { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1px solid var(--border); border-radius: var(--r-md); background: var(--surface); box-shadow: var(--shadow-sm); transition: border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); }
.trk-help-card:hover { border-color: var(--hivis); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.trk-help-card .ic { display: inline-grid; place-items: center; width: 40px; height: 40px; border-radius: 11px; background: var(--accent-soft); color: var(--accent); flex-shrink: 0; transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease); }
.trk-help-card:hover .ic { background: var(--accent); color: var(--on-accent); }
.trk-help-card .ic svg { width: 19px; height: 19px; }
.trk-help-card .tx { display: flex; flex-direction: column; line-height: 1.3; min-width: 0; text-align: left; }
.trk-help-card .tx strong { font-family: var(--font-display); font-size: 0.9rem; color: var(--heading); }
.trk-help-card .tx span { font-size: 0.78rem; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.trk-help-card .go { width: 16px; height: 16px; color: var(--faint); margin-left: auto; flex-shrink: 0; transition: color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); }
.trk-help-card:hover .go { color: var(--hivis); transform: translate(2px, -2px); }
@media (max-width: 640px) { .trk-finder__help { grid-template-columns: 1fr; } }
.trk-empty { position: relative; max-width: 600px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 16px; padding: clamp(28px, 2rem + 2vw, 52px); border: 1px solid var(--border); border-radius: var(--r-xl); background: var(--surface); box-shadow: var(--shadow-lg); overflow: hidden; }
.trk-empty::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: repeating-linear-gradient(135deg, var(--accent) 0 16px, transparent 16px 32px); }
.trk-empty__ic { display: inline-grid; place-items: center; width: 76px; height: 76px; border-radius: 22px; background: var(--accent-soft); color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 26%, transparent); }
.trk-empty__ic svg { width: 34px; height: 34px; }
.trk-empty h2 { font-family: var(--font-display); font-size: clamp(1.5rem, 1.2rem + 1.6vw, 2.1rem); text-transform: uppercase; letter-spacing: -0.01em; color: var(--heading); }
.trk-empty p { color: var(--muted); max-width: 48ch; }
.trk-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 6px; }
@media (max-width: 560px) {
	.trk-finder__field { flex-wrap: wrap; padding: 12px; border-radius: var(--r-lg); }
	.trk-finder__field .btn { flex: 1 0 100%; justify-content: center; padding-block: 13px; }
	.trk-actions { width: 100%; flex-direction: column; align-items: stretch; }
	.trk-actions .btn { width: 100%; justify-content: center; }
}
.buy-machine { font-family: var(--font-display); text-transform: uppercase; letter-spacing: -0.01em; font-size: clamp(1.4rem, 1.1rem + 1.4vw, 1.9rem); line-height: 1.05; color: var(--heading); }
.buy-ship { display: flex; flex-direction: column; gap: var(--space-4); padding-top: var(--space-5); margin-top: var(--space-2); border-top: 1px solid var(--border); }
.buy-ship__head { display: flex; align-items: center; gap: 12px; }
.buy-ship__ic { display: inline-grid; place-items: center; width: 40px; height: 40px; border-radius: 11px; background: var(--accent-soft); color: var(--accent); flex-shrink: 0; }
.buy-ship__ic svg { width: 20px; height: 20px; }
.buy-ship__head h3 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.05rem; letter-spacing: -0.01em; color: var(--heading); }
.buy-ship__opts { display: grid; gap: 12px; }
.buy-ship .choice { align-items: center; }
.buy-ship .choice-label { flex: 1 1 auto; }
.buy-ship .choice-label strong { display: block; font-family: var(--font-display); font-size: 0.95rem; color: var(--heading); }
.buy-ship .choice-label span { display: block; font-size: 0.83rem; color: var(--muted); margin-top: 3px; line-height: 1.4; }
.buy-opt-ic { display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 11px; background: var(--surface-2); color: var(--muted); flex-shrink: 0; transition: background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease); }
.buy-opt-ic svg { width: 20px; height: 20px; }
.buy-ship .choice.is-checked .buy-opt-ic { background: var(--accent); color: var(--on-accent); }
.buy-zip { display: none; margin-bottom: 0; }
.buy-zip.is-open { display: block; animation: fade-in var(--t-med) var(--ease); }
.buy-next { max-width: 760px; margin-inline: auto; }
.btn.is-loading { opacity: 0.7; pointer-events: none; }

.buy-ship .field { margin-bottom: 0; }
.buy-ship .rig-form__grid { row-gap: var(--space-4); }
.buy-reveal { display: none; }
.buy-reveal.is-open { display: flex; flex-direction: column; gap: var(--space-4); animation: fade-in var(--t-med) var(--ease); }
.map-frame { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--border); }
.map-frame iframe { display: block; width: 100%; border: 0; }

.scroll-top { position: fixed; right: 20px; bottom: 20px; z-index: 900; width: 46px; height: 46px; border-radius: 50%; background: var(--accent); color: var(--on-accent); display: inline-flex; align-items: center; justify-content: center; box-shadow: var(--shadow-md); opacity: 0; visibility: hidden; transform: translateY(12px); transition: all var(--t-med) var(--ease); }
.scroll-top.is-visible { opacity: 1; visibility: visible; transform: none; }
.scroll-top:hover { background: var(--accent-hover); transform: translateY(-3px); }

.cta-band { position: relative; background: linear-gradient(125deg, #0A0B0C 0%, #1B1F23 100%); color: #fff; border-radius: var(--r-xl); padding: clamp(2rem, 1.5rem + 3vw, 3.5rem); overflow: hidden; box-shadow: var(--shadow-lg); }
.cta-band::after { content: ""; position: absolute; inset: 0; background: var(--glow-soft); }
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { color: #fff; }
.cta-band p { color: rgba(255, 255, 255, 0.9); }

.metric { padding: var(--space-5); border-radius: var(--r-lg); background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.14); }
.metric .ic { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 12px; background: rgba(240, 140, 52, 0.16); color: var(--hivis); margin-bottom: var(--space-4); }
.metric .ic svg { width: 22px; height: 22px; }
.metric .num { font-family: var(--font-display); font-size: 2.4rem; font-weight: 800; color: #fff; line-height: 1; }
.metric .num span { color: var(--hivis); }
.metric h4 { color: #fff; margin-top: var(--space-2); font-size: 1.05rem; }
.metric p { color: rgba(255, 255, 255, 0.74); font-size: 0.9rem; margin-top: var(--space-1); }

.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: center; }
.split__media img { border-radius: var(--r-lg); box-shadow: var(--shadow-md); width: 100%; }
@media (max-width: 900px) { .split { grid-template-columns: 1fr; gap: var(--space-6); } }

@media (max-width: 992px) {
	.bento { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 640px) {
	.bento { grid-template-columns: 1fr; }
}
