/**
 * Starby Header — Magazine Split
 * Egen namnrymd .shdr för att undvika krockar med starby-menus .starby-header.
 */

.shdr {
	--shdr-teal: #304E4D;
	--shdr-teal-deep: #162928;
	--shdr-cream: #F2EDD9;
	--shdr-cream-light: #F8F6F1;
	--shdr-rust: #B85A3A;
	--shdr-rust-dark: #9A4A2F;
	--shdr-gold: #BEAA76;
	--shdr-gold-light: #D4C499;
	--shdr-text: #2D2D2D;
	--shdr-text-muted: #6B6B6B;

	/* Defaults för meny-typografi (kan överskrivas inline från BB) */
	--shdr-meny-line-height: 1.4;
	--shdr-meny-letter-spacing: 0;
	--shdr-meny-text-transform: none;

	/* Defaults för etikett-typografi (MENY/SÖK/BOKA) */
	--shdr-trigger-letter-spacing: 3px;
	--shdr-trigger-text-transform: uppercase;

	/* Defaults för sub-länkar */
	--shdr-meny-sub-size: 14px;
	--shdr-meny-sub-letter-spacing: 1px;

	/* Defaults för menyfärger */
	--shdr-meny-bg: var(--shdr-cream);
	--shdr-meny-text: var(--shdr-teal-deep);
	--shdr-meny-hover: var(--shdr-rust);
	--shdr-meny-label: var(--shdr-rust);
	--shdr-meny-close: var(--shdr-teal);
	--shdr-meny-separator: rgba(48, 78, 77, 0.16);
	--shdr-meny-overlay-bg: rgba(22, 41, 40, 0.5);

	/* Boka-knapp (header) */
	--shdr-boka-bg: var(--shdr-rust);
	--shdr-boka-text: var(--shdr-cream);
	--shdr-boka-bg-hover: var(--shdr-rust-dark);
	--shdr-boka-text-hover: var(--shdr-cream);
	--shdr-boka-radius: 100px;

	/* Sök */
	--shdr-sok-bg: var(--shdr-cream);
	--shdr-sok-overlay-bg: rgba(22, 41, 40, 0.7);
	--shdr-sok-label: var(--shdr-rust);
	--shdr-sok-input-color: var(--shdr-teal);
	--shdr-sok-input-placeholder: var(--shdr-text-muted);
	--shdr-sok-input-border: var(--shdr-teal);
	--shdr-sok-input-size: 28px;
	--shdr-sok-submit-bg: var(--shdr-teal);
	--shdr-sok-submit-icon: var(--shdr-cream);
	--shdr-sok-submit-bg-hover: var(--shdr-rust);
	--shdr-sok-submit-icon-hover: var(--shdr-cream);
	--shdr-sok-chip-bg: transparent;
	--shdr-sok-chip-text: var(--shdr-teal);
	--shdr-sok-chip-border: rgba(48, 78, 77, 0.25);
	--shdr-sok-chip-bg-hover: var(--shdr-teal);
	--shdr-sok-chip-text-hover: var(--shdr-cream);

	/* Boka-drawer */
	--shdr-drawer-bg: var(--shdr-cream);
	--shdr-drawer-title: var(--shdr-teal);
	--shdr-drawer-intro: var(--shdr-text-muted);
	--shdr-drawer-close: var(--shdr-teal);
	--shdr-drawer-option-bg: var(--shdr-cream-light);
	--shdr-drawer-option-border: rgba(48, 78, 77, 0.1);
	--shdr-drawer-option-text: var(--shdr-teal);
	--shdr-drawer-option-eyebrow: var(--shdr-rust);
	--shdr-drawer-option-bg-hover: var(--shdr-teal);
	--shdr-drawer-option-text-hover: var(--shdr-cream);
	--shdr-drawer-phone-label: var(--shdr-text-muted);
	--shdr-drawer-phone: var(--shdr-teal);
	--shdr-drawer-separator: rgba(48, 78, 77, 0.15);
	--shdr-drawer-overlay-bg: rgba(22, 41, 40, 0.55);

	font-family: var(--shdr-font-body);
	color: var(--shdr-cream);
	position: relative;
	z-index: 100;
}

/* Säkerhetsåterställ: starby-menus CSS sätter top: 32px på .admin-bar .starby-header.
   Vår klass heter .shdr så vi är immuna — men vi resettar för säkerhets skull
   ifall någon raderar prefix-bytet i framtiden. */
.admin-bar .shdr { top: 0; }

