:root {
	--blue: #003EA0;
	--blue-dark: #003D9D;
	--blue-light: #66CCFF;
	--text: #222;
	--bg: #fff;
	--muted: #6b7280;
	--footer-h: 72px;
	--header-h: 100px;
	--brand: oklch(52% 0.18 260);
	--brand-2: oklch(78% 0.14 85);
	--ink: oklch(18% 0.03 255);
	--ink-2: oklch(40% 0.02 255);
	--bg: oklch(98% 0.01 250);
	--card: oklch(99% 0.01 250);
	--hair: color-mix(in oklab, var(--ink) 8%, transparent);
	/* skuggor lager */
	--elev-1: 0 1px 2px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04);
	--elev-2: 0 4px 10px rgba(0,0,0,.08), 0 1px 0 rgba(255,255,255,.4) inset;
	--ring: 0 0 0 2px color-mix(in oklab, white 70%, transparent), 0 0 0 4px color-mix(in oklab, var(--brand) 55%, transparent);
}
* {
	box-sizing: border-box;
}
html, body {
	margin: 0;
	padding: 0;
}
body {
	font-family: 'Raleway', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	color: var(--text);
	background: var(--bg);
	line-height: 1.5;
	padding-bottom: var(--footer-h);
}
img {
	max-width: 100%;
	height: auto;
	display: block;
}
a {
	color: var(--blue);
	text-decoration: none;
}
a:hover {
	text-decoration: none;
}
.muted {
	color: var(--muted);
}
.btn {
	display: inline-block;
	border: 0;
	background: var(--blue);
	color: #fff;
	padding: .75rem 1.1rem;
	border-radius: .5rem;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
}
.btn.ghost {
	background: transparent;
	color: var(--blue);
	border: 2px solid var(--blue);
}
.btn.small {
	padding: .5rem .8rem;
	font-size: .9rem;
}
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: #fff;
	border-bottom: 0 !important;
	min-height: 100px;
	overflow: visible;
}
.header-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: .6rem 1rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	z-index: 2;
}
.logo {
	display: flex;
	align-items: baseline;
	gap: .5rem;
	color: var(--blue);
	text-decoration: none;
}
.logo-mark {
	background: var(--blue);
	color: #fff;
	padding: .2rem .45rem;
	border-radius: .35rem;
	font-weight: 800;
}
.logo-text {
	font-weight: 700;
	letter-spacing: .5px;
}
.logo-img {
	height: 60px;
	width: auto;
	display: block;
}
.nav-wrap {
	display: flex;
	align-items: center;
	gap: 1rem;
}
.menu {
	list-style: none;
	display: flex;
	gap: .8rem;
	margin: 0;
	padding: 0;
}
.menu > li {
	position: relative;
}
.menu > li > a {
	display: block;
	padding: .4rem .6rem;
	border-radius: .35rem;
	color: var(--blue);
	background: transparent;
	border: 2px solid transparent;
	transition: background .15s, border-color .15s;
}
.menu > li > a:hover {
	background: var(--blue-dark);
	text-decoration: none;
}
.sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: #fff;
	border: 1px solid #e5e7eb;
	min-width: 200px;
	box-shadow: 0 8px 24px rgba(0,0,0,.08);
	padding: .3rem;
	z-index: 50;
}
.menu > li:hover .sub-menu {
	display: block;
}
.sub-menu li {
	list-style: none;
}
.sub-menu a {
	display: block;
	padding: .5rem .6rem;
	color: var(--blue);
	border-radius: .35rem;
}
.sub-menu a:hover {
	background: #f3f4f6;
	text-decoration: none;
}
.lang-switch {
	display: flex;
	gap: .5rem;
	align-items: center;
}
.lang-switch .lang-btn {
	display: inline-block;
	padding: .35rem .55rem;
	border-radius: .5rem;
	border: 1px solid var(--blue, #005bbb);
	color: var(--blue, #005bbb);
	text-decoration: none;
	line-height: 1;
}
.lang-switch .lang-btn:hover,.lang-switch .lang-btn:focus-visible {
	background: var(--blue, #005bbb);
	color: #fff;
	text-decoration: none;
	outline: 0;
}
.lang-switch .lang-btn.is-active,.lang-switch .lang-btn.active {
	background: var(--blue, #005bbb);
	color: #fff;
	border-color: var(--blue, #005bbb);
	font-weight: 600;
}
.burger {
	display: none;
	width: 44px;
	height: 38px;
	border: 0;
	background: transparent;
	position: relative;
}
.burger span {
	position: absolute;
	left: 8px;
	right: 8px;
	height: 3px;
	background: var(--blue);
	transform-origin: left center;
}
.burger span:nth-child(1) {
	top: 10px;
}
.burger span:nth-child(2) {
	top: 17px;
}
.burger span:nth-child(3) {
	top: 24px;
}
.page > section:first-child {
	margin-top: 0;
}
.hero {
	margin-top: 0;
	background: linear-gradient(180deg, rgba(0,62,160,.90), rgba(0,62,160,.55)),radial-gradient(1200px 400px at 70% 0%, rgba(102,204,255,.5), transparent);
	color: #fff;
}
.hero-inner {
	max-width: 1000px;
	margin: 0 auto;
	padding: 42px 16px 30px;
	text-align: center;
}
.hero h1 {
	font-size: clamp(28px, 4.5vw, 48px);
	margin: .2rem 0 .4rem;
}
.hero .lead {
	font-size: clamp(16px, 2.2vw, 22px);
	opacity: .95;
}
.cta-row {
	display: flex;
	gap: .8rem;
	justify-content: center;
	margin-top: 1rem;
	flex-wrap: wrap;
}
.home-promo {
	max-width: 1100px;
	margin: 0 auto;
	padding: 22px 12px 28px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}
.promo-card {
	border: 1px solid #e5e7eb;
	border-bottom: 4px solid var(--blue-dark);
	background: #f8fafc;
	padding: 14px;
	border-radius: 10px;
}
.home-promo .promo-card {
	display: flex;
	flex-direction: column;
}
.home-promo .promo-card .card-actions {
	margin-top: auto;
}
.page-banner {
	background: linear-gradient(180deg, rgba(0,62,160,.92), rgba(0,62,160,.65)),radial-gradient(1200px 320px at 70% 0%, rgba(102,204,255,.35), transparent);
	color: #fff;
	height: 120px;
	display: flex;
	align-items: center;
	border-bottom: 1px solid rgba(255,255,255,.15);
}
.banner-inner {
	max-width: 1100px;
	margin: 0 auto;
	width: 100%;
	padding: 0 16px;
	text-align: center;
}
.page-banner h1 {
	margin: 0;
	font-weight: 700;
	letter-spacing: .2px;
	font-size: clamp(22px, 4vw, 36px);
}
.listing {
	max-width: 1200px;
	margin: 0 auto;
	padding: 20px 12px 40px;
}
.section-title {
	color: var(--blue);
	margin: 6px 0 16px;
	font-size: clamp(22px, 3.4vw, 32px);
}
.card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0,1fr));
	gap: 16px;
}
.card {
	border: 1px solid #e6e6e6;
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	display: flex;
	flex-direction: column;
	min-height: 100%;
}
.card-img {
	width: 100%;
	height: auto;
	object-fit: contain;
	max-height: min(52vw, 420px);
	background: #f1f5f9;
}
.kayak-card .card-img {
	background: linear-gradient(#f8fbff,#eef6ff);
}
.misc-card .card-img {
	background: #f8fafc;
}
.card-body {
	padding: 14px 14px 18px;
	display: flex;
	flex-direction: column;
	gap: .5rem;
}
.card-title {
	margin: 2px 0 6px;
	color: var(--blue-dark);
	font-size: 1.25rem;
}
.card-text {
	color: #333;
}
.price-row {
	margin-top: .25rem;
}
.contact, .notfound {
	max-width: 900px;
	margin: 0 auto;
	padding: 20px 12px 40px;
}
.site-footer {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 950;
	width: 100%;
	background: #fff;
	border-top: 3px solid var(--blue-dark);
}
.site-footer .social-link,.site-footer .instagram-link,.site-footer .footer-social a {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	white-space: nowrap;
	text-decoration: none;
}
.footer-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 14px 12px;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	gap: 12px;
	font-size: .95rem;
	min-height: var(--footer-h);
	align-items: center;
}
.footer-col.small {
	color: #666;
	font-size: .85rem;
}
.instagram-icon {
	display: inline-block;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	color: var(--blue);
	font-size: 1.25rem;
	line-height: 1;
}
.instagram-icon i {
	font-size: 1.25rem;
	line-height: 1;
}
.ig-link {
	display: inline-flex;
	align-items: center;
	white-space: nowrap;
	text-decoration: none;
}
.contact-actions .btn + .btn {
	margin-left: .5rem;
}
.contact-grid {
	max-width: 1100px;
	margin: 0 auto;
	padding: 20px 12px 120px;
}
.contact-card {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	padding: 18px;
	box-shadow: 0 8px 24px rgba(0,0,0,.06);
}
.contact-list {
	list-style: none;
	margin: 0 0 10px;
	padding: 0;
}
.contact-list li {
	margin: 6px 0;
}
.contact-list .lbl {
	color: var(--muted);
	margin-right: 6px;
}
.contact-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	align-items: center;
	margin-top: 8px;
}
.instagram-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: .55rem .75rem;
	border: 1px solid var(--blue);
	border-radius: 999px;
	color: var(--blue);
	text-decoration: none;
}
.instagram-pill:hover {
	background: var(--blue);
	color: #fff;
	text-decoration: none;
}
.map-modal {
	position: fixed;
	inset: 0;
	z-index: 2000;
	display: none;
}
.map-modal.open {
	display: block;
}
.map-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.45);
}
.map-dialog {
	position: relative;
	max-width: 960px;
	margin: 6vh auto;
	background: #fff;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
.map-close {
	position: absolute;
	right: 10px;
	top: 10px;
	border: 0;
	background: transparent;
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
}
.map-dialog h3 {
	margin: 14px 16px 0;
	color: var(--blue-dark);
}
.map-frame {
	width: 100%;
	height: 420px;
}
.map-frame iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}
.map-cta {
	padding: 12px;
	border-top: 1px solid #e5e7eb;
	text-align: right;
}
.catalog-wrapper {
	display: flex;
	align-items: flex-start;
}
.catalog-sidebar {
	width: 250px;
	padding: 0px 15px 15px 15px;
	border-right: 1px solid #ddd;
	position: sticky;
	top: 110px;
	max-height: calc(100vh - 120px);
	overflow: auto;
	padding-right: 8px;
	overscroll-behavior: contain;
	background: #fff;
	padding-bottom: 90px;
	scroll-padding-bottom: 90px;
}
.catalog-sidebar ul {
	list-style: none;
	padding-left: 0;
}
.catalog-sidebar li {
	margin: 5px 0;
}
.catalog-content {
	flex: 1;
	padding: 20px;
}
.catalog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 320px));
	gap: 18px;
	align-items: stretch;
	justify-content: center;
}
.catalog-card {
	border: 1px solid #eee;
	border-radius: 16px;
	background: #fafafa;
	padding: 15px;
	display: flex;
	flex-direction: column;
	position: relative;
	padding-bottom: 12px;
	max-width: 360px;
	max-height: 560px;
	overflow: hidden;
}
.catalog-card img {
	width: 100%;
	border-radius: 6px;
	margin-bottom: 10px;
}
.catalog-card h3 {
	margin-top: 0;
	margin: 10px 0 6px;
	line-height: 1.25;
	max-height: 3.2em;
	overflow: hidden;
}
.catalog-card .btn {
	margin-top: auto;
	align-self: center;
	display: inline-block;
	text-align: center;
	min-width: 120px;
}
.filter-bar {
	position: sticky;
	top: 60px;
	z-index: 100;
	background: #fff;
	padding: 10px;
	border-bottom: 1px solid #ddd;
	display: flex;
	gap: 10px;
}
.filter-bar select {
	flex: 1;
	padding: 8px;
}
.desktop-only {
	display: block;
}
.mobile-only {
	display: none;
}
.catalog-sidebar .side-cats > ul {
	list-style: none;
	padding-left: 0;
}
.catalog-sidebar .cat-item > a {
	display: block;
	padding: 10px 12px;
	border-radius: 10px;
	text-decoration: none;
	position: relative;
	padding-right: 22px;
	margin: 6px 6px 4px;
	background: #f2f7ff;
	color: #153e90;
	transition: background .15s ease, box-shadow .15s ease;
}
.catalog-sidebar .cat-item.active > a,.catalog-sidebar .cat-item > a:hover {
	background: #eef5ff;
}
.catalog-sidebar .cat-models {
	list-style: none;
	padding: 2px 0 10px 0;
	margin: 4px 0 16px 8px;
	padding-left: 10px;
	border-left: 1px dashed rgba(0,0,0,.1);
	display: none;
}
.catalog-sidebar .cat-models a.active {
	font-weight: 700;
}
.kayak-detail {
	max-width: 1100px;
	margin: 0 auto;
	padding: 10px 0 30px;
}
.kd-hero {
	text-align: center;
	margin-bottom: 16px;
	position: relative;
}
.kd-img {
	width: 100%;
	max-width: 900px;
	height: auto;
}
.kd-grid {
	display: grid;
	grid-template-columns: minmax(0,1fr) minmax(0,420px);
	gap: 24px;
	align-items: start;
	grid-template-areas: "desc specs";
	column-gap: 28px;
	row-gap: 0;
	margin-top: 12px;
}
.kd-col.kd-desc {
	text-align: left;
	grid-area: desc;
	display: block;
	color: #111;
	max-width: 62ch;
	line-height: 1.65;
	font-size: 1.05rem;
	hyphens: none;
	word-break: normal;
	overflow-wrap: break-word;
}
.kd-col.kd-specs {
	text-align: left;
	grid-area: specs;
}
.catalog-sidebar .side-cats > ul > li.cat-item > a {
	display: block;
	font-weight: 700;
	color: #0b5bd3;
	background: rgba(11, 91, 211, .08);
	border-left: 4px solid #0b5bd3;
	padding: 8px 12px;
	border-radius: 8px;
	margin: 10px 0 6px;
	text-decoration: none;
}
.catalog-sidebar .side-cats > ul > li.cat-item.active > a {
	background: rgba(11, 91, 211, .13);
	box-shadow: 0 0 0 1px rgba(11, 91, 211, .15) inset;
}
.catalog-sidebar .cat-models li a {
	display: block;
	font-weight: 500;
	color: #11325f;
	padding: 8px 12px 8px 22px;
	text-decoration: none;
	margin: 0 6px;
	border-left: 2px solid #e9efff;
	border-radius: 6px;
}
.catalog-sidebar .cat-models li a:hover {
	text-decoration: underline;
	background: #f6f9ff;
}
.spec-card {
	background: #fff;
	border: 1px solid #e9eef5;
	border-radius: 12px;
	padding: 14px;
	box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.spec-card h3 {
	margin: 0 0 10px;
	font-size: 1.05rem;
	line-height: 1.2;
}
.spec-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
	margin: 0;
	padding: 0;
}
.spec-row {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	column-gap: 14px;
	padding: 8px 12px;
	background: #f8fbff;
	border-radius: 10px;
	border: 1px solid #eef3ff;
}
.spec-row dt,.spec-row dd {
	margin: 0;
}
.spec-row dt {
	font-weight: 600;
	color: #2a2f3a;
}
.spec-row dd {
	font-weight: 500;
	color: #0f172a;
	text-align: right;
	white-space: nowrap;
	font-variant-numeric: tabular-nums;
}
.kd-col.kd-desc p {
	margin: 0 0 14px;
	color: #111;
}
.kd-col.kd-desc p + p {
	margin-top: 0.9em;
}
.kd-col.kd-specs .spec-card {
	position: sticky;
	top: 90px;
}
.spec-row:nth-child(odd) {
	background: #f3f8ff;
}
.catalog-sidebar .side-cats > ul > li.cat-item > a,.spec-title {
	display: block;
	font-weight: 700;
	color: #0b5bd3;
	background: rgba(11, 91, 211, .08);
	border-left: 4px solid #0b5bd3;
	padding: 8px 12px;
	border-radius: 8px;
	margin: 0 0 12px;
	text-decoration: none;
}
.order-cta {
	margin: 10px 0 18px;
	padding: 12px 14px;
	background: rgba(11,91,211,.08);
	border-left: 4px solid #0b5bd3;
	border-radius: 10px;
}
.order-cta-title {
	font-weight: 700;
	color: #0b5bd3;
	margin: 0 0 6px;
}
.order-cta-text {
	margin: 0;
	color: #0f172a;
}
.order-btn {
	display: inline-block;
	font-weight: 700;
	color: #fff;
	background: #0b5bd3;
	padding: 8px 12px;
	border-radius: 8px;
	text-decoration: none;
	margin-left: 6px;
}
.order-btn:hover {
	filter: brightness(1.05);
}
.catalog-grid .catalog-card img[src*="img/misc/"] {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: contain;
	background: #fff;
	padding: 8px;
	border-radius: 8px;
	box-shadow: 0 0 0 1px #eef3ff inset;
}
.misc-gallery {
	position: relative;
	width: 100%;
	max-width: 680px;
	margin: 0 auto 10px;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 0 0 1px #eef3ff inset;
	overflow: hidden;
}
.misc-gallery .mg-viewport {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
	background: #f8fafc;
	touch-action: pan-y pinch-zoom;
	overflow: hidden;
}
.misc-gallery .mg-track {
	display: flex;
	height: 100%;
	width: 100%;
	transform: translateX(0);
	transition: transform .25s ease;
}
.misc-gallery .mg-slide {
	flex: 0 0 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 6px;
}
.misc-gallery .mg-slide img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	display: block;
}
.misc-gallery .mg-arrow {
	position: absolute;
	top: 50%;
	border: 0;
	width: 42px;
	height: 42px;
	border-radius: 999px;
	background: rgba(0,0,0,.45);
	color: #fff;
	font-size: 22px;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 3;
	opacity: 0;
	transition: opacity .2s ease;
}
.misc-gallery .mg-arrow:focus-visible {
	outline: 2px solid var(--blue, #003EA0);
}
.misc-gallery .mg-arrow:hover {
	background: rgba(0,0,0,.6);
}
.misc-gallery .mg-arrow[disabled] {
	opacity: .45;
	cursor: default;
}
.misc-gallery .mg-dots {
	display: flex;
	justify-content: center;
	gap: 8px;
	padding: 8px 10px 12px;
}
.misc-gallery .mg-dot {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: #c9d6ff;
	border: 1px solid #9fb7ff;
	cursor: pointer;
}
.misc-gallery .mg-dot.is-active {
	background: #0b5bd3;
	border-color: #0b5bd3;
}
.page-kayak-museum {
	--museum-gap: 2rem;
	--museum-max: 1200px;
}
.museum-hero {
	position: relative;
	padding: 5rem 1rem 3rem;
	background: linear-gradient(180deg, rgba(15,25,35,0.6), rgba(15,25,35,0.2)), url('/img/bg/woodgrain.webp');
	background-size: cover;
	background-position: center;
	color: #fff;
	text-align: center;
}
.museum-hero-inner {
	max-width: var(--museum-max);
	margin: 0 auto;
}
.museum-hero h1 {
	font-size: clamp(2rem, 3vw, 3rem);
	line-height: 1.1;
	margin: 0 0 0.75rem;
}
.museum-hero .lead {
	font-size: clamp(1rem, 1.4vw, 1.25rem);
	opacity: 0.95;
}
.museum-hero-scrollhint {
	margin-top: 1.25rem;
	font-size: 1.5rem;
	opacity: .8;
	animation: museum-bounce 1.8s infinite;
}
@keyframes museum-bounce{
	0%,100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(6px);
	}
}
.museum-list {
	max-width: var(--museum-max);
	margin: 0 auto;
	padding: 2rem 1rem 4rem;
	display: grid;
	gap: var(--museum-gap);
}
.museum-card {
	display: grid;
	grid-template-columns: 1.45fr 1fr;
	gap: var(--museum-gap);
	align-items: stretch;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 8px 26px rgba(0,0,0,0.08);
	overflow: hidden;
	opacity: 0;
	transform: translateY(18px);
	transition: opacity .5s ease, transform .5s ease;
}
.museum-card.in {
	opacity: 1;
	transform: translateY(0);
}
.museum-card.reversed {
	grid-template-columns: 1fr 1.45fr;
}
.museum-card-media {
	position: relative;
	background: #f5f7fb;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 8px;
}
.museum-card-media img {
	width: 100%;
	height: auto;
	max-height: 300px;
	object-fit: contain;
	display: block;
}
.museum-card-media.placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #8792a2;
	font-size: .95rem;
}
.museum-card-body {
	padding: 1.25rem 1.25rem 1.5rem;
	display: flex;
	flex-direction: column;
}
.museum-card-header {
	margin-bottom: .5rem;
}
.museum-card-title {
	margin: 0 0 .25rem;
	font-size: clamp(1.25rem, 2.2vw, 1.75rem);
	line-height: 1.2;
}
.museum-card-meta .badge {
	display: inline-block;
	font-size: .75rem;
	padding: .25rem .5rem;
	border-radius: 999px;
	background: #e8f0fe;
	color: #2750b8;
}
.museum-card-text {
	margin-top: .5rem;
	display: flex;
	flex-direction: column;
	gap: .75rem;
}
.museum-card-text__clip {
	position: relative;
	max-height: 11.5rem;
	overflow: hidden;
}
.museum-card-text__clip::after {
	content: "";
	position: absolute;
	inset: auto 0 0 0;
	height: 4rem;
	background: linear-gradient(to bottom, rgba(255,255,255,0), #fff);
	pointer-events: none;
}
.museum-card-text__clip.expanded {
	max-height: none;
}
.museum-card-text__clip.expanded::after {
	display: none;
}
.museum-card .btn.museum-toggle {
	align-self: flex-start;
	min-width: 9rem;
}
.museum-timeline {
	position: relative;
	margin: 2rem 0;
	padding-left: 1.5rem;
	border-left: 3px solid #e2e8f0;
	height: 0;
}
.museum-timeline-year {
	position: absolute;
	left: -10px;
	top: -14px;
	background: #2750b8;
	color: #fff;
	font-weight: 700;
	font-size: .9rem;
	padding: .2rem .5rem;
	border-radius: 6px;
	white-space: nowrap;
	box-shadow: 0 4px 12px rgba(0,0,0,.12);
}
.timeline-wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 2rem 1rem 4rem;
}
.timeline-grid {
	position: relative;
	display: grid;
	grid-template-columns: 1fr 70px 1fr;
	gap: 2.2rem 1rem;
}
.timeline-grid::before {
	content: "";
	position: absolute;
	left: calc(50% - 1px);
	top: 0;
	bottom: 0;
	width: 2px;
	background: #e2e8f0;
}
.tline-item {
	display: contents;
	opacity: 0;
	transform: translateY(18px);
	transition: opacity .45s ease, transform .45s ease;
}
.tline-item.in {
	opacity: 1;
	transform: translateY(0);
}
.tline-col.content {
	grid-column: 1;
}
.tline-col.node {
	grid-column: 2;
	display: flex;
	align-items: center;
	justify-content: center;
}
.tline-col.spacer {
	grid-column: 3;
}
.tline-item.right .tline-col.content {
	grid-column: 3;
}
.tline-item.right .tline-col.spacer {
	grid-column: 1;
}
.tline-node {
	position: relative;
	width: 70px;
	height: 70px;
	border-radius: 999px;
	color: #fff;
	display: grid;
	place-items: center;
	box-shadow: 0 8px 26px rgba(39,80,184,.22);
	border: 6px solid #f8faff;
}
.tline-year {
	font-weight: 800;
	font-size: .95rem;
	letter-spacing: .5px;
}
.tcard {
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 10px 28px rgba(0,0,0,0.08);
	overflow: hidden;
}
.tcard-media {
	background: #f5f7fb;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 6px;
	position: relative;
}
.tcard-media img {
	width: 100%;
	height: auto;
	max-height: 340px;
	object-fit: contain;
	display: block;
}
.tcard-body {
	padding: 1.2rem 1.2rem 1.4rem;
}
.tcard-title {
	margin: 0 0 .35rem;
	font-size: clamp(1.25rem, 2.1vw, 1.75rem);
	line-height: 1.2;
}
.tcard-text {
	margin-top: .25rem;
	display: flex;
	flex-direction: column;
	gap: .75rem;
}
.tcard-text__clip {
	position: relative;
	max-height: 12rem;
	overflow: hidden;
}
.tcard-text__clip::after {
	content: "";
	position: absolute;
	inset: auto 0 0 0;
	height: 4rem;
	background: linear-gradient(to bottom, rgba(255,255,255,0), #fff);
	pointer-events: none;
}
.tcard-text__clip.expanded {
	max-height: none;
}
.tcard-text__clip.expanded::after {
	display: none;
}
.tcard .btn.tcard-toggle {
	align-self: flex-start;
	min-width: 9rem;
}
.museum-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: none;
}
.museum-lightbox.is-open {
	display: block;
}
.mlb-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(15,25,35,.65);
}
.mlb-frame {
	position: absolute;
	inset: 0;
	display: grid;
	grid-template-columns: 64px 1fr 64px;
	align-items: center;
	gap: 0;
	padding: 4vh 2vw;
}
.mlb-figure {
	margin: 0;
	display: grid;
	justify-items: center;
	gap: .75rem;
	position: static;
}
#mlb-img {
	max-width: 92vw;
	max-height: 86vh;
	width: auto;
	height: auto;
	box-shadow: 0 16px 48px rgba(0,0,0,.35);
	background: #fff;
	border-radius: 10px;
}
#mlb-cap {
	color: #e8eef7;
	font-size: 1.05rem;
	text-align: center;
	position: static;
	left: 50%;
	bottom: 8px;
	transform: none;
	max-width: 92vw;
	padding: 0;
	border-radius: 10px;
	background: none;
	font-weight: 700;
	line-height: 1.35;
	box-shadow: none;
	text-shadow: none;
	word-break: break-word;
	overflow-wrap: anywhere;
	margin: .6rem auto 0;
}
.mlb-btn {
	background: rgba(255,255,255,.9);
	border: none;
	color: #0f1923;
	font-size: 2rem;
	line-height: 1;
	width: 48px;
	height: 48px;
	border-radius: 999px;
	display: grid;
	place-items: center;
	box-shadow: 0 6px 18px rgba(0,0,0,.25);
	cursor: pointer;
	user-select: none;
}
.mlb-prev {
	justify-self: center;
}
.mlb-next {
	justify-self: center;
}
.mlb-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 42px;
	height: 42px;
	font-size: 1.6rem;
	z-index: 999;
}
body.mlb-no-scroll {
	overflow: hidden;
}
.belt {
	position: relative;
	max-width: 1200px;
	margin: 10px auto 20px;
	padding: 0 12px;
}
.belt-viewport {
	overflow-x: hidden;
	padding-bottom: 50px;
}
.belt-track {
	display: flex;
	will-change: transform;
	transform: translateX(0);
	transition: transform .45s ease;
}
.belt-slide {
	min-width: 100%;
}
.belt .card-grid {
	gap: 18px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	align-items: stretch;
}
.belt-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 1px solid #c9d3ee;
	background: #fff;
	color: #0b3b9d;
	box-shadow: 0 6px 16px rgba(0,0,0,.08);
	cursor: pointer;
	font-size: 20px;
	line-height: 32px;
}
.belt-nav.prev {
	left: -2px;
}
.belt-nav.next {
	right: -2px;
}
.belt-nav:hover {
	box-shadow: 0 10px 24px rgba(0,0,0,.12);
}
.about-card {
	position: relative;
}
.card-badge {
	position: absolute;
	left: 10px;
	top: 10px;
	background: #ffffff;
	color: #0b3b9d;
	border: 1px solid #cbd6f2;
	border-radius: 999px;
	font-size: .78rem;
	font-weight: 800;
	padding: .25rem .55rem;
	box-shadow: 0 4px 12px rgba(39,80,184,.15);
}
.belt-mobile {
	display: none;
}
.belt .about-card {
	display: flex;
	flex-direction: column;
	min-height: 300px;
	border-radius: 16px;
	box-shadow: 0 14px 26px rgba(0,0,0,.10);
	background: #fff;
}
.belt .about-card .card-img {
	width: 100%;
	height: 190px;
	object-fit: cover;
	display: block;
	border-bottom: 1px solid rgba(11,59,157,.12);
}
.belt .about-card .card-body {
	flex: 1;
	padding: 12px 14px;
	display: flex;
	flex-direction: column;
	gap: .6rem;
}
.belt .about-card .card-title {
	font-size: 1.12rem;
	margin-bottom: .2rem;
}
.belt .about-card .card-text {
	flex: 1;
	font-size: .95rem;
	line-height: 1.42;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}
