/**
 * Starby Karta — frontend.
 *
 * Mobil-först. Layout: stack på <1024px, sida-vid-sida på ≥1024px.
 * Bottom sheet på touch-enheter, sidobild på desktop.
 *
 * All visuell anpassning sker via CSS-variabler (sätts inline av Renderer
 * från BB-modulens fält) och modifier-klasser. Default-värden bakas in här
 * så shortcode / direktanrop får sensibla värden utan extra style-attribut.
 */

/* ============================================================
   Designtokens — defaults (kan överskridas via inline style)
   ============================================================ */

.starby-karta {
	/* Färger från projekt-CLAUDE.md */
	--sk-teal:        #304E4D;
	--sk-teal-dark:   #1E3534;
	--sk-teal-light:  #3F6564;
	--sk-sand:        #A89D88;
	--sk-rust:        #B85A3A;
	--sk-cream:       #F2EDD9;
	--sk-cream-light: #F8F6F1;
	--sk-text:        #2D2D2D;
	--sk-text-muted:  #6B6B6B;
	--sk-bg:          #FFFFFF;
	--sk-border:      rgba(48, 78, 77, 0.15);

	/* Konfigurerbara värden (kan skrivas över via inline-style från Renderer) */
	--sk-grid-map:        3fr;        /* default: 75 % karta */
	--sk-grid-list:       1fr;        /* default: 25 % lista */
	--sk-hotspot-bg:      var(--sk-teal);
	--sk-hotspot-fg:      var(--sk-cream);
	--sk-hotspot-active-bg: var(--sk-rust);
	--sk-heading-color:   var(--sk-teal);
	--sk-module-bg:       transparent;
	--sk-image-radius:    14px;
	--sk-map-max-height:  80vh;

	/* Mått */
	--sk-radius-pill: 999px;
	--sk-shadow-sm:   0 1px 2px rgba(30, 53, 52, 0.08);
	--sk-shadow-md:   0 4px 16px rgba(30, 53, 52, 0.12);
	--sk-shadow-lg:   0 -8px 32px rgba(30, 53, 52, 0.18);
	--sk-hotspot-size: 44px; /* WCAG 2.5.5 / Apple HIG min touch-target */

	/* Övergångar */
	--sk-trans-fast:  150ms ease-out;
	--sk-trans-med:   300ms cubic-bezier(0.4, 0, 0.2, 1);
	--sk-trans-slow:  500ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* ============================================================
   Container
   ============================================================ */

.starby-karta {
	color: var(--sk-text);
	margin: 0 auto;
	max-width: 1500px;
	background: var(--sk-module-bg);
}

/* Bakgrundsvarianter */
.starby-karta--bg-cream-light { --sk-module-bg: var(--sk-cream-light); }
.starby-karta--bg-cream       { --sk-module-bg: var(--sk-cream); }
.starby-karta--bg-teal-soft   { --sk-module-bg: rgba(48, 78, 77, 0.05); }

/* Padding-varianter */
.starby-karta--padding-none   { padding: 0; }
.starby-karta--padding-small  { padding: 16px; }
.starby-karta--padding-medium { padding: 24px 16px; }
.starby-karta--padding-large  { padding: 48px 24px; }

@media (min-width: 1024px) {
	.starby-karta--padding-small  { padding: 24px; }
	.starby-karta--padding-medium { padding: 40px; }
	.starby-karta--padding-large  { padding: 64px; }
}

.starby-karta__title {
	font-weight: 400;
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	line-height: 1.2;
	margin: 0 0 0.5rem;
	color: var(--sk-heading-color);
}

.starby-karta__intro {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--sk-text-muted);
	max-width: 65ch;
	margin: 0 0 1.5rem;
}

/* ============================================================
   Layout: karta + lista
   ============================================================ */

.starby-karta__layout {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
	.starby-karta--side-by-side .starby-karta__layout {
		grid-template-columns: minmax(0, var(--sk-grid-map)) minmax(220px, var(--sk-grid-list));
		gap: 32px;
		align-items: start;
	}

	.starby-karta--stacked .starby-karta__layout {
		grid-template-columns: 1fr;
		max-width: 1100px;
		margin: 0 auto;
	}
}

/* ============================================================
   Figure + bild + hotspots
   ============================================================ */

.starby-karta__figure {
	margin: 0;
	min-width: 0; /* tillåt grid-cellen att krympa */
}

.starby-karta__viewport {
	position: relative;
	width: 100%;
	background: var(--sk-cream-light);
	border-radius: var(--sk-image-radius);
	overflow: hidden;
	touch-action: pinch-zoom;
}

.starby-karta--shadow-none   .starby-karta__viewport { box-shadow: none; }
.starby-karta--shadow-subtle .starby-karta__viewport { box-shadow: var(--sk-shadow-sm); }
.starby-karta--shadow-medium .starby-karta__viewport { box-shadow: var(--sk-shadow-md); }