/* Bar-förgrund (text/ikoner/logga) — temat sätter basfärgen, topp- och
   scroll-läge kan överrida via BB-fälten (--shdr-top-text / --shdr-scrolled-text). */
.shdr { --shdr-bar-theme-fg: var(--shdr-cream); }
.shdr--dark { --shdr-bar-theme-fg: var(--shdr-teal); }
.shdr { --shdr-bar-fg: var(--shdr-top-text, var(--shdr-bar-theme-fg)); }
.shdr.is-scrolled { --shdr-bar-fg: var(--shdr-scrolled-text, var(--shdr-bar-theme-fg)); }

/* Effektiv menypanel-padding — kan bytas på mobil via media query längre ner */
.shdr { --shdr-pad-eff: var(--shdr-meny-pad, 36px); }

.shdr *,
.shdr *::before,
.shdr *::after { box-sizing: border-box; }

.shdr a { text-decoration: none; color: inherit; }

/* Generell knapp-reset: ärv typsnitt och färger */
.shdr button {
	font: inherit;
	color: inherit;
	cursor: pointer;
}

/* Tema-reset för text-triggers — Astra sätter !important-bakgrund på buttons.
   Boka-knappen är exkluderad (har egen styling som riktig knapp). */
.shdr .shdr__trigger,
.shdr .shdr__trigger:hover,
.shdr .shdr__trigger:focus,
.shdr .shdr__trigger:active,
.shdr .shdr__close,
.shdr .shdr__close:hover,
.shdr .shdr__close:focus,
.shdr .shdr__close:active {
	background: transparent !important;
	background-color: transparent !important;
	box-shadow: none !important;
	border: 0 !important;
	border-radius: 0 !important;
	min-height: 0 !important;
	line-height: inherit !important;
	padding: 4px 0 !important;
}

.shdr .screen-reader-text {
	position: absolute; width: 1px; height: 1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap;
}

/* Sticky header — fixerad vid scroll på både desktop och mobil.
   Vi använder fixed istället för sticky eftersom Beaver Builders rad-
   och kolumnhöjder/overflow bryter sticky-kontexten i många layouter. */
.shdr--sticky {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
}

/* Admin-bar-justering — knuffa ned headern under WP-admin-baren. */
.admin-bar .shdr--sticky { top: 32px; }
@media screen and (max-width: 782px) {
	.admin-bar .shdr--sticky { top: 46px; }
}

/* ============================================
   HEADER-BAR
   ============================================ */
.shdr__bar {
	position: relative;
	isolation: isolate;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 24px;
	padding: 14px 40px;
	transition: padding .4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow .3s ease;
}

/* Krymp bar-padding vid scroll */
.shdr--shrink.is-scrolled .shdr__bar {
	padding-top: 8px;
	padding-bottom: 8px;
}

/* Diskret skugga på header-raden när man scrollat — bara när raden har en bakgrund.
   Icke-transparent header har alltid glas-bg (skugga så fort man scrollar);
   transparent topp får bakgrund + skugga först vid scroll-läget. */
.shdr--sticky.is-past-top:not(.shdr--transparent-top) .shdr__bar,
.shdr--sticky.shdr--transparent-top.is-scrolled .shdr__bar {
	box-shadow: 0 6px 18px rgba(22, 41, 40, 0.08);
}

/* Diskret glasmorfism på ett pseudo-element så vi kan masking-tona ut
   bakgrunden nedåt utan att påverka innehållet. */
.shdr__bar::before {
	content: '';
	position: absolute;
	inset: 0;
	background-color: rgba(22, 41, 40, 0.18);
	-webkit-backdrop-filter: blur(8px) saturate(120%);
	backdrop-filter: blur(8px) saturate(120%);
	-webkit-mask-image: linear-gradient(to bottom, black 0%, black 45%, transparent 100%);
	mask-image: linear-gradient(to bottom, black 0%, black 45%, transparent 100%);
	pointer-events: none;
	z-index: -1;
	transition: background-color .3s ease;
}

/* Mörk variant (mörk text på ljus hero) får en mjuk ljus glaston. */
.shdr--dark .shdr__bar::before {
	background-color: rgba(248, 246, 241, 0.40);
}

/* Fallback när backdrop-filter inte stöds — gör bakgrunden lite mer opak så
   texten alltid är läsbar. */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
	.shdr__bar::before { background-color: rgba(22, 41, 40, 0.70); }
	.shdr--dark .shdr__bar::before { background-color: rgba(248, 246, 241, 0.85); }
}