.belt .about-card .card-badge {
	position: absolute;
	left: 12px;
	top: 12px;
	background: #fff;
	color: #0b3b9d;
	border: 1px solid rgba(11,59,157,.28);
	border-radius: 999px;
	font-weight: 800;
	font-size: .82rem;
	padding: .28rem .6rem;
	box-shadow: 0 6px 14px rgba(11,59,157,.18);
}
.belt .about-card .card-badge,.belt-mobile .about-card .card-badge {
	left: auto !important;
	right: 12px !important;
	top: 12px;
	z-index: 3;
}
.card-img.slider {
	position: relative;
	overflow: hidden;
	background: #fff;
}
.card-img.slider img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 192px;
	object-fit: cover;
	background: #fff;
}
.card-img.slider img.bottom {
	z-index: 0;
}
.card-img.slider img.top {
	z-index: 1;
	clip-path: inset(0 0 0 0);
	-webkit-clip-path: inset(0 0 0 0);
	transition: clip-path var(--wipe-duration,2.5s) ease-in-out;
	-webkit-transition: -webkit-clip-path var(--wipe-duration,2.5s) ease-in-out;
}
.card-img.slider[data-images] img {
	object-fit: contain;
	object-position: center center;
	background: #fff;
}
.prod-badges {
	position: absolute;
	top: 10px;
	right: 10px;
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	justify-content: flex-end;
	max-width: 70%;
	pointer-events: none;
	z-index: 5;
}
.prod-badge {
	pointer-events: auto;
	background: #fff;
	color: #0b3b9d;
	border: 1px solid #cbd6f2;
	border-radius: 999px;
	font-size: .78rem;
	font-weight: 800;
	padding: .28rem .6rem;
	line-height: 1;
	white-space: nowrap;
	box-shadow: 0 6px 14px rgba(11,59,157,.18);
}
.page-special {
	--museum-gap: 2rem;
	--museum-max: 1200px;
}
.video-hero {
	position: relative;
	min-height: 52vh;
	display: grid;
	place-items: center;
	color: #fff;
	text-align: center;
	overflow: clip;
}
.vh-media {
	position: absolute;
	inset: 0;
	z-index: 0;
	background: #0b1630 url('/video/special-hero-poster.jpg') center/cover no-repeat;
}
.vh-video {
	position: absolute;
	inset: 0;
	width: 50%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 60%;
	display: block;
	filter: saturate(1.05);
}
.vh-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.35)),radial-gradient(1200px 360px at 70% 0%, rgba(102,204,255,.22), transparent);
	pointer-events: none;
}
.vh-inner {
	position: relative;
	z-index: 2;
	max-width: 1100px;
	width: 100%;
	padding: 56px 16px 38px;
}
.video-hero h1 {
	margin: 0 0 .5rem;
	font-weight: 800;
	letter-spacing: .2px;
	font-size: clamp(28px, 4.2vw, 56px);
	text-shadow: 0 2px 18px rgba(0,0,0,.45);
}
.video-hero .lead {
	margin: 0 auto;
	max-width: 70ch;
	font-size: clamp(16px, 2vw, 22px);
	opacity: .96;
	text-shadow: 0 1px 10px rgba(0,0,0,.35);
}
.vh-scrollhint {
	margin-top: 1.1rem;
	font-size: 1.5rem;
	opacity: .85;
	animation: vh-bounce 1.8s infinite;
}
@keyframes vh-bounce{
	0%,100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(6px);
	}
}
.split-hero {
	position: relative;
	--sh-height: 42vh;
	--sh-height-mobile: 38vh;
	min-height: var(--sh-height);
	display: grid;
	grid-template-columns: 1fr;
	overflow: clip;
	color: #fff;
}
.sh-inner {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	text-align: center;
	padding: 48px 16px 36px;
	z-index: 3;
}
.split-hero h1 {
	margin: 0 0 .4rem;
	font-weight: 800;
	letter-spacing: .2px;
	font-size: clamp(28px, 4.2vw, 56px);
	text-shadow: 0 2px 18px rgba(0,0,0,.45);
}
.split-hero .lead {
	margin: 0 auto;
	max-width: 70ch;
	font-size: clamp(16px, 2vw, 22px);
	opacity: .96;
	text-shadow: 0 1px 10px rgba(0,0,0,.35);
}
.sh-left, .sh-right {
	position: relative;
	min-height: var(--sh-height);
}
.sh-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 8%;
	display: block;
	filter: saturate(1.05);
}
.sh-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.25)),radial-gradient(1200px 360px at 70% 0%, rgba(102,204,255,.20), transparent);
	z-index: 1;
	pointer-events: none;
}
.sh-right {
	display: none;
	background: #0b1630;
}
.sh-slides {
	position: absolute;
	inset: 0;
	overflow: hidden;
}
.sh-slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	opacity: 0;
	transition: opacity .9s ease;
}
.sh-slide.is-active {
	opacity: 1;
}
.sh-fallback {
	position: absolute;
	inset: 0;
	background: radial-gradient(1200px 360px at 70% 0%, rgba(102,204,255,.15), transparent), linear-gradient(180deg, #0a1732, #020814 70%);
}
.sh-left {
	background: #0b1630 var(--sh-poster) center/cover no-repeat;
}
.mg-arrow {
	position: absolute;
	top: 50%;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 0;
	background: rgba(0,0,0,0.08);
	backdrop-filter: blur(4px);
	box-shadow: 0 2px 10px rgba(0,0,0,0.15);
	color: #333;
	font-size: 20px;
	line-height: 44px;
	text-align: center;
	cursor: pointer;
	z-index: 3;
}
.mg-arrow:focus {
	outline: 2px solid rgba(0,0,0,0.25);
	outline-offset: 2px;
}
.mg-dot.is-active {
	background: rgba(0,0,0,0.55);
}
.swipe-hint {
	position: absolute;
	left: 50%;
	bottom: 14px;
	transform: translateX(-50%);
	z-index: 4;
	display: none;
	pointer-events: none;
}
.swipe-hint .hint-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(0,0,0,0.45);
	color: #fff;
	font-size: 16px;
	line-height: 1;
	box-shadow: 0 6px 18px rgba(0,0,0,0.18);
	animation: hint-fade 1.8s ease-in-out infinite;
}
.swipe-hint .chev {
	font-weight: 700;
	display: inline-block;
	animation: chev-slide 1.8s ease-in-out infinite;
}
.misc-gallery.hint-off .swipe-hint {
	display: none !important;
}
@keyframes hint-fade{
	0%, 100% {
		opacity: .65;
	}
	50% {
		opacity: 1;
	}
}
@keyframes chev-slide{
	0% {
		transform: translateX(0);
	}
	50% {
		transform: translateX(6px);
	}
	100% {
		transform: translateX(0);
	}
}
.misc-gallery, .gallery[data-gallery] {
	position: relative;
}
.misc-gallery .mg-arrow,.gallery[data-gallery] .gallery-nav {
	position: absolute;
	top: 50%;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 0;
	background: rgba(0,0,0,0.08);
	backdrop-filter: blur(4px);
	box-shadow: 0 2px 10px rgba(0,0,0,0.15);
	color: #333;
	font-size: 20px;
	line-height: 44px;
	text-align: center;
	cursor: pointer;
	z-index: 3;
}
.misc-gallery .mg-dots,.gallery[data-gallery] .gallery-dots {
	display: flex;
	gap: 8px;
	justify-content: center;
	align-items: center;
	padding: 10px 0 14px;
}
.misc-gallery .mg-dot,.gallery[data-gallery] .gallery-dots .dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: 0;
	background: rgba(0,0,0,0.25);
	display: inline-block;
	cursor: pointer;
}
.misc-gallery .mg-dot.is-active,.gallery[data-gallery] .gallery-dots .dot.active {
	background: rgba(0,0,0,0.55);
}
.is-touch .misc-gallery .mg-arrow,.is-touch .misc-gallery .mg-dots,.is-touch .gallery[data-gallery] .gallery-nav,.is-touch .gallery[data-gallery] .gallery-dots {
	display: none !important;
}
.is-touch .misc-gallery:not(.hint-off) .swipe-hint,.is-touch .gallery[data-gallery]:not(.hint-off) .swipe-hint {
	display: block;
}
.museum-popup {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: none;
}
.museum-popup.is-open {
	display: block;
}
.popup-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.85);
}
.popup-dialog {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	padding: 2rem;
	outline: none;
	overscroll-behavior: contain;
}
.popup-content {
	max-width: 95vw;
	max-height: 95vh;
	overflow: auto;
	border-radius: 8px;
	box-shadow: 0 0 24px rgba(0,0,0,0.6);
	background: #111;
}
#museum-popup-img {
	display: block;
	width: auto;
	height: auto;
	max-width: 95vw;
	max-height: 95vh;
}
.popup-close {
	position: absolute;
	top: 1rem;
	right: 1rem;
	width: 36px;
	height: 36px;
	border: none;
	border-radius: 50%;
	background: #fff;
	color: #000;
	font-size: 20px;
	line-height: 36px;
	cursor: pointer;
}
.project-sub {
	margin: .25rem 0 0;
	font-size: .92rem;
	line-height: 1.35;
	opacity: .9;
}
.img-badge {
	position: absolute;
	top: .75rem;
	left: .75rem;
	padding: .25rem .5rem;
	font-size: .875rem;
	line-height: 1.1;
	border-radius: .5rem;
	font-weight: 600;
	background: #eee;
	color: #222;
	box-shadow: 0 2px 6px rgba(0,0,0,.12);
}
.img-badge-current {
	background: #116149;
	color: #fff;
	border: 1px solid #0c4a3a;
}
.tline-year.is-current {
	background: #116149 !important;
	background-image: none !important;
	color: #fff !important;
	width: 70px;
	height: 70px;
	border-radius: 50%;
	display: grid;
	place-items: center;
	border: 6px solid #f8faff;
	box-shadow: 0 0 0 6px #e6ffef, 0 8px 26px rgba(17,97,73,.24);
}
.split-hero.no-split {
	display: block;
}
.split-hero.no-split .sh-left {
	width: 100%;
}
.split-hero.no-split .sh-video,.split-hero.no-split .sh-left img.sh-poster {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.split-hero.no-split .sh-right {
	display: none !important;
}
.page-home .home-fold {
	min-height: calc(100dvh - var(--header-h));
	display: grid;
	grid-template-rows: auto 1fr auto;
}
.page-home .split-hero {
	--sh-height: 34vh;
	--sh-height-mobile: 34vh;
}
.page-home .desktop-belt {
	padding-bottom: 0 !important;
}
body:has(.page-home) {
	padding-bottom: 0 !important;
}
.page-home .home-fold > :last-child {
	margin-bottom: 0 !important;
}
.card-img-link {
	display: block;
	line-height: 0;
}
.card-img-link:focus-visible {
	outline: 2px solid var(--link, #2750b8);
	outline-offset: 2px;
}
.card-title a {
	text-decoration: none;
}
.card-title a:hover {
	text-decoration: underline;
}
.page-home .sh-video {
	display: block !important;
}
.sh-video::-webkit-media-controls-start-playback-button {
	display: none!important;
}
.sh-video::-webkit-media-controls-overlay-play-button {
	display: none!important;
}
.vkv-no-motion .split-hero .sh-video {
	display: none!important;
}
.vkv-no-motion .split-hero .sh-right {
	display: none!important;
}
.vkv-no-motion .split-hero .sh-poster {
	display: block!important;
}
.page-special .about-card .card-img {
	aspect-ratio: 3 / 4;
	width: 100%;
	height: auto;
	max-height: none;
	object-fit: cover;
	object-position: center center;
	display: block;
	background: #f1f5f9;
}
.side-cats .side-head {
	position: sticky;
	top: 0;
	background: #fff;
	padding: 10px 12px 12px;
	z-index: 5;
	border-bottom: 1px solid #e7eefc;
	font-weight: 600;
	box-shadow: 0 1px 0 rgba(39,80,184,.03);
}
.catalog-sidebar .cat-item.is-open .cat-models,.catalog-sidebar .cat-item.active .cat-models {
	display: block;
}
.catalog-sidebar .cat-item > a::after {
	content: "▾";
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%) rotate(-90deg);
	font-size: .85em;
	opacity: .6;
}
.catalog-sidebar .cat-item.is-open > a::after,.catalog-sidebar .cat-item.active > a::after {
	transform: translateY(-50%) rotate(0deg);
}
.side-cats {
	position: relative;
}
.side-cats ul {
	margin: 0;
	padding: 8px 0 14px;
	list-style: none;
}
.catalog-sidebar .cat-item > a:hover {
	background: #e9f1ff;
	box-shadow: inset 0 0 0 2px #dfe8ff;
}
.catalog-sidebar .cat-item.active > a,.catalog-sidebar .cat-item.is-open > a {
	background: #e9f1ff;
	box-shadow: inset 0 0 0 2px #9db7ff;
}
.catalog-sidebar .cat-item.active > a::after,.catalog-sidebar .cat-item.is-open > a::after {
	transform: translateY(-50%) rotate(0deg);
	opacity: .85;
}
.catalog-sidebar .cat-item.active .cat-models,.catalog-sidebar .cat-item.is-open .cat-models {
	display: block;
}
.catalog-sidebar .cat-models li a.active {
	background: #eef4ff;
	box-shadow: inset 0 0 0 2px #cfe0ff;
	font-weight: 600;
}
.side-cats::before {
	content: "";
	position: sticky;
	top: 0;
	height: 1px;
	display: block;
	background: linear-gradient(#fff, rgba(255,255,255,0));
	z-index: 4;
}
.rb-banner {
	position: relative;
	width: 100%;
	display: block;
	overflow: hidden;
}
.rb-media {
	position: static !important;
	inset: 0;
	overflow: hidden;
	background: #000;
}
.rb-video, .rb-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.rb-text {
	position: relative;
	z-index: 2;
	max-width: 1100px;
	margin: 0 auto;
	padding: 1rem;
	color: #fff;
	text-shadow: 0 2px 16px rgba(0,0,0,.5);
}
.rb-text h1 {
	font-size: clamp(1.8rem, 4vw, 3rem);
	margin: 0 0 .4rem;
}
.rb-text .lead {
	font-size: clamp(1rem, 2vw, 1.25rem);
	margin: 0 0 .8rem;
}
.rb-cta {
	margin-top: .6rem;
}
.rb-video {
	z-index: 1;
}
.rb-image {
	z-index: 0;
}
.rb-media.is-still .rb-video {
	display: none !important;
}
.rb-media .rb-image {
	display: none;
}
.rb-media.is-still .rb-image {
	display: block;
}
@keyframes rb-bob{
	0%,100%{
		transform: translate(-50%, 0);
	}
	50% {
		transform: translate(-50%, 6px);
	}
}
@keyframes rb-bob-icon{
	0%,100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(6px);
	}
}
.card-flags,img.card-flags,svg.card-flags {
	height: 1.4em;
	width: 2.1em;
	vertical-align: -0.15em;
	display: inline-block;
	object-fit: cover;
	border-radius: 2px;
	line-height: 0;
}
.price-badge {
	position: absolute;
	top: 2px;
	left: 2px;
	z-index: 2;
	background: #144da7;
	color: #fff;
	font-weight: 700;
	font-size: 10px;
	line-height: 1;
	padding: 4px 6px;
	border-radius: 999px;
	box-shadow: 0 6px 18px rgba(0,0,0,.18);
	pointer-events: none;
	user-select: none;
	white-space: nowrap;
}
.catalog-card .price-pill {
	align-self: center;
	margin-bottom: 8px;
}
.card.about-card {
	display: flex;
	flex-direction: column;
}
.card.about-card .card-body {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
}
.card.about-card .card-actions {
	margin-top: auto;
	display: flex;
	justify-content: left;
}
.special-grid .card.about-card {
	height: 100%;
}
.cat-section-title {
	font-weight: 800;
	font-size: 1.35rem;
	line-height: 1.2;
	color: #0b3b9d;
	margin: 28px 0 14px;
	padding: 8px 10px;
	border-radius: 12px;
	background: linear-gradient(180deg, rgba(11,91,211,.06), rgba(255,255,255,0));
	scroll-margin-top: 90px;
}
.cat-section {
	margin-bottom: 18px;
}
.catalog-card .card-img-link img {
	display: block;
	width: 100%;
	height: 200px;
	object-fit: contain;
}
.catalog-card p {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: 3.6em;
}
footer.site-footer {
	border-top: 0;
	box-shadow: 0 -3px 12px rgba(0,0,0,.09);
}
.menu > li > a:hover, .menu > li.active > a {
	background: rgba(0,62,160,0.06);
	border-color: var(--blue);
}
.sub-menu a.active {
	font-weight: 700;
	text-decoration: underline;
}
.has-children {
	position: relative;
}
.submenu-toggle {
	position: absolute;
	right: 0.5em;
	top: 0;
	bottom: 0;
	width: 2em;
	background: transparent;
	border: none;
	cursor: pointer;
}
.submenu-toggle::after {
	content: '▾';
	color: var(--blue);
	font-size: 1.2em;
	transition: transform .2s;
}
.has-children.open > .submenu-toggle::after {
	transform: rotate(180deg);
}
.has-children.open > .sub-menu {
	display: block;
}
.main-nav .sub-menu {
	display: none;
}
.rb-hint {
	color: #fff;
	position: absolute;
	left: 50%;
	bottom: 18px;
	transform: translateX(-50%);
	width: 28px;
	height: 28px;
	pointer-events: none;
	opacity: .85;
	animation: rb-bob 1.2s ease-in-out infinite;
}
@keyframes rb-bob{
	0%,100%{
		transform: translate(-50%,0);
	}
	50%{
		transform: translate(-50%,-6px);
	}
}
.spec-row--price {
	background: #eaf2ff;
	border: 1px solid #cfe0ff;
	box-shadow: 0 0 0 2px #f4f8ff inset;
}
.spec-row--price dt {
	font-weight: 800;
	color: #0b5bd3;
}
.spec-row--price dd {
	font-weight: 800;
	font-variant-numeric: tabular-nums;
}
.spec-row--option {
	background: #f8fbff;
	border: 1px dashed #cfe0ff;
}
.spec-row--option dt {
	font-weight: 700;
}
.spec-row--option dd {
	font-weight: 700;
}
.misc-gallery .mg-slide video {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	display: block;
}
.rb-media > .rb-video {
	display: block;
	object-fit: cover;
}
.rb-media > .rb-image {
	display: block;
}
.rb-media.end-overlay {
	position: relative !important;
}
.rb-media.end-overlay > .rb-image {
	display: block;
	position: absolute;
	inset: 0;
	object-fit: cover;
	opacity: 0;
	transition: opacity 300ms ease;
	pointer-events: none;
}
.misc-gallery:hover .mg-arrow {
	opacity: 1;
}
.misc-gallery .swipe-hint {
	display: none;
}
.is-touch .misc-gallery:not(.hint-off) .swipe-hint {
	display: block;
}
.museum-lightbox .mlb-frame {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(12px, 2vw, 24px);
	max-width: 96vw;
	max-height: 92vh;
	margin: 0 auto;
	box-sizing: border-box;
	height: 90vh;
}
.museum-lightbox .mlb-figure {
	margin: 0;
	line-height: 0;
	max-width: 100%;
	max-height: 100%;
	align-items: center;
	justify-content: center;
}
#mlb-img,#mlb-video {
	display: block;
	max-width: 85vw;
	max-height: 80vh;
	width: auto;
	height: auto;
	object-fit: contain;
}
.museum-lightbox .mlb-btn.mlb-prev,.museum-lightbox .mlb-btn.mlb-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
}
.museum-lightbox .mlb-btn.mlb-prev {
	left: max(12px, 2vw);
}
.museum-lightbox .mlb-btn.mlb-next {
	right: max(12px, 2vw);
}
.museum-lightbox .mlb-frame .mlb-btn {
	min-width: 36px;
	min-height: 36px;
}
#catalog-model-gallery .mg-slide {
	display: flex !important;
	align-items: center;
	justify-content: center;
	padding: 6px;
	height: 100%;
}
#catalog-model-gallery .mg-viewport {
	display: block;
}
#catalog-model-gallery .mg-track {
	height: 100%;
}
#catalog-model-gallery .mg-slide > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}
#catalog-model-gallery .mg-slide img {
	display: block;
	margin: auto;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}