@media (min-width: 1024px) {
	.starby-karta__viewport {
		max-height: var(--sk-map-max-height);
	}
}

.starby-karta__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	user-select: none;
}

.starby-karta__hotspots {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

/* ============================================================
   Hotspot-knappar
   ============================================================ */

.starby-karta__hotspot {
	position: absolute;
	transform: translate(-50%, -50%);
	width: var(--sk-hotspot-size);
	height: var(--sk-hotspot-size);
	border-radius: 50%;
	border: 3px solid var(--sk-cream);
	background: var(--sk-hotspot-bg);
	color: var(--sk-hotspot-fg);
	cursor: pointer;
	pointer-events: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	font-family: inherit;
	font-weight: 700;
	font-size: 16px;
	line-height: 1;
	box-shadow:
		0 0 0 0 transparent,
		0 4px 12px rgba(30, 53, 52, 0.35);
	transition:
		transform var(--sk-trans-fast),
		background var(--sk-trans-fast),
		box-shadow var(--sk-trans-fast);
	animation: starby-karta-pulse 2.4s ease-out 2;
}

/* Hotspot-storlek */
.starby-karta--hotspot-small  { --sk-hotspot-size: 40px; }
.starby-karta--hotspot-small  .starby-karta__hotspot { font-size: 14px; border-width: 2px; }
.starby-karta--hotspot-medium { --sk-hotspot-size: 44px; }
.starby-karta--hotspot-large  { --sk-hotspot-size: 52px; font-size: 18px; }
.starby-karta--hotspot-large  .starby-karta__hotspot { font-size: 18px; }

.starby-karta--no-pulse .starby-karta__hotspot {
	animation: none;
}

.starby-karta__hotspot:hover,
.starby-karta__hotspot:focus-visible {
	background: var(--sk-hotspot-active-bg);
	transform: translate(-50%, -50%) scale(1.12);
	outline: none;
	box-shadow:
		0 0 0 4px rgba(184, 90, 58, 0.25),
		0 6px 16px rgba(30, 53, 52, 0.4);
}

.starby-karta__hotspot.is-active {
	background: var(--sk-hotspot-active-bg);
	transform: translate(-50%, -50%) scale(1.15);
	box-shadow:
		0 0 0 6px rgba(184, 90, 58, 0.3),
		0 6px 18px rgba(30, 53, 52, 0.45);
	animation: none;
}

.starby-karta__hotspot-nr {
	display: block;
	pointer-events: none;
}

@keyframes starby-karta-pulse {
	0%   { box-shadow: 0 0 0 0 rgba(184, 90, 58, 0.5), 0 4px 12px rgba(30, 53, 52, 0.35); }
	60%  { box-shadow: 0 0 0 14px rgba(184, 90, 58, 0), 0 4px 12px rgba(30, 53, 52, 0.35); }
	100% { box-shadow: 0 0 0 0 rgba(184, 90, 58, 0), 0 4px 12px rgba(30, 53, 52, 0.35); }
}

@media (prefers-reduced-motion: reduce) {
	.starby-karta__hotspot {
		animation: none;
		transition: none;
	}
}

/* ============================================================
   Lista med beskrivningar
   ============================================================ */

.starby-karta__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.starby-karta__item {
	display: grid;
	grid-template-columns: 32px 1fr;
	gap: 12px;
	padding: 14px 0;
	border-bottom: 1px solid var(--sk-border);
	scroll-margin-top: 100px;
	transition: background var(--sk-trans-med);
	border-radius: 6px;
}

.starby-karta__item:last-child {
	border-bottom: none;
}

.starby-karta__item.is-active {
	background: var(--sk-cream-light);
	padding-left: 10px;
	padding-right: 10px;
}

.starby-karta__item-nr {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--sk-hotspot-bg);
	color: var(--sk-hotspot-fg);
	font-weight: 700;
	font-size: 13px;
	flex-shrink: 0;
}

.starby-karta__item.is-active .starby-karta__item-nr {
	background: var(--sk-hotspot-active-bg);
}

.starby-karta__item-content {
	min-width: 0;
}

.starby-karta__item-title {
	font-weight: 400;
	font-size: 1.15rem;
	line-height: 1.3;
	margin: 0 0 4px;
	color: var(--sk-heading-color);
}

.starby-karta__item-title a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color var(--sk-trans-fast);
}

.starby-karta__item-title a:hover,
.starby-karta__item-title a:focus-visible {
	border-bottom-color: var(--sk-hotspot-active-bg);
}

.starby-karta__item-description {
	font-size: 0.9rem;
	line-height: 1.55;
	color: var(--sk-text);
	margin: 0;
}

/* Listans täthet — compact är smalare, lämpar sig för smal kolumn */
.starby-karta--density-compact .starby-karta__item {
	padding: 10px 0;
	grid-template-columns: 28px 1fr;
	gap: 10px;
}