/* Transparent i toppläget — ingen bakgrund/blur förrän man scrollar */
.shdr--transparent-top .shdr__bar::before {
	background-color: transparent;
	-webkit-backdrop-filter: none;
	backdrop-filter: none;
	-webkit-mask-image: none;
	mask-image: none;
}

/* Vid scroll: tona in scroll-bakgrunden (gäller alla varianter, även transparent topp) */
.shdr.is-scrolled .shdr__bar::before {
	background-color: var(--shdr-scrolled-bg, rgba(22, 41, 40, 0.95));
	-webkit-backdrop-filter: blur(12px) saturate(120%);
	backdrop-filter: blur(12px) saturate(120%);
	-webkit-mask-image: none;
	mask-image: none;
}

.shdr__bar-left {
	display: flex;
	align-items: center;
	gap: 16px;
}

.shdr__bar-right {
	justify-self: end;
}

/* ============================================
   TRIGGERS — Meny / Sök
   ============================================ */
/* Höj specificity (.shdr .shdr__trigger) — Astras .button vinner annars */
.shdr .shdr__trigger {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	color: var(--shdr-bar-fg);
	font-family: var(--shdr-trigger-font-family) !important;
	font-size: var(--shdr-trigger-font-size) !important;
	font-weight: var(--shdr-trigger-font-weight) !important;
	letter-spacing: var(--shdr-trigger-letter-spacing) !important;
	text-transform: var(--shdr-trigger-text-transform) !important;
	padding: 4px 0;
	transition: opacity .2s ease;
}

.shdr--dark .shdr__trigger { color: var(--shdr-bar-fg); }

.shdr__trigger:hover { opacity: .7; }

.shdr__trigger:focus-visible {
	outline: 2px solid var(--shdr-gold-light);
	outline-offset: 4px;
}

.shdr__lines {
	display: inline-flex;
	flex-direction: column;
	gap: 4px;
}
.shdr__lines span {
	display: block;
	height: 1px;
	background: currentColor;
	transition: width .25s ease;
}
.shdr__lines span:nth-child(1) { width: 22px; }
.shdr__lines span:nth-child(2) { width: 14px; }

.shdr__trigger:hover .shdr__lines span:nth-child(2) { width: 22px; }

.shdr__divider {
	color: var(--shdr-bar-fg);
	opacity: 0.4;
	font-size: 14px;
	user-select: none;
}
.shdr--dark .shdr__divider { color: var(--shdr-bar-fg); }

.shdr__sok-icon {
	width: 16px;
	height: 16px;
}

/* ============================================
   LOGOTYP
   ============================================ */
.shdr__logo {
	font-family: var(--shdr-font-heading);
	font-size: 30px;
	color: var(--shdr-bar-fg);
	letter-spacing: 1px;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: font-size .4s cubic-bezier(0.4, 0, 0.2, 1), color .3s ease;
}

.shdr--dark .shdr__logo { color: var(--shdr-bar-fg); }

/* Krymp text-loggan vid scroll (om bild saknas) */
.shdr--shrink.is-scrolled .shdr__logo { font-size: 20px; }

/* Krymp logga-bilden vid scroll */
.shdr--shrink.is-scrolled .shdr__logo img { height: var(--shdr-logo-height-scrolled, 40px); }

.shdr__logo img {
	display: block;
	height: var(--shdr-logo-height, 64px);
	width: auto;
	transition: height .4s cubic-bezier(0.4, 0, 0.2, 1);
	max-width: 100%;
	object-fit: contain;
	min-width: 1px;
	flex-shrink: 0;
}

/* ============================================
   BOKA → (textetikett)
   ============================================ */
.shdr .shdr__boka {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--shdr-boka-bg) !important;
	background-color: var(--shdr-boka-bg) !important;
	color: var(--shdr-boka-text) !important;
	font-family: var(--shdr-trigger-font-family) !important;
	font-size: var(--shdr-trigger-font-size) !important;
	font-weight: var(--shdr-trigger-font-weight) !important;
	letter-spacing: var(--shdr-trigger-letter-spacing) !important;
	text-transform: var(--shdr-trigger-text-transform) !important;
	border: 0 !important;
	border-radius: var(--shdr-boka-radius) !important;
	padding: 12px 22px !important;
	transition: background-color .2s ease, color .2s ease;
}

.shdr .shdr__boka:hover,
.shdr .shdr__boka:focus {
	background: var(--shdr-boka-bg-hover) !important;
	background-color: var(--shdr-boka-bg-hover) !important;
	color: var(--shdr-boka-text-hover, var(--shdr-boka-text)) !important;
}

/* ============================================
   OVERLAY (gemensamt)
   ============================================ */