.catalog-sidebar .side-cats::after {
	content: "";
	display: block;
	height: 120px;
}
.info-box {
	background-color: #e8f1ff;
	border-left: 4px solid #0057c2;
	border-radius: 8px;
	padding: 10px 15px;
	margin: 20px 0;
	color: #002a66;
	font-size: 0.95rem;
}
.info-box strong {
	color: #0046b3;
}
.museum-lightbox .mlb-btn {
	touch-action: manipulation;
}
@media (max-width: 480px) {
	.logo-img {
		height: 54px;
	}
}
@media (prefers-reduced-motion: no-preference) {
	.lang-switch .lang-btn {
		transition: background-color .15s, color .15s, border-color .15s;
	}
}
@media (forced-colors: active) {
	.lang-switch .lang-btn {
		border-color: ButtonText;
	}
	.lang-switch .lang-btn.is-active,.lang-switch .lang-btn.active {
		background: Highlight;
		color: HighlightText;
		border-color: Highlight;
	}
}
@media (max-width: 991.98px) {
	.burger {
		display: block;
	}
	.nav-wrap {
		position: fixed;
		inset: 100px 0 auto 0;
		background: #fff;
		display: block;
		padding: 12px;
		border-top: 3px solid var(--blue-dark);
		box-shadow: 0 12px 28px rgba(0,0,0,.12);
		transform: translateY(-100%);
		opacity: 0;
		pointer-events: none;
		transition: transform .25s ease, opacity .2s ease;
		z-index: 999;
	}
	.nav-wrap.open {
		transform: translateY(0);
		opacity: 1;
		pointer-events: auto;
	}
	.menu {
		display: block;
	}
	.menu > li {
		margin-bottom: .4rem;
	}
	.menu > li > a {
		display: block;
		background: #fff;
		color: var(--blue);
		border: 1px solid var(--blue);
	}
	.lang-switch {
		margin-top: .6rem;
		display: flex;
		gap: .5rem;
	}
}
@media (max-width: 900px) {
	.home-promo {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 700px) {
	.page-banner {
		height: 96px;
	}
}
@media (max-width: 1100px) {
	.card-grid {
		grid-template-columns: repeat(2, minmax(0,1fr));
	}
}
@media (max-width: 640px) {
	.card-grid {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 480px) {
	.card-img {
		max-height: 54vw;
	}
}
@media (max-width: 800px) {
	.footer-inner {
		grid-template-columns: 1fr;
		min-height: var(--footer-h);
		padding: 10px 12px;
		gap: 8px;
	}
	.footer-col.small {
		font-size: .85rem;
	}
	:root {
		--footer-h: 56px;
	}
	body {
		padding-bottom: 0 !important;
	}
	.site-footer {
		position: static !important;
	}
}
@media (max-width: 800px) {
	.footer-inner {
		text-align: center;
	}
	.site-footer .social-link,.site-footer .instagram-link,.site-footer .footer-social a {
		justify-content: center;
	}
}
@media (max-width: 800px) {
	.footer-inner {
		grid-template-columns: 1fr;
		text-align: left;
		padding: 10px 16px;
		gap: 3px;
	}
	.ig-link {
		justify-content: flex-start;
		padding-left: 4px;
	}
}
@media (max-width: 700px) {
	.map-dialog {
		margin: 10vh 12px;
	}
	.map-frame {
		height: 320px;
	}
}
@media (max-width:768px) {
	.desktop-only {
		display: none;
	}
	.mobile-only {
		display: block;
	}
}
@media (max-width: 900px) {
	.kd-grid {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 900px) {
	.kd-grid {
		grid-template-columns: 1fr;
		grid-template-areas: "desc""specs";
		row-gap: 18px;
	}
}
@media (min-width: 1100px) {
	.spec-card {
		padding: 16px;
	}
	.spec-row {
		padding: 9px 12px;
	}
}
@media (max-width: 900px) {
	.kd-col.kd-specs .spec-card {
		position: static;
	}
}
@media (max-width: 768px) {
	.filter-bar {
		position: fixed;
		left: 50%;
		bottom: 12px;
		transform: translateX(-50%);
		width: calc(100% - 24px);
		max-width: 560px;
		z-index: 1000;
		background: rgba(255,255,255,.96);
		border: 1px solid #dfe6f5;
		border-radius: 14px;
		box-shadow: 0 10px 28px rgba(0,0,0,.12);
		padding: 8px;
		display: flex;
		gap: 8px;
		align-items: center;
		justify-content: center;
	}
	.filter-bar form {
		display: flex;
		gap: 8px;
		align-items: center;
		justify-content: center;
		width: 100%;
	}
	.filter-bar select {
		flex: 0 0 auto;
		min-width: 140px;
		max-width: 48%;
		padding: 8px 12px;
		border-radius: 999px;
		border: 1px solid #cfe0ff;
		background: rgba(11,91,211,.08);
		color: #0b5bd3;
		font-weight: 700;
		text-align: center;
		appearance: none;
		-webkit-appearance: none;
	}
	.filter-bar select:focus {
		outline: none;
		box-shadow: 0 0 0 2px rgba(11,91,211,.25);
	}
	.catalog-content {
		padding-bottom: 100px;
	}
}
@media (max-width: 768px) {
	.filter-bar {
		position: fixed;
		top: auto;
		bottom: 12px;
		left: 50%;
		transform: translateX(-50%);
		width: calc(100% - 24px);
		max-width: 560px;
		height: auto;
		z-index: 1000;
		background: rgba(255,255,255,.96);
		border: 1px solid #dfe6f5;
		border-bottom: 0;
		border-radius: 14px;
		box-shadow: 0 10px 28px rgba(0,0,0,.12);
		padding: 8px;
		display: flex;
		gap: 8px;
		align-items: center;
		justify-content: center;
	}
	.filter-bar form {
		display: flex;
		gap: 8px;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: auto;
	}
	.filter-bar select {
		flex: 0 0 auto;
		min-width: 140px;
		max-width: 48%;
		padding: 8px 12px;
		border-radius: 999px;
		border: 1px solid #cfe0ff;
		background: rgba(11,91,211,.08);
		color: #0b5bd3;
		font-weight: 700;
		text-align: center;
		appearance: none;
		-webkit-appearance: none;
	}
	.catalog-content {
		padding-bottom: 100px;
	}
}
@media (max-width: 768px) {
	.misc-gallery .mg-arrow {
		width: 36px;
		height: 36px;
		font-size: 18px;
	}
}
@media (max-width: 960px) {
	.museum-card,.museum-card.reversed {
		grid-template-columns: 1fr;
	}
	.museum-card-media {
		height: 40vw;
		min-height: 220px;
		max-height: 360px;
	}
}
@media (max-width: 520px) {
	.museum-card-media {
		height: 48vw;
		min-height: 200px;
	}
}
@media (max-width: 960px) {
	.museum-card-media img {
		max-height: 220px;
	}
}
@media (max-width: 520px) {
	.museum-card-media img {
		max-height: 200px;
	}
}
@media (min-width: 1280px) {
	.museum-card {
		grid-template-columns: 1.9fr 1fr;
	}
	.museum-card.reversed {
		grid-template-columns: 1fr 1.9fr;
	}
	.museum-card-media img {
		max-height: 360px;
	}
}
@media (max-width: 960px) {
	.museum-card-media img {
		max-height: 240px;
	}
}
@media (max-width: 520px) {
	.museum-card-media img {
		max-height: 220px;
	}
}
@media (min-width: 1280px) {
	.museum-card {
		grid-template-columns: minmax(520px, 1.5fr) minmax(520px, 1fr);
	}
	.museum-card.reversed {
		grid-template-columns: minmax(520px, 1fr) minmax(520px, 1.5fr);
	}
}
@media (max-width: 1024px) {
	.tcard-media img {
		max-height: 300px;
	}
}
@media (max-width: 820px) {
	.timeline-grid {
		grid-template-columns: 1fr;
	}
	.timeline-grid::before {
		display: none;
	}
	.tline-item {
		display: block;
	}
	.tline-col.node {
		justify-content: flex-start;
		margin: 0 0 .6rem 0;
	}
	.tline-node {
		width: 62px;
		height: 62px;
	}
	.tline-year {
		font-size: .9rem;
	}
	.tline-col.content, .tline-col.spacer {
		grid-column: auto;
	}
	.tcard-media img {
		max-height: 260px;
	}
}
@media (max-width: 520px) {
	.tcard-media img {
		max-height: 220px;
	}
}
@media (min-width: 1024px) {
	#mlb-cap {
		font-size: 1.15rem;
	}
}
@media (max-width: 680px) {
	#mlb-cap {
		bottom: 6px;
		padding: .5rem .75rem;
		border-radius: 8px;
		max-width: 96vw;
	}
}
@media (min-width: 1024px) {
	#mlb-cap {
		font-size: 1.15rem;
	}
}
@media (max-width: 680px) {
	#mlb-cap {
		max-width: 96vw;
	}
}
@media (max-width: 680px) {
	.museum-lightbox-trigger {
		pointer-events: none;
		cursor: default;
	}
}
@media (max-width: 900px) {
	.desktop-belt {
		display: none;
	}
	.belt-mobile {
		display: block;
		max-width: 1100px;
		margin: 15px auto 24px;
		padding: 0 12px;
	}
	.belt-mobile .card-grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}
}
@media (max-width: 900px) {
	.belt-mobile .card-grid {
		grid-template-columns: 1fr;
		gap: 14px;
	}
	.belt-mobile .about-card {
		min-height: 280px;
		border-radius: 16px;
		box-shadow: 0 14px 26px rgba(0,0,0,.10);
		background: #fff;
	}
	.belt-mobile .about-card .card-img {
		height: 180px;
	}
}
@media (max-width: 900px) {
	.belt-mobile .about-card img.card-img {
		width: 100%;
		max-height: 192px;
		height: auto;
		object-fit: cover;
		display: block;
	}
}
@media (max-width: 680px) {
	.prod-badges {
		top: 8px;
		right: 8px;
		gap: 5px;
		max-width: 80%;
	}
	.prod-badge {
		font-size: .75rem;
		padding: .24rem .5rem;
	}
}
@media (min-width: 901px) {
	.kd-hero {
		position: relative;
	}
	.kd-hero .prod-badges {
		top: 12px;
		left: 50%;
		right: auto;
		transform: translateX(calc(-50% + min(8vw, 200px)));
		justify-content: center;
		gap: 8px;
		max-width: 80%;
		z-index: 30;
	}
	.kd-hero .prod-badge {
		font-size: .92rem;
		padding: .40rem .80rem;
		background: rgba(255,255,255,.96);
		box-shadow: 0 8px 18px rgba(11,59,157,.20);
	}
}
@media (max-width: 900px) {
	.video-hero {
		min-height: 40vh;
	}
	.vh-inner {
		padding: 44px 14px 28px;
	}
}
@media (min-width: 1200px), (min-aspect-ratio: 16/9) {
	.split-hero {
		grid-template-columns: 1fr 1fr;
	}
	.sh-left {
		grid-column: 1;
	}
	.sh-right {
		grid-column: 2;
		display: block;
	}
	.sh-inner {
		pointer-events: none;
	}
}
@media (max-width: 900px) {
	.split-hero {
		min-height: var(--sh-height-mobile);
	}
	.sh-left, .sh-right {
		min-height: var(--sh-height-mobile);
	}
}
@media (hover:hover) {
	.mg-arrow:hover {
		transform: scale(1.06);
		background: rgba(0,0,0,0.12);
	}
}
@media (hover:none) and (pointer:coarse) {
	.mg-arrow, .mg-dots {
		display: none !important;
	}
	.misc-gallery:not(.hint-off) .swipe-hint {
		display: block;
	}
}
@media (hover:hover) {
	.misc-gallery .mg-arrow:hover,.gallery[data-gallery] .gallery-nav:hover {
		transform: scale(1.06);
		background: rgba(0,0,0,0.12);
	}
}
@media (hover:none) and (pointer:coarse) {
	.misc-gallery .mg-arrow,.misc-gallery .mg-dots,.gallery[data-gallery] .gallery-nav,.gallery[data-gallery] .gallery-dots {
		display: none !important;
	}
	.misc-gallery:not(.hint-off) .swipe-hint,.gallery[data-gallery]:not(.hint-off) .swipe-hint {
		display: block;
	}
}
@media (max-width: 680px) {
	.museum-lightbox .mlb-frame {
		grid-template-columns: 1fr;
		padding: 3vh 3vw;
		place-items: center;
	}
	.museum-lightbox .mlb-figure {
		position: relative;
		width: 100%;
		display: grid;
		justify-items: center;
	}
	.museum-lightbox #mlb-img {
		max-width: 94vw;
		max-height: 78vh;
		margin: 0 auto;
		display: block;
	}
	.museum-lightbox .mlb-prev,.museum-lightbox .mlb-next {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: 36px;
		height: 36px;
		font-size: 1.4rem;
		box-shadow: 0 6px 18px rgba(0,0,0,.25);
	}
	.museum-lightbox .mlb-prev {
		left: 6vw;
	}
	.museum-lightbox .mlb-next {
		right: 6vw;
	}
	.museum-lightbox .mlb-close {
		top: 10px;
		right: 10px;
		width: 36px;
		height: 36px;
		font-size: 1.3rem;
	}
}
@media (max-width: 680px) {
	.museum-lightbox .mlb-figure {
		position: relative;
		overflow: visible;
	}
	.museum-lightbox .mlb-prev,.museum-lightbox .mlb-next {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		z-index: 50;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 36px;
		height: 36px;
	}
	.museum-lightbox .mlb-prev {
		left: 6vw;
		right: auto;
		opacity: 1;
		visibility: visible;
	}
	.museum-lightbox .mlb-next {
		right: 6vw;
		left: auto;
	}
}
@media (hover:hover) {
	.popup-close:hover {
		background: #eee;
	}
}
@media (max-width: 800px) {
	.page-home .home-fold {
		min-height: auto;
		grid-template-rows: auto auto auto;
	}
}
@media (max-width: 800px) {
	.page-home .home-fold {
		min-height: auto;
		padding-bottom: 0;
		grid-template-rows: auto auto auto;
	}
}
@media (min-width: 701px) {
	.rb-banner {
		height: var(--rb-vh-d, 70vh);
	}
}
@media (max-width: 700px) {
	.rb-banner {
		height: var(--rb-vh-m, 60vh);
	}
}
@media (min-width: 701px) {
	.rb-video, .rb-image {
		object-position: var(--rb-pos-d, 50% 50%);
		transform: scale(var(--rb-zoom-d, 1));
		transform-origin: center center;
	}
}
@media (max-width: 700px) {
	.rb-video, .rb-image {
		object-position: var(--rb-pos-m, 50% 50%);
		transform: scale(var(--rb-zoom-m, 1));
		transform-origin: center center;
	}
}
@media (min-width: 701px) {
	.rb-text {
		transform: translateY(var(--rb-texty-d, 0px));
	}
}
@media (max-width: 700px) {
	.rb-text {
		transform: translateY(var(--rb-texty-m, 0px));
	}
}
@media (prefers-reduced-motion: reduce) {
	.rb-video {
		display: none !important;
	}
	.rb-image {
		display: block !important;
	}
}
@media (max-width: 700px) {
	.price-badge {
		font-size: .9rem;
		padding: 3px 6px;
	}
}
@media (min-width: 1200px) {
	.catalog-grid {
		grid-template-columns: repeat(auto-fit, minmax(260px, 360px));
		gap: 20px;
	}
}
@media (min-width: 992px) {
	.submenu-toggle {
		display: none;
	}
	.has-children > .sub-menu {
		display: block;
	}
}
@media (max-width: 991.98px) {
	.main-nav .menu > li + li {
		margin-top: 8px;
	}
	.main-nav .menu > li > a {
		display: block;
		font-size: 18px;
		line-height: 1.2;
		padding: 14px 3.5rem 14px 1rem;
		min-height: 52px;
		border: 2px solid var(--blue);
		border-radius: 10px;
		background: #fff;
	}
	.main-nav .menu > li.active > a {
		background: rgba(0,62,160,.06);
	}
	.main-nav .submenu-toggle {
		position: absolute;
		right: .5rem;
		top: 50%;
		transform: translateY(-50%);
		width: 44px;
		height: 44px;
		border: 2px solid var(--blue);
		border-radius: 10px;
		background: #fff;
	}
	.main-nav .submenu-toggle::after {
		content: '▾';
		font-size: 20px;
		display: inline-block;
		transition: transform .2s ease;
		line-height: 1;
	}
	.main-nav .has-children.open > .submenu-toggle::after {
		transform: rotate(180deg);
	}
	.main-nav .has-children.open > a {
		background: rgba(0,62,160,.06);
		border-color: var(--blue);
	}
	.main-nav .sub-menu {
		display: none;
		padding: 6px 0 10px 0;
		margin: 6px 0 0 0;
		border-left: 3px solid var(--blue);
		margin-left: 1rem;
	}
	.main-nav .has-children.open > .sub-menu {
		display: block;
	}
	.main-nav .sub-menu li a {
		display: block;
		font-size: 16px;
		padding: 10px 1rem;
		border-radius: 8px;
	}
	.main-nav .sub-menu a.active {
		font-weight: 700;
		text-decoration: underline;
		background: rgba(0,62,160,.04);
	}
}
@media (max-width: 991.98px) {
	.main-nav .has-children.open > .sub-menu {
		display: block;
	}
	.main-nav .submenu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}
}
@media (min-width: 992px) {
	.main-nav .submenu-toggle {
		display: none;
	}
	.main-nav .has-children {
		position: relative;
	}
	.main-nav .has-children > .sub-menu {
		display: none;
		position: absolute;
		left: 0;
		top: 100%;
		min-width: 220px;
		background: #fff;
		border: 1px solid rgba(0,0,0,.08);
		border-radius: 10px;
		padding: .4rem 0;
		box-shadow: 0 10px 24px rgba(0,0,0,.08);
		z-index: 20;
	}
	.main-nav .has-children:hover > .sub-menu,.main-nav .has-children:focus-within > .sub-menu {
		display: block;
	}
}
@media (max-width: 991.98px) {
	.main-nav .menu > li.active > a {
		background: rgba(0,62,160,.10);
		border-color: var(--blue);
		font-weight: 700;
	}
	.main-nav .menu > li.has-children.open > a {
		background: rgba(0,62,160,.06);
		border-color: var(--blue);
	}
	.main-nav .sub-menu {
		background: #fff;
		border: 1px solid rgba(0,0,0,.08);
		border-radius: 10px;
		box-shadow: 0 10px 24px rgba(0,0,0,.08);
		padding: .25rem 0;
		margin: .5rem 0 0 0;
	}
	.main-nav .sub-menu li a {
		display: block;
		padding: .75rem 1rem;
		font-size: 16px;
		border-radius: 8px;
	}
	.main-nav .sub-menu a.active {
		background: rgba(0,62,160,.10);
		font-weight: 700;
		position: relative;
	}
	.main-nav .sub-menu a.active::before {
		content: '';
		position: absolute;
		left: 8px;
		top: 50%;
		transform: translateY(-50%);
		width: 4px;
		height: 18px;
		background: var(--blue);
		border-radius: 2px;
	}
	.main-nav .submenu-toggle {
		border: 2px solid var(--blue);
		border-radius: 10px;
		width: 44px;
		height: 44px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		background: #fff;
	}
	.main-nav .submenu-toggle::after {
		content: '▾';
		font-size: 20px;
		transition: transform .2s ease;
		line-height: 1;
		color: var(--blue);
	}
	.main-nav .has-children.open > .submenu-toggle::after {
		transform: rotate(180deg);
	}
}
@media (hover:hover) and (pointer:fine) {
	.museum-lightbox .mlb-btn.mlb-prev,.museum-lightbox .mlb-btn.mlb-next {
		opacity: 0;
		transition: opacity .2s ease;
	}
	.museum-lightbox.is-open .mlb-frame:hover .mlb-btn.mlb-prev,.museum-lightbox.is-open .mlb-frame:hover .mlb-btn.mlb-next {
		opacity: 1;
	}
}
.rb-banner{
	background:#000;
}
.rb-media, .rb-video, .rb-image{
	background:#000;
}
.misc-gallery .mg-prev,.gallery[data-gallery] .gallery-nav.prev {
	left: 12px;
	transform: rotate(90deg);
}
.misc-gallery .mg-prev:hover {
	transform: rotate(90deg);
}
.misc-gallery .mg-next,.gallery[data-gallery] .gallery-nav.next {
	right: 12px;
	transform: rotate(-90deg);
}
.misc-gallery .mg-next:hover {
	transform: rotate(-90deg);
}
.card{
	background:var(--card);
	border-radius:14px;
	box-shadow:var(--elev-1);
	transition:transform .18s ease, box-shadow .18s ease;
	will-change:transform;
	position:relative;
}
.card::after{
	/* hairline */
	content:"";
	position:absolute;
	inset:0;
	border-radius:14px;
	box-shadow:inset 0 0 0 1px var(--hair);
	pointer-events:none;
}
.card:hover{
	transform:translateY(-2px);
	box-shadow:var(--elev-2);
}
.hero, .figure img{
	content-visibility:auto;
	contain-intrinsic-size: 720px 405px;
}
img{
	image-rendering:auto;
}
/* Flytta positioneringen till containern */
.price-badges{
	position:absolute;
	top:10px;
	left:10px;
	display:flex;
	flex-wrap:wrap;
	gap:6px;
	z-index:3;
	pointer-events:none;
	/* om de inte ska vara klickbara */
}
.price-badge{
	position:static;
	pointer-events:auto;
}
/* återställ från ev. absolut */
/* Stil för överstruken resp. nupris */
.price-badge--was{
	text-decoration:line-through;
	opacity:.8;
}
.price-badge--now{
	font-weight:800;
}
/* Om du tidigare hade margin på .price-badge: ta bort, vi använder gap */
.price-badge{
	margin:0;
}
.carbon-info {
	margin: 16px 0 18px;
	padding: 12px 14px;
	background: #fffbeb;
	border-left: 4px solid #f59e0b;
	border-radius: 10px;
	box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}