.starby-karta--density-compact .starby-karta__item-nr {
	width: 28px;
	height: 28px;
	font-size: 12px;
}

.starby-karta--density-compact .starby-karta__item-title {
	font-size: 1.05rem;
}

.starby-karta--density-compact .starby-karta__item-description {
	font-size: 0.875rem;
	line-height: 1.5;
}

.starby-karta--density-comfortable .starby-karta__item {
	padding: 18px 0;
	grid-template-columns: 36px 1fr;
	gap: 14px;
}

.starby-karta--density-comfortable .starby-karta__item-nr {
	width: 36px;
	height: 36px;
	font-size: 14px;
}

.starby-karta--density-comfortable .starby-karta__item-title {
	font-size: 1.25rem;
}

.starby-karta--density-comfortable .starby-karta__item-description {
	font-size: 0.95rem;
}

/* ============================================================
   Bottom sheet (mobil-modal)
   ============================================================ */

.starby-karta__sheet {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 9999;
	background: var(--sk-bg);
	border-top-left-radius: 24px;
	border-top-right-radius: 24px;
	box-shadow: var(--sk-shadow-lg);
	transform: translateY(100%);
	transition: transform var(--sk-trans-slow);
	max-height: 70vh;
	display: flex;
	flex-direction: column;
}

.starby-karta__sheet[hidden] {
	display: none;
}

.starby-karta__sheet.is-open {
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	.starby-karta__sheet {
		transition: none;
	}
}

@media (min-width: 1024px) {
	.starby-karta__sheet {
		display: none !important;
	}
}

.starby-karta__sheet-inner {
	padding: 24px 24px 32px;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.starby-karta__sheet-handle {
	position: absolute;
	top: 8px;
	left: 50%;
	transform: translateX(-50%);
	width: 40px;
	height: 4px;
	border-radius: 2px;
	background: var(--sk-sand);
	opacity: 0.5;
}

.starby-karta__sheet-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: none;
	background: var(--sk-cream-light);
	color: var(--sk-teal);
	font-size: 20px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: inherit;
}

.starby-karta__sheet-close:hover,
.starby-karta__sheet-close:focus-visible {
	background: var(--sk-cream);
	outline: 2px solid var(--sk-hotspot-active-bg);
	outline-offset: 2px;
}

.starby-karta__sheet-nr {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--sk-hotspot-active-bg);
	color: var(--sk-hotspot-fg);
	font-weight: 700;
	font-size: 14px;
	margin-bottom: 12px;
	margin-top: 8px;
}

.starby-karta__sheet-title {
	font-weight: 400;
	font-size: 1.5rem;
	line-height: 1.3;
	margin: 0 0 8px;
	color: var(--sk-heading-color);
	padding-right: 44px;
}

.starby-karta__sheet-description {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--sk-text);
	margin: 0 0 16px;
}

.starby-karta__sheet-link {
	display: inline-block;
	color: var(--sk-hotspot-active-bg);
	text-decoration: none;
	font-weight: 600;
	margin-bottom: 20px;
	border-bottom: 1px solid currentColor;
}

.starby-karta__sheet-link[hidden] {
	display: none;
}

.starby-karta__sheet-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding-top: 16px;
	border-top: 1px solid var(--sk-border);
}

.starby-karta__sheet-prev,
.starby-karta__sheet-next {
	background: transparent;
	border: 1px solid var(--sk-border);
	color: var(--sk-teal);
	border-radius: var(--sk-radius-pill);
	padding: 10px 18px;
	font-size: 0.9rem;
	font-weight: 600;
	cursor: pointer;
	font-family: inherit;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.starby-karta__sheet-prev:hover:not(:disabled),
.starby-karta__sheet-next:hover:not(:disabled),
.starby-karta__sheet-prev:focus-visible,
.starby-karta__sheet-next:focus-visible {
	background: var(--sk-teal);
	color: var(--sk-cream);
	border-color: var(--sk-teal);
	outline: none;
}

.starby-karta__sheet-prev:disabled,
.starby-karta__sheet-next:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.starby-karta__sheet-counter {
	font-size: 0.85rem;
	color: var(--sk-text-muted);
	font-variant-numeric: tabular-nums;
}

/* ============================================================
   Sheet backdrop
   ============================================================ */

.starby-karta__sheet-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(30, 53, 52, 0.4);
	opacity: 0;
	transition: opacity var(--sk-trans-med);
	z-index: 9998;
	pointer-events: none;
}

.starby-karta__sheet-backdrop.is-open {
	opacity: 1;
	pointer-events: auto;
}

@media (min-width: 1024px) {
	.starby-karta__sheet-backdrop {
		display: none;
	}
}

/* ============================================================
   Screen reader-utility (om temat saknar den)
   ============================================================ */

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