.shdr-overlay {
	position: fixed;
	inset: 0;
	z-index: 200;
	background: var(--shdr-meny-overlay-bg);
	backdrop-filter: blur(2px);
	opacity: 0;
	visibility: hidden;
	transition: opacity .3s ease, visibility .3s ease;
}

.shdr-overlay[data-state="open"] {
	opacity: 1;
	visibility: visible;
}

.shdr-overlay[hidden] { display: none; }
.shdr.is-js .shdr-overlay { display: block; }

/* ============================================
   OVERLAY — MENY (slide-in från vänster)
   ============================================ */
.shdr-meny {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: var(--shdr-meny-width, 480px);
	max-width: 90%;
	background: var(--shdr-meny-bg);
	color: var(--shdr-meny-text);
	padding: var(--shdr-pad-eff, 36px);
	display: flex;
	flex-direction: column;
	overflow-y: auto;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
	box-shadow: 16px 0 48px rgba(22, 41, 40, 0.4);
	background-color: var(--shdr-meny-bg);
	transform: translateX(-40px);
	transition: transform .4s ease;
}
.shdr-overlay--meny[data-state="open"] .shdr-meny {
	transform: translateX(0);
}

/* Gradient på panelen (aktiveras av shdr--meny-gradient; ligger ovanpå bakgrundsfärgen) */
.shdr--meny-gradient .shdr-meny {
	background-image: var(--shdr-meny-bg-grad);
}

.shdr-meny__top {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	padding-bottom: 16px;
	margin-bottom: 16px;
}

.shdr-meny__label {
	font-family: var(--shdr-trigger-font-family);
	font-size: var(--shdr-trigger-font-size);
	font-weight: var(--shdr-trigger-font-weight);
	letter-spacing: var(--shdr-trigger-letter-spacing);
	text-transform: var(--shdr-trigger-text-transform);
	color: var(--shdr-meny-label);
}

.shdr .shdr__close {
	font-family: var(--shdr-trigger-font-family) !important;
	font-size: var(--shdr-trigger-font-size) !important;
	font-weight: var(--shdr-trigger-font-weight) !important;
	letter-spacing: var(--shdr-trigger-letter-spacing) !important;
	text-transform: var(--shdr-trigger-text-transform) !important;
	color: var(--shdr-meny-close);
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: opacity .2s ease;
}
.shdr .shdr__close:hover { opacity: .7; }

.shdr-meny__nav { flex: 1; }

.shdr-meny__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}

.shdr-meny__item {
	border-bottom: 1px solid var(--shdr-meny-separator);
}

/* Sista posten i listan får ingen linje — undviker dubbel linje mot "Mer"-sektionen/footern */
.shdr-meny__list > .shdr-meny__item:last-child { border-bottom: 0; }

.shdr--no-separators .shdr-meny__item { border-bottom: 0; }

/* Explicit separator-items från WP-menyn (CSS-klass: shdr-separator) */
.shdr-meny__separator-item {
	list-style: none;
	margin: 16px 0 4px;
	padding-top: 16px;
	border-top: 1px solid var(--shdr-meny-separator);
}

.shdr-meny__separator-item:first-child {
	border-top: 0;
	margin-top: 0;
	padding-top: 0;
}

.shdr-meny__section-label {
	display: flex;
	align-items: center;
	gap: 14px;
	font-size: 12px;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--shdr-meny-label);
	font-weight: 600;
	padding: 2px 0;
	margin: 6px 0 14px;
}
/* Linje som löper ut till höger om rubriken */
.shdr-meny__section-label::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--shdr-meny-separator);
}
/* När separatorn har en rubrik räcker den inline-linjen — ta bort den breda topplinjen */
.shdr-meny__separator-item:has(.shdr-meny__section-label) {
	border-top: 0;
	padding-top: 0;
}

.shdr-meny__num {
	display: none; /* Numrering avaktiverad — håller HTML kompatibel */
}

.shdr-meny__link {
	font-family: var(--shdr-meny-font-family, 'DM Serif Display', Georgia, serif);
	font-size: var(--shdr-meny-font-size, 28px);
	font-weight: var(--shdr-meny-font-weight);
	line-height: var(--shdr-meny-line-height);
	letter-spacing: var(--shdr-meny-letter-spacing);
	text-transform: var(--shdr-meny-text-transform);
	color: var(--shdr-meny-text);
	padding: 14px 0;
	display: block;
	transition: color .2s ease, padding-left .2s ease;
}

/* Mjuk indragning vid hover — texten glider in en aning + byter färg */
.shdr-meny__link:hover {
	color: var(--shdr-meny-hover);
	padding-left: 10px;
}