.carbon-info-title {
	font-weight: 700;
	color: #92400e;
	margin: 0 0 6px;
}
.carbon-info-text {
	margin: 0 0 10px;
	color: #3f3f46;
}
.carbon-info-btn {
	display: inline-block;
	font-weight: 600;
	font-size: 0.95rem;
	padding: 7px 12px;
	border-radius: 999px;
	border: 1px solid #fbbf24;
	background: rgba(250,204,21,0.12);
	color: #78350f;
	text-decoration: none;
}
.carbon-info-btn:hover {
	background: rgba(250,204,21,0.22);
}
/* Pickup/ej postleverans – röd varning */
.order-cta--pickup {
	background: #fef2f2;
	/* ljusröd bakgrund */
	border-left-color: #dc2626;
	/* röd kant (om du har border-left på .order-cta) */
}
.order-cta--pickup .order-cta-title {
	color: #b91c1c;
	/* mörkare röd rubrik */
}
.order-cta--pickup .order-btn {
	background: #dc2626;
	border-color: #dc2626;
}
.order-cta--pickup .order-btn:hover {
	background: #b91c1c;
	border-color: #b91c1c;
}
.page-image-archive {
	background: #020813;
	color: #f9fafb;
}
.page-image-archive .page-banner {
	background:radial-gradient(1200px 320px at 70% 0%, rgba(102,204,255,0.25), transparent),linear-gradient(180deg, #020813, #050b16);
	border-bottom-color: rgba(255,255,255,0.08);
}
.page-image-archive .contact-card.info-box {
	background: rgba(15,23,42,0.92);
	border-color: #38bdf8;
	color: #e5e7eb;
}
.page-image-archive .muted {
	color: #cbd5f5;
}
/* Masonry-liknande layout via columns */
.image-archive-grid {
	column-count: 3;
	column-gap: 16px;
}
@media (max-width: 960px) {
	.image-archive-grid {
		column-count: 2;
	}
}
@media (max-width: 640px) {
	.image-archive-grid {
		column-count: 1;
	}
}
.image-archive-item {
	break-inside: avoid;
	-webkit-column-break-inside: avoid;
	margin-bottom: 16px;
}
.image-archive-inner {
	position: relative;
	overflow: hidden;
	border-radius: 14px 14px 0 0;
	background: #020617;
}
.image-archive-media {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	transition:transform 0.25s ease,box-shadow 0.25s ease,filter 0.25s ease;
}
/* Hover: växer och snurrar lite */
.image-archive-inner:hover .image-archive-media {
	transform: scale(1.05) rotate(1.5deg);
	box-shadow: 0 14px 28px rgba(0,0,0,0.55);
	filter: saturate(1.05);
}
.image-archive-caption {
	padding: 8px 10px 10px;
	font-size: 0.85rem;
	color: #e5e7eb;
	background: linear-gradient(to bottom, rgba(15,23,42,0.96), rgba(15,23,42,1));
	border-radius: 0 0 14px 14px;
}
.image-archive-summary {
	font-weight: 500;
	margin-bottom: 2px;
}
.image-archive-meta {
	font-size: 0.8rem;
	opacity: 0.85;
}
/* Upload-form styling */
.image-upload-form {
	margin-top: 10px;
	margin-bottom: 20px;
}
.image-upload-form .upload-field {
	display: block;
	padding: 10px 12px;
	border-radius: 10px;
	border: 1px dashed #9ca3af;
	background: #f9fafb;
	cursor: pointer;
	margin-bottom: 10px;
}
.image-upload-form .upload-field span {
	display: block;
	font-weight: 600;
	margin-bottom: 4px;
}
.image-upload-form input[type="file"],.image-upload-form input[type="text"] {
	display: block;
	width: 100%;
}
.image-upload-status {
	margin: 8px 0 0;
	font-size: 0.9rem;
}
.image-upload-status.error {
	color: #b91c1c;
}
.image-upload-status.ok {
	color: #166534;
}
.page-image-archive .info-box .image-archive-upload-link {
	color: #7dd3fc;
	text-decoration: underline;
}
.page-image-archive .info-box .image-archive-upload-link:hover {
	text-decoration: none;
	filter: brightness(1.1);
}
.page-image-archive .info-box {
	background: linear-gradient(135deg,#020617,#111827);
	border-radius: 18px;
	border: 1px solid rgba(148,163,184,0.40);
	box-shadow: 0 18px 45px rgba(15,23,42,0.75);
	color: #e5e7eb;
}
.page-image-archive .info-box .section-title {
	color: #f9fafb;
}
.page-image-archive .info-box .muted {
	color: #c7d2fe;
}
.page-image-archive .info-box p {
	color: #e5e7eb;
}
.page-image-archive .info-box .image-archive-upload-link {
	color: #7dd3fc;
	text-decoration: underline;
}
.page-image-archive .info-box .image-archive-upload-link:hover {
	text-decoration: none;
	filter: brightness(1.1);
}