.shdr-meny__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.shdr-meny__item--has-children .shdr-meny__link {
	flex: 1;
}

.shdr .shdr-meny__toggle,
.shdr .shdr-meny__toggle:hover,
.shdr .shdr-meny__toggle:focus,
.shdr .shdr-meny__toggle:active {
	background: transparent !important;
	background-color: transparent !important;
	box-shadow: none !important;
	border: 0 !important;
	border-radius: 50% !important;
	min-height: 0 !important;
	width: 36px;
	height: 36px;
	padding: 0 !important;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--shdr-meny-text);
	cursor: pointer;
	flex-shrink: 0;
	transition: background-color .2s ease, color .2s ease;
}
.shdr .shdr-meny__toggle:hover {
	background-color: rgba(48, 78, 77, 0.06) !important;
	color: var(--shdr-meny-hover);
}

.shdr-meny__chevron {
	width: 14px;
	height: 14px;
	transition: transform .25s ease;
}
.shdr-meny__toggle[aria-expanded="true"] .shdr-meny__chevron {
	transform: rotate(180deg);
}

/* Pil i cirkel — aktiveras med klassen shdr--meny-circle. Fylls vid hover/öppen. */
.shdr--meny-circle .shdr-meny__toggle {
	border: 1px solid var(--shdr-meny-toggle, var(--shdr-teal)) !important;
	border-radius: 50% !important;
	color: var(--shdr-meny-toggle, var(--shdr-teal));
}
.shdr--meny-circle .shdr-meny__toggle:hover,
.shdr--meny-circle .shdr-meny__item--has-children:hover .shdr-meny__toggle,
.shdr--meny-circle .shdr-meny__item--open .shdr-meny__toggle {
	background-color: var(--shdr-meny-toggle, var(--shdr-teal)) !important;
	color: var(--shdr-meny-bg) !important;
}

.shdr-meny__sublist {
	list-style: none;
	margin: 0 0 0 4px;
	padding: 0 0 0 14px;
	border-left: 1px solid var(--shdr-meny-separator);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	max-height: 0;
	opacity: 0;
	transition: max-height .35s ease, opacity .25s ease, padding-top .35s ease, padding-bottom .35s ease, margin-bottom .35s ease;
}

.shdr-meny__item--open .shdr-meny__sublist {
	max-height: 800px;
	opacity: 1;
	padding-top: 4px;
	padding-bottom: 10px;
	margin-bottom: 6px;
}

.shdr-meny__subitem {
	border: 0;
}

.shdr-meny__sublink {
	font-family: var(--shdr-meny-sub-font-family, 'DM Sans', sans-serif);
	font-size: var(--shdr-meny-sub-size);
	font-weight: var(--shdr-meny-sub-font-weight, 400);
	line-height: 1.5;
	letter-spacing: var(--shdr-meny-sub-letter-spacing);
	color: var(--shdr-meny-text);
	opacity: 0.75;
	padding: 6px 0;
	display: block;
	transition: color .2s ease, opacity .2s ease, padding-left .2s ease;
}

.shdr-meny__sublink:hover {
	color: var(--shdr-meny-hover);
	opacity: 1;
	padding-left: 4px;
}

.shdr-meny__empty {
	color: var(--shdr-text-muted);
	font-size: 14px;
	padding: 24px 0;
}

.shdr-meny__bottom {
	margin-top: auto;
	padding-top: 24px;
	border-top: 1px solid var(--shdr-meny-separator);
	display: flex;
	flex-direction: column;
	gap: 14px;
	font-family: var(--shdr-trigger-font-family);
	font-size: 13px;
	color: var(--shdr-meny-contact-text, var(--shdr-text-muted));
	letter-spacing: 1px;
}

.shdr-meny__contact strong {
	display: block;
	color: var(--shdr-meny-contact-label, var(--shdr-teal));
	font-family: var(--shdr-trigger-font-family);
	font-size: var(--shdr-trigger-font-size);
	font-weight: var(--shdr-trigger-font-weight);
	letter-spacing: var(--shdr-trigger-letter-spacing);
	text-transform: var(--shdr-trigger-text-transform);
	margin-bottom: 4px;
}

.shdr-meny__contact a,
.shdr-meny__contact span {
	color: inherit;
	font-family: var(--shdr-trigger-font-family);
	transition: color .2s ease;
}
.shdr-meny__contact a:hover { color: var(--shdr-meny-hover); }

/* Mörk fot — footern som eget färgblock, bleed:ar ut till panelens kanter.
   Aktiveras av klassen shdr--meny-footer-panel när en footer-bakgrund satts. */
.shdr--meny-footer-panel .shdr-meny__bottom {
	background: var(--shdr-meny-footer-bg);
	border-top: 0;
	/* Bleed:ar ut till panelens kanter oavsett padding-värde */
	margin: 24px calc(-1 * var(--shdr-pad-eff, 36px)) calc(-1 * var(--shdr-pad-eff, 36px));
	padding: 26px var(--shdr-pad-eff, 36px) var(--shdr-pad-eff, 36px);
}

/* Fäst footern längst ner — alltid synlig medan menylänkarna scrollar under.
   Bakgrunden gör den opak (footer-färg om satt, annars panelens bakgrund). */
.shdr--meny-footer-sticky .shdr-meny { padding-bottom: 0; }
.shdr--meny-footer-sticky .shdr-meny__bottom {
	position: sticky;
	bottom: 0;
	z-index: 2;
	margin-bottom: 0;
	padding-bottom: var(--shdr-pad-eff, 36px);
	background: var(--shdr-meny-footer-bg, var(--shdr-meny-bg));
}

.shdr-meny__contact-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px 28px;
}

/* Telefon vänsterställd, mejl högerställd → balanserat mot de fullbreda knapparna */
.shdr-meny__contact { min-width: 0; }
.shdr-meny__contact:nth-child(even) { text-align: right; }
.shdr-meny__contact a,
.shdr-meny__contact span {
	overflow-wrap: anywhere;
}

/* CTA-knappar i menyns fot — Boka (fylld) + Kontakt (outline) */
.shdr-meny__cta {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 4px;
}

.shdr .shdr-meny__cta-btn {
	display: block;
	width: 100%;
	text-align: center;
	font-family: var(--shdr-trigger-font-family) !important;
	font-size: var(--shdr-trigger-font-size) !important;
	font-weight: var(--shdr-trigger-font-weight) !important;
	letter-spacing: var(--shdr-trigger-letter-spacing) !important;
	text-transform: var(--shdr-trigger-text-transform) !important;
	padding: 14px 22px !important;
	border-radius: var(--shdr-boka-radius, 100px) !important;
	cursor: pointer;
	transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}

/* Boka — fylld */
.shdr .shdr-meny__cta-btn--boka {
	background: var(--shdr-boka-bg) !important;
	background-color: var(--shdr-boka-bg) !important;
	color: var(--shdr-boka-text) !important;
	border: 0 !important;
}
.shdr .shdr-meny__cta-btn--boka:hover,
.shdr .shdr-meny__cta-btn--boka:focus {
	background: var(--shdr-boka-bg-hover) !important;
	background-color: var(--shdr-boka-bg-hover) !important;
	color: var(--shdr-boka-text-hover, var(--shdr-boka-text)) !important;
}

/* Kontakt — outline */
.shdr .shdr-meny__cta-btn--kontakt {
	background: transparent !important;
	background-color: transparent !important;
	color: var(--shdr-meny-kontakt-btn, var(--shdr-meny-text)) !important;
	border: 1px solid var(--shdr-meny-kontakt-btn, var(--shdr-meny-text)) !important;
}
.shdr .shdr-meny__cta-btn--kontakt:hover,
.shdr .shdr-meny__cta-btn--kontakt:focus {
	background: var(--shdr-meny-kontakt-btn, var(--shdr-meny-text)) !important;
	background-color: var(--shdr-meny-kontakt-btn, var(--shdr-meny-text)) !important;
	color: var(--shdr-meny-bg) !important;
}

/* "Mer" — chips/taggar (sekundära snabblänkar) */
.shdr-meny__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 2px;
}
.shdr .shdr-meny__chip {
	font-family: var(--shdr-trigger-font-family);
	font-size: 12px;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--shdr-meny-chip, var(--shdr-meny-text));
	text-decoration: none;
	padding: 9px 16px;
	border-radius: 100px;
	border: 1px solid var(--shdr-meny-chip, var(--shdr-meny-text));
	transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}
.shdr .shdr-meny__chip:hover,
.shdr .shdr-meny__chip:focus {
	background: var(--shdr-meny-chip-fill, var(--shdr-meny-chip, var(--shdr-meny-text)));
	border-color: var(--shdr-meny-chip-fill, var(--shdr-meny-chip, var(--shdr-meny-text)));
	color: var(--shdr-meny-bg);
}

/* ============================================
   OVERLAY — SÖK (vertikalt centrerad)
   ============================================ */
.shdr-overlay--sok { background: var(--shdr-sok-overlay-bg); }

.shdr-sok {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	max-width: 720px;
	background: var(--shdr-sok-bg);
	color: var(--shdr-sok-input-color);
	padding: 40px 48px 48px;
	border-radius: 4px;
	transform: translate(-50%, calc(-50% - 16px));
	transition: transform .4s ease, opacity .25s ease;
	opacity: 0;
}

.shdr-overlay--sok[data-state="open"] .shdr-sok {
	transform: translate(-50%, -50%);
	opacity: 1;
}

.shdr-sok__top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid var(--shdr-meny-separator);
	padding-bottom: 16px;
	margin-bottom: 24px;
}

.shdr-sok__label {
	font-family: var(--shdr-trigger-font-family);
	font-size: var(--shdr-trigger-font-size);
	font-weight: var(--shdr-trigger-font-weight);
	letter-spacing: var(--shdr-trigger-letter-spacing);
	text-transform: var(--shdr-trigger-text-transform);
	color: var(--shdr-sok-label);
}

.shdr .shdr__close--sok { color: var(--shdr-sok-label) !important; }

.shdr-sok__form {
	display: flex;
	align-items: center;
	gap: 12px;
	border-bottom: 2px solid var(--shdr-sok-input-border);
	padding-bottom: 12px;
}

.shdr-sok__input {
	flex: 1;
	border: 0;
	background: transparent;
	font-family: var(--shdr-meny-font-family);
	font-size: var(--shdr-sok-input-size);
	color: var(--shdr-sok-input-color);
	padding: 8px 0;
	outline: none;
	line-height: 1.2;
}

.shdr-sok__input::placeholder {
	color: var(--shdr-sok-input-placeholder);
	opacity: .7;
}

.shdr .shdr-sok__submit,
.shdr .shdr-sok__submit:hover,
.shdr .shdr-sok__submit:focus,
.shdr .shdr-sok__submit:active {
	background: var(--shdr-sok-submit-bg) !important;
	background-color: var(--shdr-sok-submit-bg) !important;
	color: var(--shdr-sok-submit-icon) !important;
	width: 44px !important;
	height: 44px !important;
	min-height: 44px !important;
	border: 0 !important;
	border-radius: 50% !important;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 !important;
	transition: background-color .2s ease, color .2s ease;
	flex-shrink: 0;
}
.shdr .shdr-sok__submit:hover {
	background: var(--shdr-sok-submit-bg-hover) !important;
	background-color: var(--shdr-sok-submit-bg-hover) !important;
	color: var(--shdr-sok-submit-icon-hover) !important;
}
.shdr-sok__submit svg { width: 18px; height: 18px; }

.shdr-sok__suggestions { margin-top: 24px; }
.shdr-sok__suggestions-label {
	font-family: var(--shdr-trigger-font-family);
	font-size: var(--shdr-trigger-font-size);
	font-weight: var(--shdr-trigger-font-weight);
	letter-spacing: var(--shdr-trigger-letter-spacing);
	text-transform: var(--shdr-trigger-text-transform);
	color: var(--shdr-sok-label);
	display: block;
	margin-bottom: 12px;
}
.shdr-sok__suggestions ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.shdr-sok__suggestions a {
	display: inline-block;
	padding: 6px 14px;
	background: var(--shdr-sok-chip-bg);
	border: 1px solid var(--shdr-sok-chip-border);
	border-radius: 100px;
	font-family: var(--shdr-trigger-font-family);
	font-size: 13px;
	color: var(--shdr-sok-chip-text);
	transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.shdr-sok__suggestions a:hover {
	background: var(--shdr-sok-chip-bg-hover);
	color: var(--shdr-sok-chip-text-hover);
	border-color: var(--shdr-sok-chip-bg-hover);
}

/* ============================================
   OVERLAY — BOKA (slide-in från höger)
   ============================================ */
.shdr-overlay--boka { background: var(--shdr-drawer-overlay-bg); }

.shdr-boka {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 480px;
	max-width: 90%;
	background: var(--shdr-drawer-bg);
	color: var(--shdr-drawer-option-text);
	padding: 32px 40px 32px;
	display: flex;
	flex-direction: column;
	box-shadow: -16px 0 48px rgba(22, 41, 40, 0.4);
	transform: translateX(40px);
	transition: transform .4s ease;
	overflow-y: auto;
}

.shdr-overlay--boka[data-state="open"] .shdr-boka {
	transform: translateX(0);
}

/* Gradient på boka-drawern (aktiveras av shdr--drawer-gradient) */
.shdr--drawer-gradient .shdr-boka {
	background-image: var(--shdr-drawer-bg-grad);
}

.shdr-boka__top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid var(--shdr-drawer-separator);
	padding-bottom: 16px;
	margin-bottom: 20px;
}

.shdr-boka__top .shdr__close {
	color: var(--shdr-drawer-close) !important;
}

.shdr-boka__title {
	font-family: var(--shdr-meny-font-family);
	font-size: 26px;
	color: var(--shdr-drawer-title);
	line-height: 1.2;
	margin-bottom: 8px;
}

.shdr-boka__intro {
	font-family: var(--shdr-trigger-font-family);
	font-size: 14px;
	color: var(--shdr-drawer-intro);
	line-height: 1.6;
	margin-bottom: 24px;
}

.shdr-boka__options {
	list-style: none;
	margin: 0 0 24px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.shdr-boka__option {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 16px 18px;
	background: var(--shdr-drawer-option-bg);
	border: 1px solid var(--shdr-drawer-option-border);
	border-radius: 4px;
	color: var(--shdr-drawer-option-text);
	transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
	position: relative;
}

.shdr-boka__option:hover {
	background: var(--shdr-drawer-option-bg-hover);
	border-color: var(--shdr-drawer-option-bg-hover);
	color: var(--shdr-drawer-option-text-hover);
	transform: translateX(2px);
}

.shdr-boka__option::after {
	content: '→';
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 16px;
	opacity: .5;
	transition: opacity .2s ease, right .2s ease;
}
.shdr-boka__option:hover::after {
	opacity: 1;
	right: 14px;
}

.shdr-boka__option-eyebrow {
	font-family: var(--shdr-trigger-font-family);
	font-size: 10px;
	font-weight: var(--shdr-trigger-font-weight);
	letter-spacing: var(--shdr-trigger-letter-spacing);
	text-transform: var(--shdr-trigger-text-transform);
	color: var(--shdr-drawer-option-eyebrow);
}
.shdr-boka__option:hover .shdr-boka__option-eyebrow {
	color: var(--shdr-drawer-option-text-hover);
	opacity: .8;
}

.shdr-boka__option-title {
	font-family: var(--shdr-meny-font-family);
	font-size: 20px;
	line-height: 1.3;
}

.shdr-boka__option-desc {
	font-family: var(--shdr-trigger-font-family);
	font-size: 13px;
	opacity: .75;
	line-height: 1.5;
}

.shdr-boka__phone {
	margin-top: auto;
	padding-top: 20px;
	border-top: 1px solid var(--shdr-drawer-separator);
	text-align: center;
}
.shdr-boka__phone-label {
	font-family: var(--shdr-trigger-font-family);
	font-size: var(--shdr-trigger-font-size);
	font-weight: var(--shdr-trigger-font-weight);
	letter-spacing: var(--shdr-trigger-letter-spacing);
	text-transform: var(--shdr-trigger-text-transform);
	color: var(--shdr-drawer-phone-label);
	display: block;
	margin-bottom: 6px;
}
.shdr-boka__phone-number {
	font-family: var(--shdr-meny-font-family);
	font-size: 22px;
	color: var(--shdr-drawer-phone);
	transition: opacity .2s ease;
}
.shdr-boka__phone-number:hover { opacity: .7; }

/* ============================================
   BODY-LOCK
   ============================================ */
html.shdr-overlay-open,
body.shdr-overlay-open { overflow: hidden; }

/* ============================================
   RESPONSIVT
   ============================================ */
@media (max-width: 900px) {
	.shdr__bar {
		padding: 12px 20px;
		gap: 12px;
	}

	.shdr__bar-left { gap: 10px; }
	.shdr__trigger-label { display: none; }
	.shdr__divider { display: none; }
	.shdr__logo { font-size: 18px; }
	.shdr__boka { font-size: 10px; letter-spacing: 2px; }

	/* Något mindre logga på mobil */
	.shdr .shdr__logo img { height: 44px; }
	.shdr--shrink.is-scrolled .shdr__logo img { height: 34px; }

	.shdr-meny {
		width: 100%;
		max-width: 100%;
	}

	/* Eget padding-värde på mobil (om satt i BB), annars ärvs desktop-värdet */
	.shdr { --shdr-pad-eff: var(--shdr-meny-pad-mobile, var(--shdr-meny-pad, 36px)); }

	.shdr-sok {
		padding: 28px 24px 32px;
		max-width: 100%;
	}

	.shdr-boka {
		padding: 24px 24px 24px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.shdr *,
	.shdr *::before,
	.shdr *::after {
		transition-duration: 0.01ms !important;
	}
}
