/**
 * ---------------------------------------------------------
 * BeaMii Place Styles
 * ---------------------------------------------------------
 * Fil: assets/css/place.css
 * Version: 2.9.0
 *
 * Ansvar:
 * - Ejer hele sted-sidens visuelle lag
 * - Samler tidligere inline CSS fra page-sted.php
 * - Matcher nuværende markup i page-sted.php
 * - Matcher nuværende place.js
 *
 * Dækker:
 * - page background + layout
 * - sticky actions
 * - hero
 * - hero kontakt-dropdown
 * - cards / section heads / content
 * - meal flags (skjult defensivt)
 * - kontakt / info
 * - quick links / lister
 * - promo / instagram / gallery
 * - opening hours
 * - widget / embed
 * - recommendations sliders
 * - share sheet / smart prompt
 * - mini map / full map modal
 * - toast
 * - intern PDF-dokumentvisning i BeaMii-shell
 * - custom PDF.js-dokumentvisning for signerede PDF-links
 *
 * Vigtigt:
 * - Bevarer eksisterende classnames og hooks
 * - Skal kun enqueues på sted-sider
 * - app.css ejer app shell, place.css ejer sted-siden
 * ---------------------------------------------------------
 */

/* ========================================================================
 * 01. PLACE ROOT / TOKENS
 * ===================================================================== */

.beamii-place2{
	--bp-bg: rgba(255,255,255,.88);
	--bp-bg-strong: rgba(255,255,255,.96);
	--bp-surface: rgba(255,255,255,.94);
	--bp-surface-2: rgba(255,255,255,.84);
	--bp-surface-3: rgba(247,250,252,.94);

	--bp-text: #102033;
	--bp-text-strong: rgba(12,18,32,.94);
	--bp-muted: rgba(16,32,51,.64);
	--bp-muted-2: rgba(16,32,51,.52);

	--bp-line: rgba(15,23,42,.08);
	--bp-line-soft: rgba(15,23,42,.05);
	--bp-line-strong: rgba(15,23,42,.12);
	--bp-white-line: rgba(255,255,255,.42);

	--bp-primary: #198fd1;
	--bp-primary-2: #2ea7e0;
	--bp-primary-3: #0f6ea5;
	--bp-primary-soft: rgba(25,143,209,.10);
	--bp-primary-soft-2: rgba(25,143,209,.06);
	--bp-primary-shadow: rgba(31,163,214,.22);

	--bp-accent: #ff8a1f;
	--bp-success: #1f9d68;
	--bp-danger: #ff5f7a;

	--bp-shadow-xs: 0 2px 8px rgba(15,23,42,.04);
	--bp-shadow-sm: 0 8px 20px rgba(15,23,42,.07);
	--bp-shadow-md: 0 14px 34px rgba(15,23,42,.10);
	--bp-shadow-lg: 0 24px 54px rgba(15,23,42,.18);

	--bp-radius-sm: 14px;
	--bp-radius-md: 18px;
	--bp-radius-lg: 24px;
	--bp-radius-xl: 28px;

	--bp-blur: 18px;
	--bp-content-max: 860px;
	--bp-content-narrow: 760px;

	--bp-sticky-top: calc(var(--safe-top, env(safe-area-inset-top, 0px)) + 74px);
	--bp-bottom-space: calc(96px + env(safe-area-inset-bottom));
	--bp-page-top-space: 86px;
}

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

.beamii-place2 a,
.beamii-place2 button,
.beamii-place2 summary{
	-webkit-tap-highlight-color: transparent;
}

.beamii-place2 [hidden]{
	display: none !important;
}

/* ========================================================================
 * 02. PAGE BACKGROUND / PAGE LAYOUT
 * ===================================================================== */

.beamii-place2__pagebg{
	background:
		radial-gradient(circle at top, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 32%),
		linear-gradient(180deg, #8fb7d4 0%, #77a5c7 22%, #6c9cc0 48%, #6b9bbf 100%);
	min-height: 100vh;
}

.beamii-place2__page{
	padding-top: max(8px, env(safe-area-inset-top));
	padding-bottom: var(--bp-bottom-space);
}

.beamii-place2__wrap{
	width: 100%;
	max-width: var(--bp-content-max);
	margin: 0 auto;
	padding: var(--bp-page-top-space) 14px 0;
}

/* ========================================================================
 * 03. SHARED CARD / TYPOGRAPHY / CONTENT ELEMENTS
 * ===================================================================== */

.beamii-place2__card{
	position: relative;
	background: var(--bp-surface);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid var(--bp-white-line);
	border-radius: 24px;
	box-shadow:
		0 10px 30px rgba(12,18,32,.10),
		inset 0 1px 0 rgba(255,255,255,.42);
}

.beamii-place2__info-card,
.beamii-place2__content-card,
.beamii-place2__section,
.beamii-place2__embed-card,
.beamii-place2__widget-card,
.beamii-place2__reco-section{
	padding: 16px;
	margin-bottom: 12px;
}

.beamii-place2__card-title{
	margin: 0;
	font-size: 1rem;
	font-weight: 900;
	letter-spacing: -.02em;
	line-height: 1.2;
	color: var(--bp-text-strong);
}

.beamii-place2__card-title--spaced{
	margin-bottom: 12px;
}

.beamii-place2__card-text{
	color: rgba(12,18,32,.70);
	line-height: 1.58;
}

.beamii-place2__section-head,
.beamii-place2__info-head{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}

.beamii-place2__section-title{
	margin: 0;
	font-size: 1rem;
	font-weight: 900;
	letter-spacing: -.02em;
	line-height: 1.2;
	color: var(--bp-text-strong);
}

.beamii-place2 [data-beamii-section]{
	scroll-margin-top: calc(var(--bp-sticky-top) + 18px);
}

.beamii-place2__section-head--compact{
	margin-bottom: 10px;
}

.beamii-place2__section-heading-copy{
	min-width: 0;
}

.beamii-place2__section-meta-list{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
	max-width: min(100%, 420px);
}

.beamii-place2__section-meta-chip{
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px;
	border-radius: 999px;
	background: var(--bp-primary-soft-2);
	border: 1px solid var(--bp-line-soft);
	color: var(--bp-muted);
	font-size: .78rem;
	font-weight: 700;
	line-height: 1;
	white-space: nowrap;
}

.beamii-place2__contact-head-copy,
.beamii-place2__map-copy{
	min-width: 0;
	flex: 1 1 auto;
}

.beamii-place2__content-body{
	color: rgba(12,18,32,.78);
	line-height: 1.68;
	font-size: .96rem;
}

.beamii-place2__content-body > *:first-child{
	margin-top: 0;
}

.beamii-place2__content-body > *:last-child{
	margin-bottom: 0;
}

.beamii-place2__content-body p{
	margin: 0 0 14px;
}

.beamii-place2__content-body ul,
.beamii-place2__content-body ol{
	margin: 0 0 14px;
	padding-left: 18px;
}

.beamii-place2__content-body li{
	margin-bottom: 8px;
}

.beamii-place2__content-body.is-wide{
	max-width: none;
}

.beamii-place2__content-body.is-card{
	max-width: 70ch;
}

.beamii-place2__action-row{
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 14px;
}

/* ========================================================================
 * 04. STICKY ACTION BAR
 * ===================================================================== */

.beamii-place2__sticky-actions-wrap{
	position: sticky;
	top: var(--bp-sticky-top);
	z-index: 21;
	padding: 10px 12px 0;
	max-width: calc(var(--bp-content-max) + 32px);
	margin: 0 auto;
	pointer-events: none;
}

.beamii-place2__sticky-actions{
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	grid-template-areas:
		"main tools"
		"cta cta";
	align-items: center;
	gap: 10px 12px;
	padding: 12px;
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.78));
	border: 1px solid rgba(255,255,255,.66);
	box-shadow:
		0 18px 36px rgba(15,23,42,.16),
		inset 0 1px 0 rgba(255,255,255,.42);
	backdrop-filter: blur(18px) saturate(1.1);
	-webkit-backdrop-filter: blur(18px) saturate(1.1);
	pointer-events: auto;
}

.beamii-place2__sticky-actions-main,
.beamii-place2__sticky-actions-cta,
.beamii-place2__sticky-actions-tools{
	display: flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
}

.beamii-place2__sticky-actions-main{
	grid-area: main;
	gap: 10px;
}

.beamii-place2__sticky-actions-cta{
	grid-area: cta;
}

.beamii-place2__sticky-actions-tools{
	grid-area: tools;
	justify-content: flex-end;
	flex-wrap: nowrap;
}

.beamii-place2__sticky-actions-title{
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.beamii-place2__sticky-actions-kicker{
	display: inline-flex;
	align-items: center;
	width: fit-content;
	padding: 4px 9px;
	border-radius: 999px;
	font-size: .66rem;
	font-weight: 900;
	line-height: 1;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--bp-primary-ink);
	background: rgba(25,143,209,.10);
}

.beamii-place2__sticky-actions-name{
	font-size: 1rem;
	font-weight: 900;
	line-height: 1.08;
	letter-spacing: -.01em;
	color: var(--bp-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.beamii-place2__sticky-actions-city{
	font-size: .81rem;
	line-height: 1.15;
	color: var(--bp-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.beamii-place2__sticky-btn,
.beamii-place2__sticky-pill,
.beamii-place2__directions,
.beamii-place2__info-btn,
.beamii-place2__chip-btn,
.beamii-place2__map-btn,
.beamii-place2__sheet-btn,
.beamii-place2__smartprompt-btn,
.beamii-place2__hero-contact-route{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	text-decoration: none;
	cursor: pointer;
	transition:
		transform .18s ease,
		box-shadow .18s ease,
		border-color .18s ease,
		background .18s ease,
		color .18s ease,
		filter .18s ease;
	-webkit-tap-highlight-color: transparent;
}

.beamii-place2__sticky-btn,
.beamii-place2__sticky-pill{
	min-height: 44px;
	padding: 0 14px;
	border-radius: 999px;
	border: 1px solid rgba(15,23,42,.08);
	background: rgba(255,255,255,.88);
	color: var(--bp-text);
	font-weight: 850;
	box-shadow: 0 2px 8px rgba(15,23,42,.03);
}

.beamii-place2__sticky-btn:hover,
.beamii-place2__sticky-pill:hover,
.beamii-place2__sticky-btn:focus-visible,
.beamii-place2__sticky-pill:focus-visible{
	transform: translateY(-1px);
	box-shadow: var(--bp-shadow-sm);
	border-color: rgba(25,143,209,.18);
	outline: none;
}

.beamii-place2__sticky-btn:active,
.beamii-place2__sticky-pill:active{
	transform: translateY(0);
	box-shadow: 0 4px 12px rgba(15,23,42,.08);
}

.beamii-place2__sticky-btn--icon{
	width: 44px;
	padding: 0;
	flex: 0 0 44px;
}

.beamii-place2__sticky-btn--back{
	background: rgba(18,32,48,.06);
	border-color: rgba(18,32,48,.08);
}

.beamii-place2__sticky-btn--tool{
	min-width: 44px;
	padding-inline: 14px;
}

.beamii-place2__sticky-btn-text{
	font-size: .84rem;
	font-weight: 850;
	line-height: 1;
	white-space: nowrap;
}

.beamii-place2__sticky-pill--route{
	width: 100%;
	justify-content: center;
	min-height: 46px;
}

.beamii-place2__sticky-btn--primary,
.beamii-place2__directions,
.beamii-place2__info-btn--primary,
.beamii-place2__chip-btn--primary,
.beamii-place2__map-btn--primary,
.beamii-place2__sheet-btn--primary,
.beamii-place2__smartprompt-btn--primary,
.beamii-place2__hero-contact-route{
	background: linear-gradient(135deg, var(--bp-primary-2) 0%, var(--bp-primary) 100%);
	color: #fff;
	border-color: transparent;
	box-shadow: 0 12px 24px var(--bp-primary-shadow);
}

.beamii-place2__sticky-btn--primary:hover,
.beamii-place2__directions:hover,
.beamii-place2__info-btn--primary:hover,
.beamii-place2__chip-btn--primary:hover,
.beamii-place2__map-btn--primary:hover,
.beamii-place2__sheet-btn--primary:hover,
.beamii-place2__smartprompt-btn--primary:hover,
.beamii-place2__hero-contact-route:hover{
	color: #fff;
	filter: brightness(1.03);
}

.beamii-place2__sticky-btn.is-active{
	border-color: rgba(255,95,122,.22);
	background: rgba(255,95,122,.07);
}

.beamii-place2__sticky-btn.is-active i{
	color: var(--bp-danger);
}

.beamii-place2__directions{
	min-height: 48px;
	padding: 0 18px;
	border-radius: 999px;
	font-weight: 800;
}

.beamii-place2__info-actions,
.beamii-place2__promo-actions{
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.beamii-place2__info-btn,
.beamii-place2__chip-btn,
.beamii-place2__map-btn{
	min-height: 40px;
	padding: 0 14px;
	border-radius: 999px;
	font-weight: 800;
	background: rgba(12,18,32,.05);
	color: rgba(12,18,32,.88);
	border: 1px solid rgba(12,18,32,.08);
	box-shadow: none;
}

.beamii-place2__info-btn:hover,
.beamii-place2__chip-btn:hover,
.beamii-place2__map-btn:hover{
	color: rgba(12,18,32,.96);
	background: rgba(12,18,32,.07);
	transform: translateY(-1px);
}

.beamii-place2__sticky-btn:focus-visible,
.beamii-place2__sticky-pill:focus-visible,
.beamii-place2__directions:focus-visible,
.beamii-place2__info-btn:focus-visible,
.beamii-place2__chip-btn:focus-visible,
.beamii-place2__map-btn:focus-visible,
.beamii-place2__sheet-btn:focus-visible,
.beamii-place2__smartprompt-btn:focus-visible,
.beamii-place2__hero-contact-route:focus-visible{
	outline: 2px solid rgba(25,143,209,.34);
	outline-offset: 2px;
}

/* ========================================================================
 * 05. HERO
 * ===================================================================== */

.beamii-place2__hero{
	position: relative;
	overflow: hidden;
	margin-bottom: 12px;
}

.beamii-place2__hero-cover{
	position: relative;
	min-height: 260px;
	background:
		linear-gradient(180deg, rgba(13,24,37,.08), rgba(13,24,37,.22)),
		linear-gradient(135deg, #90b9d8 0%, #7faece 42%, #6d9cc0 100%);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.beamii-place2__hero-cover.has-image{
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.beamii-place2__hero-cover.is-compact{
	min-height: 210px;
}

.beamii-place2__hero-inner{
	position: relative;
	z-index: 2;
	padding: 18px;
	min-height: 260px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 12px;
}

.beamii-place2__hero-inner.is-compact{
	min-height: 210px;
}

.beamii-place2__hero-top{
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.beamii-place2__logo{
	width: 78px;
	height: 78px;
	border-radius: 22px;
	overflow: hidden;
	flex: 0 0 78px;
	background: rgba(255,255,255,.95);
	border: 1px solid rgba(255,255,255,.58);
	box-shadow: 0 8px 20px rgba(12,18,32,.12);
	display: grid;
	place-items: center;
}

.beamii-place2__logo img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.beamii-place2__logo-fallback{
	font-size: 26px;
	color: rgba(12,18,32,.68);
}

.beamii-place2__hero-copy{
	flex: 1 1 auto;
	min-width: 0;
}

.beamii-place2__title{
	margin: 0;
	color: #fff;
	font-weight: 900;
	font-size: clamp(1.6rem, 4vw, 2.35rem);
	line-height: 1.06;
	letter-spacing: -.03em;
	text-shadow: 0 8px 22px rgba(0,0,0,.22);
}

.beamii-place2__meta{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 10px;
}

.beamii-place2__meta-pill{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 34px;
	padding: 0 12px;
	border-radius: 999px;
	color: #fff !important;
	font-size: .84rem;
	font-weight: 800;
	background: rgba(255,255,255,.16);
	border: 1px solid rgba(255,255,255,.20);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	text-decoration: none;
}

.beamii-place2__meta-pill:hover{
	background: rgba(255,255,255,.22);
	color: #fff !important;
}

.beamii-place2__hero-text{
	color: rgba(255,255,255,.96);
	line-height: 1.56;
	font-weight: 500;
	max-width: 64ch;
	text-shadow: 0 2px 10px rgba(0,0,0,.15);
}

/* ========================================================================
 * 06. HERO CONTACT DROPDOWN
 * ===================================================================== */

.beamii-place2__hero-contact{
	margin-top: 2px;
}

.beamii-place2__hero-contact summary{
	list-style: none;
}

.beamii-place2__hero-contact summary::-webkit-details-marker{
	display: none;
}

.beamii-place2__hero-contact-summary{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	min-height: 44px;
	padding: 0 14px;
	border-radius: 999px;
	background: rgba(255,255,255,.16);
	border: 1px solid rgba(255,255,255,.20);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: #fff;
	font-size: .88rem;
	font-weight: 800;
	cursor: pointer;
	user-select: none;
}

.beamii-place2__hero-contact-summary:hover{
	background: rgba(255,255,255,.20);
}

.beamii-place2__hero-contact-summary:focus-visible{
	outline: 2px solid rgba(255,255,255,.55);
	outline-offset: 2px;
}

.beamii-place2__hero-contact-summary-copy{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
}

.beamii-place2__hero-contact-summary-meta{
	margin-left: auto;
	padding: 0 10px;
	min-height: 26px;
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	background: rgba(255,255,255,.16);
	border: 1px solid rgba(255,255,255,.14);
	font-size: .74rem;
	font-weight: 800;
	color: rgba(255,255,255,.88);
}

.beamii-place2__hero-contact-summary-icon{
	flex: 0 0 auto;
	transition: transform .18s ease;
}

.beamii-place2__hero-contact[open] .beamii-place2__hero-contact-summary-icon{
	transform: rotate(180deg);
}

.beamii-place2__hero-contact-panel{
	margin-top: 10px;
	padding: 12px;
	border-radius: 18px;
	background: rgba(255,255,255,.14);
	border: 1px solid rgba(255,255,255,.18);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.beamii-place2__hero-contact-grid{
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
}

.beamii-place2__hero-contact-item{
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 12px;
	border-radius: 16px;
	background: rgba(255,255,255,.94);
	border: 1px solid rgba(255,255,255,.44);
	color: #102033;
	text-decoration: none;
	box-shadow: 0 2px 10px rgba(15,23,42,.05);
	transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.beamii-place2__hero-contact-item:hover{
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(15,23,42,.10);
	color: #102033;
	background: #fff;
}

.beamii-place2__hero-contact-item:focus-visible{
	outline: 2px solid rgba(25,143,209,.28);
	outline-offset: 2px;
}

.beamii-place2__hero-contact-item-icon{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	flex: 0 0 36px;
	border-radius: 12px;
	background: var(--bp-primary-soft);
	color: var(--bp-primary);
}

.beamii-place2__hero-contact-item-copy{
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.beamii-place2__hero-contact-item-label{
	font-size: .72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: rgba(16,32,51,.54);
}

.beamii-place2__hero-contact-item-value{
	font-size: .92rem;
	font-weight: 800;
	line-height: 1.35;
	color: #102033;
	word-break: break-word;
}

.beamii-place2__hero-contact-actions{
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 12px;
}

.beamii-place2__hero-contact-route{
	min-height: 42px;
	padding: 0 14px;
	border-radius: 999px;
	font-weight: 800;
}

/* ========================================================================
 * 07. MEAL FLAGS (SKJULT DEFENSIVT)
 * ===================================================================== */

/*
 * Måltider / servering er fjernet fra page-sted.php,
 * men skjules også defensivt her hvis gammel markup stadig rendres.
 */
.beamii-place2__meal-flags{
	display: none !important;
}

.beamii-place2__meal-flag{
	display: none !important;
}

.beamii-place2__meal-flag-icon,
.beamii-place2__meal-flag-copy,
.beamii-place2__meal-flag-label,
.beamii-place2__meal-flag-meta{
	display: none !important;
}

/* ========================================================================
 * 08. CONTACT / INFO
 * ===================================================================== */

.beamii-place2__contact-grid,
.beamii-place2__list,
.beamii-place2__hours-table{
	display: grid;
	gap: 10px;
}

.beamii-place2__contact-item{
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 12px 14px;
	border-radius: 18px;
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
	color: rgba(12,18,32,.84);
	text-decoration: none;
	width: 100%;
	text-align: left;
	cursor: pointer;
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.beamii-place2__contact-item:hover{
	color: rgba(12,18,32,.92);
	background: rgba(12,18,32,.05);
	transform: translateY(-1px);
	box-shadow: var(--bp-shadow-xs);
}

.beamii-place2__contact-item:focus-visible{
	outline: 2px solid rgba(25,143,209,.20);
	outline-offset: 2px;
}

.beamii-place2__contact-icon{
	width: 22px;
	flex: 0 0 22px;
	margin-top: 1px;
	text-align: center;
	color: var(--bp-primary);
}

.beamii-place2__contact-copy,
.beamii-place2__list-copy{
	min-width: 0;
	flex: 1 1 auto;
}

.beamii-place2__contact-label{
	display: block;
	font-size: .76rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: rgba(12,18,32,.50);
	margin-bottom: 2px;
}

.beamii-place2__contact-value{
	display: block;
	font-weight: 700;
	color: rgba(12,18,32,.88);
	word-break: break-word;
}

/* ========================================================================
 * 09. QUICK LINKS / LISTS
 * ===================================================================== */

.beamii-place2__quick-grid{
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.beamii-place2__quick-item{
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	min-height: 112px;
	padding: 14px;
	border-radius: 20px;
	text-decoration: none;
	color: rgba(12,18,32,.88);
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.beamii-place2__quick-item:hover{
	transform: translateY(-1px);
	background: rgba(12,18,32,.055);
	color: rgba(12,18,32,.96);
}

.beamii-place2__quick-item:focus-visible{
	outline: 2px solid rgba(25,143,209,.20);
	outline-offset: 2px;
}

.beamii-place2__quick-icon,
.beamii-place2__list-icon,
.beamii-place2__reco-head-icon{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--bp-primary-soft);
	color: var(--bp-primary);
}

.beamii-place2__quick-icon{
	width: 40px;
	height: 40px;
	border-radius: 14px;
	font-size: 1rem;
}

.beamii-place2__quick-copy{
	display: block;
	width: 100%;
}

.beamii-place2__quick-label,
.beamii-place2__list-label{
	display: block;
	font-weight: 800;
	line-height: 1.22;
	word-break: break-word;
}

.beamii-place2__quick-meta,
.beamii-place2__list-meta{
	display: block;
	margin-top: 4px;
	line-height: 1.35;
	color: rgba(12,18,32,.58);
}

.beamii-place2__quick-meta{
	font-size: .78rem;
}

.beamii-place2__list-meta{
	font-size: .82rem;
}

.beamii-place2__list-item{
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 56px;
	padding: 12px 14px;
	border-radius: 18px;
	text-decoration: none;
	color: rgba(12,18,32,.88);
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.beamii-place2__list-item:hover{
	color: rgba(12,18,32,.96);
	background: rgba(12,18,32,.055);
	transform: translateY(-1px);
	box-shadow: var(--bp-shadow-xs);
}

.beamii-place2__list-item:focus-visible{
	outline: 2px solid rgba(25,143,209,.20);
	outline-offset: 2px;
}

.beamii-place2__list-icon{
	width: 34px;
	height: 34px;
	border-radius: 12px;
	flex: 0 0 34px;
}

.beamii-place2__list-arrow{
	color: rgba(12,18,32,.35);
	flex: 0 0 auto;
}

/* ========================================================================
 * 10. PROMO / INSTAGRAM
 * ===================================================================== */

.beamii-place2__promo,
.beamii-place2__instagram{
	overflow: hidden;
	padding: 0;
	margin-bottom: 12px;
}

.beamii-place2__promo-inner,
.beamii-place2__instagram-inner{
	display: grid;
	grid-template-columns: 1fr;
	text-decoration: none;
	color: inherit;
}

.beamii-place2__promo-media,
.beamii-place2__instagram-media{
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.beamii-place2__promo-media{
	background:
		linear-gradient(135deg, rgba(20,143,202,.14), rgba(20,143,202,.04)),
		linear-gradient(135deg, #f5f8fc 0%, #e8eff7 100%);
}

.beamii-place2__instagram-media{
	background:
		linear-gradient(135deg, rgba(20,143,202,.12), rgba(20,143,202,.03)),
		linear-gradient(135deg, #f6f8fc 0%, #eef3f8 100%);
}

.beamii-place2__promo-media img,
.beamii-place2__instagram-media img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.beamii-place2__promo-body,
.beamii-place2__instagram-body{
	padding: 16px;
}

.beamii-place2__promo-eyebrow,
.beamii-place2__instagram-badge,
.beamii-place2__hours-status,
.beamii-place2__hours-meta,
.beamii-place2__reco-pill{
	display: inline-flex;
	align-items: center;
	gap: 6px;
	border-radius: 999px;
	background: rgba(20,143,202,.08);
	color: var(--bp-primary);
	font-weight: 800;
}

.beamii-place2__promo-eyebrow{
	min-height: 28px;
	padding: 0 10px;
	font-size: .78rem;
	margin-bottom: 10px;
}

.beamii-place2__instagram-badge{
	min-height: 30px;
	padding: 0 12px;
	font-size: .78rem;
	margin-bottom: 10px;
}

.beamii-place2__promo-title,
.beamii-place2__instagram-title{
	margin: 0 0 8px;
	font-size: 1.08rem;
	line-height: 1.2;
	font-weight: 900;
	color: rgba(12,18,32,.92);
}

.beamii-place2__instagram-title{
	margin-bottom: 6px;
}

.beamii-place2__promo-text,
.beamii-place2__instagram-text,
.beamii-place2__widget-description{
	color: rgba(12,18,32,.68);
	line-height: 1.58;
}

.beamii-place2__instagram-handle{
	display: inline-block;
	font-weight: 800;
	color: var(--bp-primary);
	margin-bottom: 8px;
}

.beamii-place2__instagram-placeholder{
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: rgba(12,18,32,.24);
	font-size: clamp(2rem, 8vw, 3rem);
}

/* ========================================================================
 * 11. GALLERY
 * ===================================================================== */

.beamii-place2__gallery{
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(240px, 78%);
	gap: 10px;
	overflow-x: auto;
	padding-bottom: 2px;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x proximity;
	scrollbar-width: none;
}

.beamii-place2__gallery::-webkit-scrollbar{
	display: none;
}

.beamii-place2__gallery-item{
	scroll-snap-align: start;
	border-radius: 20px;
	overflow: hidden;
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
	min-height: 180px;
}

.beamii-place2__gallery-item img{
	width: 100%;
	height: 100%;
	min-height: 180px;
	object-fit: cover;
	display: block;
}

/* ========================================================================
 * 12. HOURS / OPENING TIMES
 * ===================================================================== */

.beamii-place2__hours-status{
	min-height: 34px;
	padding: 0 12px;
	font-size: .82rem;
	border: 1px solid rgba(20,143,202,.10);
}

.beamii-place2__hours{
	color: rgba(12,18,32,.78);
	line-height: 1.7;
	white-space: pre-line;
}

.beamii-place2__hours-overview{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 12px;
	margin-bottom: 12px;
}

.beamii-place2__hours-summary-copy{
	min-width: 0;
	display: grid;
	gap: 2px;
}

.beamii-place2__hours-summary-label{
	font-size: .74rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--bp-muted);
}

.beamii-place2__hours-summary-value{
	font-weight: 800;
	color: var(--bp-text-strong);
}

.beamii-place2__hours-details{
	border-radius: 18px;
	background: rgba(12,18,32,.03);
	border: 1px solid rgba(12,18,32,.06);
}

.beamii-place2__hours-details > summary{
	list-style: none;
}

.beamii-place2__hours-details > summary::-webkit-details-marker{
	display: none;
}

.beamii-place2__hours-summary{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 16px;
	font-weight: 800;
	color: var(--bp-text-strong);
	cursor: pointer;
}

.beamii-place2__hours-summary:focus-visible{
	outline: 2px solid rgba(25,143,209,.28);
	outline-offset: 2px;
}

.beamii-place2__hours-summary-title{
	min-width: 0;
}

.beamii-place2__hours-summary-icon{
	flex: 0 0 auto;
	transition: transform .18s ease;
}

.beamii-place2__hours-details[open] .beamii-place2__hours-summary-icon{
	transform: rotate(180deg);
}

.beamii-place2__hours-details-panel{
	padding: 0 10px 10px;
}

.beamii-place2__hours-row{
	display: grid;
	grid-template-columns: 110px minmax(0, 1fr);
	gap: 12px;
	align-items: start;
	padding: 12px 14px;
	border-radius: 18px;
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
}

.beamii-place2__hours-day-wrap{
	display: grid;
	gap: 6px;
}

.beamii-place2__hours-day{
	font-weight: 800;
	color: rgba(12,18,32,.88);
	line-height: 1.35;
}

.beamii-place2__hours-today{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 22px;
	padding: 0 8px;
	width: fit-content;
	border-radius: 999px;
	background: rgba(25,143,209,.08);
	color: var(--bp-primary);
	font-size: .72rem;
	font-weight: 800;
}

.beamii-place2__hours-row.is-today{
	background: rgba(25,143,209,.06);
	border-color: rgba(25,143,209,.16);
	box-shadow: inset 0 0 0 1px rgba(25,143,209,.05);
}

.beamii-place2__hours-values{
	display: grid;
	gap: 6px;
	min-width: 0;
}

.beamii-place2__hours-item{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	line-height: 1.4;
	color: rgba(12,18,32,.76);
}

.beamii-place2__hours-time{
	font-weight: 800;
	color: rgba(12,18,32,.88);
}

.beamii-place2__hours-meta{
	min-height: 24px;
	padding: 0 8px;
	font-size: .74rem;
}

.beamii-place2__hours-closed{
	font-weight: 700;
	color: rgba(12,18,32,.52);
}

/* ========================================================================
 * 13. WIDGET / EMBED
 * ===================================================================== */

.beamii-place2__widget-embed{
	width: 100%;
	overflow: hidden;
	border-radius: 18px;
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
	padding: 8px;
}

.beamii-place2__widget-embed iframe,
.beamii-place2__embed-frame{
	width: 100%;
	border: 0;
	border-radius: 14px;
	background: #fff;
	display: block;
}

.beamii-place2__embed-frame{
	min-height: 280px;
	background: rgba(12,18,32,.04);
}

.beamii-place2__widget-embed--kultunaut{
	padding: 12px;
	background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
	border-color: rgba(20,32,48,.10);
	box-shadow: 0 10px 24px rgba(12,18,32,.06);
}

.beamii-place2__kultunaut-mount{
	width: 100%;
	min-height: 132px;
	border-radius: 14px;
	overflow: hidden;
}

.beamii-place2__kultunaut-state{
	background: rgba(12,18,32,.03);
	border: 1px dashed rgba(12,18,32,.14);
	border-radius: 14px;
	padding: 14px;
}

.beamii-place2__kultunaut-state-title{
	font-weight: 800;
	font-size: .95rem;
	color: rgba(12,18,32,.92);
	margin: 0 0 4px;
}

.beamii-place2__kultunaut-state-text{
	font-size: .86rem;
	color: rgba(12,18,32,.66);
	line-height: 1.45;
}

.beamii-place2__event-list{
	display: grid;
	gap: 12px;
}

.beamii-place2__event-slider{
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(260px, 82%);
	gap: 12px;
	overflow-x: auto;
	overflow-y: hidden;
	padding: 2px 2px 8px;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x proximity;
	scrollbar-width: none;
}

.beamii-place2__event-slider::-webkit-scrollbar{
	display: none;
}

.beamii-place2__event-card{
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border-radius: 22px;
	text-decoration: none;
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 10px 24px rgba(12,18,32,.06);
	color: rgba(12,18,32,.88);
	min-height: 100%;
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
	scroll-snap-align: start;
}

.beamii-place2__event-card:hover,
.beamii-place2__event-card:focus-visible{
	color: rgba(12,18,32,.96);
	background: rgba(12,18,32,.055);
	transform: translateY(-1px);
	outline: none;
}

.beamii-place2__event-media{
	position: relative;
	aspect-ratio: 16 / 10;
	background: linear-gradient(180deg, rgba(13,24,37,.04), rgba(13,24,37,.16)), linear-gradient(135deg, #dbe9f4 0%, #c5dced 100%);
	overflow: hidden;
}

.beamii-place2__event-media img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.beamii-place2__event-media--placeholder{
	display: grid;
	place-items: center;
	color: rgba(20,143,202,.48);
	font-size: 1.5rem;
}

.beamii-place2__event-media--skeleton{
	min-height: 160px;
	background: linear-gradient(90deg, rgba(228,235,243,.96) 0%, rgba(244,247,251,.98) 50%, rgba(228,235,243,.96) 100%);
	background-size: 200% 100%;
	animation: beamiiPlaceSkeletonPulse 1.35s ease-in-out infinite;
}

.beamii-place2__event-body{
	padding: 14px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1 1 auto;
}

.beamii-place2__event-title{
	font-weight: 900;
	line-height: 1.2;
	letter-spacing: -.02em;
	color: rgba(12,18,32,.92);
	font-size: 1.02rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.beamii-place2__event-meta{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0;
}

.beamii-place2__event-chip,
.beamii-place2__event-tag{
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: .74rem;
	font-weight: 700;
	color: rgba(12,18,32,.72);
	padding: 4px 9px;
	border-radius: 999px;
	background: rgba(255,255,255,.82);
	border: 1px solid rgba(12,18,32,.08);
	max-width: 100%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.beamii-place2__event-text{
	font-size: .84rem;
	line-height: 1.5;
	color: rgba(12,18,32,.72);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.beamii-place2__event-tags{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: auto;
}

.beamii-place2__events-loading{
	display: grid;
	gap: 12px;
}

.beamii-place2__events-loading--embedded{
	position: relative;
}

.beamii-place2__kultunaut-mount--loading{
	display: none;
}

.beamii-place2__event-card--skeleton{
	pointer-events: none;
}

.beamii-place2__event-skeleton{
	display: block;
	height: 12px;
	border-radius: 999px;
	background: linear-gradient(90deg, rgba(228,235,243,.96) 0%, rgba(244,247,251,.98) 50%, rgba(228,235,243,.96) 100%);
	background-size: 200% 100%;
	animation: beamiiPlaceSkeletonPulse 1.35s ease-in-out infinite;
}

.beamii-place2__event-skeleton--title{
	height: 16px;
	width: 78%;
	border-radius: 10px;
}

.beamii-place2__event-skeleton--chip{
	height: 28px;
	width: 116px;
}

.beamii-place2__event-skeleton--chip-short{
	width: 86px;
}

.beamii-place2__event-skeleton--text{
	width: 100%;
}

.beamii-place2__event-skeleton--text-short{
	width: 68%;
}

@keyframes beamiiPlaceSkeletonPulse{
	0%{ background-position: 200% 0; }
	100%{ background-position: -200% 0; }
}

.beamii-place2__event-promos{
	background: rgba(255,159,67,.10);
	border: 1px solid rgba(255,159,67,.32);
	border-radius: 14px;
	padding: 10px;
	display: grid;
	gap: 8px;
}

.beamii-place2__event-promos-title{
	font-size: .72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: rgba(170,82,0,.86);
}

.beamii-place2__event-promo{
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 8px 10px;
	border-radius: 10px;
	text-decoration: none;
	background: rgba(255,255,255,.84);
	border: 1px solid rgba(255,159,67,.24);
	color: rgba(12,18,32,.90);
}

.beamii-place2__event-promo:hover,
.beamii-place2__event-promo:focus-visible{
	background: rgba(255,255,255,.96);
}

.beamii-place2__event-promo-title{
	font-size: .85rem;
	font-weight: 700;
	line-height: 1.35;
}

.beamii-place2__event-promo-source{
	font-size: .72rem;
	color: rgba(12,18,32,.60);
}

.beamii-place2__widget-embed rssapp-carousel{
	display: block;
	width: 100%;
}

/* ========================================================================
 * 14. RECOMMENDATIONS / RELATED GROUPS
 * ===================================================================== */

.beamii-place2__reco-head{
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
}

.beamii-place2__reco-head-icon{
	width: 38px;
	height: 38px;
	border-radius: 14px;
	flex: 0 0 38px;
}

.beamii-place2__reco-grid{
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.beamii-place2__reco-slider{
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(260px, 78%);
	gap: 12px;
	overflow-x: auto;
	padding: 2px 2px 4px;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x proximity;
	scrollbar-width: none;
}

.beamii-place2__reco-slider::-webkit-scrollbar{
	display: none;
}

.beamii-place2__reco-item{
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border-radius: 22px;
	text-decoration: none;
	background: rgba(12,18,32,.04);
	border: 1px solid rgba(12,18,32,.06);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
	color: rgba(12,18,32,.88);
	min-height: 100%;
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.beamii-place2__reco-slider .beamii-place2__reco-item{
	scroll-snap-align: start;
}

.beamii-place2__reco-item:hover{
	color: rgba(12,18,32,.96);
	background: rgba(12,18,32,.055);
	transform: translateY(-1px);
}

.beamii-place2__reco-item:focus-visible{
	outline: 2px solid rgba(25,143,209,.20);
	outline-offset: 2px;
}

.beamii-place2__reco-media{
	position: relative;
	aspect-ratio: 16 / 10;
	background:
		linear-gradient(180deg, rgba(13,24,37,.04), rgba(13,24,37,.16)),
		linear-gradient(135deg, #dbe9f4 0%, #c5dced 100%);
	overflow: hidden;
}

.beamii-place2__reco-media img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.beamii-place2__reco-media-placeholder{
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	color: rgba(20,143,202,.48);
	font-size: 1.5rem;
}

.beamii-place2__reco-distance{
	position: absolute;
	right: 10px;
	bottom: 10px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-height: 28px;
	padding: 0 10px;
	border-radius: 999px;
	font-size: .74rem;
	font-weight: 800;
	color: #fff;
	background: rgba(12,18,32,.52);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.beamii-place2__reco-body{
	padding: 14px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1 1 auto;
}

.beamii-place2__reco-title{
	font-weight: 900;
	line-height: 1.2;
	letter-spacing: -.02em;
	color: rgba(12,18,32,.92);
}

.beamii-place2__reco-meta{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.beamii-place2__reco-pill{
	min-height: 26px;
	padding: 0 10px;
	font-size: .74rem;
}

.beamii-place2__reco-excerpt{
	color: rgba(12,18,32,.64);
	font-size: .9rem;
	line-height: 1.5;
}

/* ========================================================================
 * 15. SHARE SHEET / SMART PROMPT
 * ===================================================================== */

.beamii-place2__sheet[hidden],
.beamii-place2__smartprompt[hidden]{
	display: none !important;
}

.beamii-place2__sheet,
.beamii-place2__smartprompt{
	position: fixed;
	inset: 0;
	z-index: 1100;
	pointer-events: auto;
	touch-action: manipulation;
}

.beamii-place2__sheet-backdrop,
.beamii-place2__smartprompt-backdrop{
	position: absolute;
	inset: 0;
	background: rgba(10,18,30,.46);
	border: none;
	padding: 0;
	margin: 0;
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

.beamii-place2__sheet-card,
.beamii-place2__smartprompt-card{
	position: absolute;
	left: 12px;
	right: 12px;
	bottom: 12px;
	z-index: 2;
	border-radius: 28px;
	background: linear-gradient(180deg, #fff, rgba(248,250,252,.98));
	border: 1px solid var(--bp-line-soft);
	box-shadow: var(--bp-shadow-lg);
	padding: 18px;
	pointer-events: auto;
}

.beamii-place2__sheet-handle,
.beamii-place2__smartprompt-handle{
	width: 56px;
	height: 5px;
	border-radius: 999px;
	background: rgba(15,23,42,.14);
	margin: 0 auto 14px;
}

.beamii-place2__sheet-title,
.beamii-place2__smartprompt-title{
	font-size: 1.08rem;
	font-weight: 900;
	letter-spacing: -.015em;
	line-height: 1.15;
	color: var(--bp-text);
	margin: 0;
}

.beamii-place2__sheet-text,
.beamii-place2__smartprompt-text{
	margin: 8px 0 0;
	color: rgba(16,32,51,.7);
	line-height: 1.55;
	font-size: .95rem;
}

.beamii-place2__sheet-actions,
.beamii-place2__smartprompt-actions{
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 16px;
}

.beamii-place2__sheet-btn,
.beamii-place2__smartprompt-btn{
	min-height: 52px;
	padding: 0 16px;
	border-radius: 18px;
	border: 1px solid var(--bp-line);
	background: #f7fafc;
	color: var(--bp-text);
	font-weight: 900;
	box-shadow: 0 1px 0 rgba(255,255,255,.7) inset;
	touch-action: manipulation;
	-webkit-tap-highlight-color: transparent;
}

.beamii-place2__sheet-btn:hover,
.beamii-place2__smartprompt-btn:hover,
.beamii-place2__sheet-btn:focus-visible,
.beamii-place2__smartprompt-btn:focus-visible{
	transform: translateY(-1px);
	box-shadow: var(--bp-shadow-sm);
	border-color: rgba(25,143,209,.18);
	outline: none;
}

.beamii-place2__sheet-btn:active,
.beamii-place2__smartprompt-btn:active{
	transform: translateY(0);
}

.beamii-place2__sheet-btn--soft,
.beamii-place2__smartprompt-btn--soft{
	background: #fff;
}

.beamii-place2__sheet-subactions{
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	margin-top: 2px;
}

.beamii-place2__smartprompt-note{
	margin-top: 10px;
	font-size: .81rem;
	line-height: 1.45;
	color: rgba(16,32,51,.56);
	text-align: center;
}

.beamii-place2__smartprompt-login-hint{
	margin: 10px 0 0;
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(31,60,92,.07);
	border: 1px solid rgba(31,60,92,.12);
	color: rgba(16,32,51,.82);
	font-size: .9rem;
	line-height: 1.45;
}

/* ========================================================================
 * 17. MINI MAP / MAP ACTIONS
 * ===================================================================== */

.beamii-place2__map-wrap{
	display: grid;
	gap: 12px;
}

.beamii-place2__map-actions{
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

#beamiiMiniMap,
.beamii-place2 [data-beamii-mini-map]{
	width: 100%;
	min-height: 240px;
	height: 240px;
	border-radius: 20px;
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(20,143,202,.06), rgba(20,143,202,.02)),
		#eef4f8;
	border: 1px solid rgba(12,18,32,.08);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.45);
}

#beamiiMiniMap .leaflet-control-attribution,
.beamii-place2 [data-beamii-mini-map] .leaflet-control-attribution,
#beamiiFullMap .leaflet-control-attribution{
	font-size: 10px;
}

#beamiiMiniMap .leaflet-container,
.beamii-place2 [data-beamii-mini-map] .leaflet-container,
#beamiiFullMap .leaflet-container{
	font: inherit;
}

/* ========================================================================
 * 18. FULL MAP MODAL
 * ===================================================================== */

#beamiiMapModal{
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 12px;
	background: rgba(8,15,25,.40);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

#beamiiMapModal[hidden]{
	display: none !important;
}

.beamii-mapmodal__backdrop{
	position: absolute;
	inset: 0;
	background: transparent;
	border: 0;
	padding: 0;
	margin: 0;
	cursor: pointer;
}

.beamii-mapmodal__dialog{
	position: relative;
	z-index: 2;
	width: min(100%, 860px);
	height: min(82vh, 820px);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border-radius: 28px;
	background: rgba(255,255,255,.98);
	border: 1px solid rgba(255,255,255,.65);
	box-shadow:
		0 24px 60px rgba(12,18,32,.22),
		inset 0 1px 0 rgba(255,255,255,.55);
	animation: beamiiPlaceMapUp .18s ease forwards;
}

@keyframes beamiiPlaceMapUp{
	from{
		opacity: 0;
		transform: translateY(14px) scale(.985);
	}
	to{
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.beamii-mapmodal__topbar{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 16px;
	border-bottom: 1px solid rgba(12,18,32,.08);
	background: rgba(255,255,255,.92);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.beamii-mapmodal__title{
	margin: 0;
	font-size: 1rem;
	font-weight: 900;
	letter-spacing: -.02em;
	color: rgba(12,18,32,.92);
}

.beamii-mapmodal__subtitle{
	margin-top: 4px;
	font-size: .84rem;
	color: rgba(12,18,32,.58);
}

.beamii-mapmodal__close{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 999px;
	border: 1px solid rgba(12,18,32,.08);
	background: rgba(12,18,32,.05);
	color: rgba(12,18,32,.88);
	cursor: pointer;
}

.beamii-mapmodal__close:hover{
	background: rgba(12,18,32,.08);
	color: rgba(12,18,32,.96);
}

.beamii-mapmodal__close:focus-visible{
	outline: 2px solid rgba(25,143,209,.28);
	outline-offset: 2px;
}

#beamiiFullMap{
	flex: 1 1 auto;
	width: 100%;
	min-height: 320px;
	background: #eef4f8;
}

#beamiiFullMap .leaflet-pane,
#beamiiMiniMap .leaflet-pane,
.beamii-place2 [data-beamii-mini-map] .leaflet-pane{
	z-index: auto;
}

#beamiiFullMap .leaflet-top,
#beamiiFullMap .leaflet-bottom,
#beamiiMiniMap .leaflet-top,
.beamii-place2 [data-beamii-mini-map] .leaflet-top,
#beamiiMiniMap .leaflet-bottom,
.beamii-place2 [data-beamii-mini-map] .leaflet-bottom{
	z-index: 400;
}

.beamii-place2__map-card{
	overflow: hidden;
}

.beamii-place2__info-head--map{
	align-items: flex-start;
}

.beamii-place2__map-copy{
	min-width: 0;
	flex: 1 1 auto;
}

.beamii-place2__map-text{
	margin: 6px 0 0;
	color: rgba(12,18,32,.68);
	line-height: 1.55;
	font-size: .92rem;
	max-width: 62ch;
}

.beamii-place2__map-meta{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 12px;
}

.beamii-place2__map-meta-item{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 34px;
	max-width: 100%;
	padding: 0 12px;
	border-radius: 999px;
	background: rgba(12,18,32,.045);
	border: 1px solid rgba(12,18,32,.06);
	color: rgba(12,18,32,.78);
	font-size: .84rem;
	font-weight: 700;
}

.beamii-place2__map-meta-item span{
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.beamii-place2__map-canvas-wrap{
	position: relative;
}

.beamii-place2__map-surface{
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 500;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 40px;
	padding: 0 14px;
	border: 1px solid rgba(255,255,255,.58);
	border-radius: 999px;
	background: rgba(12,18,32,.66);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	color: #fff;
	font-weight: 800;
	box-shadow: 0 12px 24px rgba(12,18,32,.20);
	cursor: pointer;
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}

.beamii-place2__map-surface:hover{
	transform: translateY(-1px);
	background: rgba(12,18,32,.74);
}

.beamii-place2__map-surface:focus-visible{
	outline: 2px solid rgba(255,255,255,.65);
	outline-offset: 2px;
}

.beamii-place2__map-note{
	font-size: .82rem;
	line-height: 1.45;
	color: rgba(12,18,32,.58);
}

.beamii-place2__map-fallback{
	display: grid;
	grid-template-columns: auto minmax(0,1fr);
	gap: 14px;
	padding: 16px;
	margin-bottom: 12px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(20,143,202,.08), rgba(20,143,202,.03));
	border: 1px solid rgba(20,143,202,.12);
}

.beamii-place2__map-fallback-icon{
	width: 46px;
	height: 46px;
	border-radius: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(25,143,209,.12);
	color: var(--bp-primary);
	font-size: 1.05rem;
}

.beamii-place2__map-fallback-copy{
	min-width: 0;
}

#beamiiMiniMap,
.beamii-place2 [data-beamii-mini-map]{
	height: 280px;
	min-height: 280px;
	cursor: grab;
}

#beamiiMiniMap:active,
.beamii-place2 [data-beamii-mini-map]:active{
	cursor: grabbing;
}

.beamii-mapmodal__body{
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
}

.beamii-mapmodal__footer{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 12px 16px 16px;
	border-top: 1px solid rgba(12,18,32,.08);
	background: rgba(255,255,255,.94);
}

.beamii-mapmodal__meta{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
	color: rgba(12,18,32,.70);
	font-size: .88rem;
	font-weight: 700;
}

.beamii-mapmodal__meta span{
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.beamii-mapmodal__actions{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 10px;
}

.beamii-mapmodal__action{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 40px;
	padding: 0 14px;
	border-radius: 999px;
	border: 1px solid rgba(12,18,32,.08);
	background: rgba(12,18,32,.05);
	color: rgba(12,18,32,.88);
	text-decoration: none;
	font-weight: 800;
	transition: transform .18s ease, background .18s ease, border-color .18s ease;
}

.beamii-mapmodal__action:hover{
	transform: translateY(-1px);
	background: rgba(12,18,32,.07);
	color: rgba(12,18,32,.96);
}

.beamii-mapmodal__action:focus-visible{
	outline: 2px solid rgba(25,143,209,.28);
	outline-offset: 2px;
}

.beamii-mapmodal__action--primary{
	background: linear-gradient(135deg, var(--bp-primary-2) 0%, var(--bp-primary) 100%);
	border-color: transparent;
	color: #fff;
	box-shadow: 0 12px 24px var(--bp-primary-shadow);
}

.beamii-mapmodal__action--primary:hover{
	color: #fff;
	filter: brightness(1.03);
}

/* ========================================================================
 * 19. TOAST
 * ===================================================================== */

.beamii-place2 .toast{
	position: fixed;
	left: 50%;
	bottom: calc(100px + env(safe-area-inset-bottom));
	transform: translateX(-50%);
	z-index: 99999;
	min-width: 140px;
	max-width: calc(100vw - 32px);
	padding: 12px 16px;
	border-radius: 999px;
	background: rgba(12,18,32,.90);
	color: #fff;
	font-size: .92rem;
	font-weight: 800;
	line-height: 1.35;
	text-align: center;
	box-shadow: 0 14px 34px rgba(12,18,32,.26);
}

/* ========================================================================
 * 20. NOT FOUND
 * ===================================================================== */

.beamii-place2__card--not-found{
	padding: 20px;
}

.beamii-place2--not-found .beamii-place2__wrap{
	max-width: var(--bp-content-narrow);
	padding-top: 24px;
}

/* ========================================================================
 * 21. SCROLL LOCK / MODAL STATES
 * ===================================================================== */

html.beamii-modal-open,
body.is-lock-scroll,
html.is-lock-scroll{
	overflow: hidden;
}

/* ========================================================================
 * 22. DESKTOP ENHANCEMENTS
 * ===================================================================== */

@media (min-width: 760px){
	.beamii-place2{
		--bp-page-top-space: 94px;
	}

	.beamii-place2__wrap{
		padding-left: 18px;
		padding-right: 18px;
	}

	.beamii-place2__hero-inner{
		padding: 22px;
		min-height: 300px;
	}

	.beamii-place2__hero-inner.is-compact{
		min-height: 220px;
	}

	.beamii-place2__hero-top{
		gap: 16px;
	}

	.beamii-place2__logo{
		width: 86px;
		height: 86px;
		flex-basis: 86px;
		border-radius: 24px;
	}

	.beamii-place2__sticky-actions-wrap{
		padding-left: 18px;
		padding-right: 18px;
	}

	.beamii-place2__sticky-actions{
		grid-template-columns: minmax(0, 1fr) auto auto;
		grid-template-areas: "main cta tools";
		gap: 12px 14px;
		padding: 12px 14px;
	}

	.beamii-place2__sticky-actions-main{
		gap: 12px;
	}

	.beamii-place2__sticky-actions-tools{
		gap: 10px;
	}

	.beamii-place2__sticky-actions-name{
		font-size: 1.02rem;
	}

	.beamii-place2__sticky-actions-city{
		font-size: .82rem;
	}

	.beamii-place2__sticky-pill--route{
		width: auto;
		min-width: 140px;
		padding-inline: 18px;
	}

	.beamii-place2__hero-contact-grid{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.beamii-place2__promo-inner,
	.beamii-place2__instagram-inner{
		grid-template-columns: minmax(280px, 40%) minmax(0, 1fr);
		align-items: stretch;
	}

	.beamii-place2__promo-media,
	.beamii-place2__instagram-media{
		aspect-ratio: auto;
		min-height: 100%;
	}

	.beamii-place2__reco-grid{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.beamii-place2__gallery{
		grid-auto-columns: minmax(280px, 36%);
	}

	.beamii-place2__sheet-card,
	.beamii-place2__smartprompt-card{
		left: 50%;
		right: auto;
		width: min(560px, calc(100vw - 24px));
		transform: translateX(-50%);
	}
}

@media (min-width: 1100px){
	.beamii-place2__reco-grid{
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

/* ========================================================================
 * 23. TABLET / MOBILE
 * ===================================================================== */

@media (max-width: 900px){
	.beamii-place2__quick-grid{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.beamii-place2__reco-grid{
		grid-template-columns: 1fr;
	}

	.beamii-place2__reco-slider{
		grid-auto-columns: minmax(240px, 86%);
	}
}

@media (max-width: 640px){
	.beamii-place2{
		--bp-page-top-space: 92px;
	}

	.beamii-place2__page{
		padding-bottom: calc(96px + env(safe-area-inset-bottom));
	}

	.beamii-place2__wrap{
		padding-left: 10px;
		padding-right: 10px;
	}

	.beamii-place2__sticky-actions-wrap{
		top: calc(var(--safe-top, env(safe-area-inset-top, 0px)) + 82px);
		padding: 8px 10px 0;
	}

	.beamii-place2__sticky-actions{
		padding: 10px;
		border-radius: 18px;
		gap: 10px;
	}

	.beamii-place2__sticky-actions-main{
		gap: 8px;
	}

	.beamii-place2__sticky-actions-kicker{
		padding: 3px 8px;
		font-size: .62rem;
	}

	.beamii-place2__sticky-actions-name{
		font-size: .94rem;
	}

	.beamii-place2__sticky-actions-city{
		font-size: .76rem;
	}

	.beamii-place2__sticky-actions-tools{
		gap: 6px;
	}

	.beamii-place2__sticky-btn,
	.beamii-place2__sticky-btn--icon,
	.beamii-place2__sticky-btn--tool{
		min-height: 40px;
		height: 40px;
	}

	.beamii-place2__sticky-btn--icon,
	.beamii-place2__sticky-btn--tool{
		width: 40px;
		padding: 0;
		flex: 0 0 40px;
	}

	.beamii-place2__sticky-btn-text{
		display: none;
	}

	.beamii-place2__hero-cover{
		min-height: 230px;
	}

	.beamii-place2__hero-inner{
		min-height: 230px;
		padding: 16px;
	}

	.beamii-place2__hero-inner.is-compact{
		min-height: 190px;
	}

	.beamii-place2__logo{
		width: 68px;
		height: 68px;
		flex-basis: 68px;
		border-radius: 20px;
	}

	.beamii-place2__title{
		font-size: clamp(1.4rem, 7vw, 1.95rem);
	}

	.beamii-place2__hero-text{
		font-size: .93rem;
	}

	.beamii-place2__hero-contact-summary{
		min-height: 42px;
		padding: 0 12px;
		font-size: .84rem;
	}

	.beamii-place2__hero-contact-panel{
		padding: 10px;
		border-radius: 16px;
	}

	.beamii-place2__hero-contact-item{
		padding: 11px;
		border-radius: 14px;
	}

	.beamii-place2__hero-contact-item-icon{
		width: 34px;
		height: 34px;
		flex-basis: 34px;
		border-radius: 10px;
	}

	.beamii-place2__info-card,
	.beamii-place2__content-card,
	.beamii-place2__section,
	.beamii-place2__embed-card,
	.beamii-place2__widget-card,
	.beamii-place2__reco-section{
		padding: 14px;
	}

	.beamii-place2__section-head,
	.beamii-place2__info-head{
		flex-direction: column;
		align-items: flex-start;
	}

	.beamii-place2__section-meta-list{
		justify-content: flex-start;
		max-width: none;
	}

	.beamii-place2__info-actions,
	.beamii-place2__promo-actions{
		width: 100%;
	}

	.beamii-place2__info-btn,
	.beamii-place2__chip-btn,
	.beamii-place2__map-btn{
		flex: 1 1 auto;
	}

	.beamii-place2__quick-item{
		min-height: 104px;
		padding: 13px;
		border-radius: 18px;
	}

	.beamii-place2__hours-row{
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.beamii-place2__gallery{
		grid-auto-columns: minmax(220px, 86%);
	}

	.beamii-place2__sheet-card,
	.beamii-place2__smartprompt-card{
		left: 10px;
		right: 10px;
		bottom: 10px;
		padding: 16px;
		border-radius: 24px;
	}

	.beamii-place2__sheet-subactions{
		grid-template-columns: 1fr;
	}

	.beamii-mapmodal__dialog{
		width: 100%;
		height: min(88vh, 100%);
		border-radius: 24px;
	}

	.beamii-place2__map-meta{
		margin-bottom: 10px;
	}

	.beamii-place2__map-meta-item{
		max-width: 100%;
	}

	.beamii-place2__map-meta-item span{
		white-space: normal;
	}

	.beamii-place2__map-surface{
		top: 10px;
		right: 10px;
		min-height: 36px;
		padding: 0 12px;
		font-size: .82rem;
	}

	.beamii-place2__map-fallback{
		grid-template-columns: 1fr;
	}

	.beamii-mapmodal__footer{
		flex-direction: column;
		align-items: stretch;
		padding: 12px 14px 14px;
	}

	.beamii-mapmodal__actions{
		justify-content: stretch;
	}

	.beamii-mapmodal__action{
		flex: 1 1 calc(50% - 5px);
	}

	.beamii-mapmodal__topbar{
		padding: 12px 14px;
	}

	#beamiiMiniMap,
.beamii-place2 [data-beamii-mini-map]{
		height: 220px;
		min-height: 220px;
	}

	.beamii-place2__reco-slider{
		grid-auto-columns: minmax(220px, 88%);
	}
}


@media (max-width: 420px){
	.beamii-place2__quick-grid{
		grid-template-columns: 1fr;
	}

	.beamii-place2__sticky-actions{
		grid-template-columns: minmax(0, 1fr);
		grid-template-areas:
			"main"
			"cta"
			"tools";
	}

	.beamii-place2__sticky-actions-tools{
		justify-content: flex-start;
	}

	.beamii-place2__sticky-actions-city{
		display: none;
	}

	.beamii-place2__meta-pill{
		font-size: .8rem;
		padding-left: 10px;
		padding-right: 10px;
	}

	.beamii-place2__reco-slider{
		grid-auto-columns: minmax(220px, 92%);
	}
}


/* ========================================================================
 * 24. REDUCED MOTION
 * ===================================================================== */

@media (prefers-reduced-motion: reduce){
	.beamii-place2__sticky-btn,
	.beamii-place2__sticky-pill,
	.beamii-place2__quick-item,
	.beamii-place2__list-item,
	.beamii-place2__contact-item,
	.beamii-place2__reco-item,
	.beamii-place2__sheet-btn,
	.beamii-place2__smartprompt-btn,
	.beamii-place2__info-btn,
	.beamii-place2__chip-btn,
	.beamii-place2__map-btn,
	.beamii-place2__directions,
	.beamii-place2__hero-contact-route,
	.beamii-place2__hero-contact-item,
	.beamii-place2__hero-contact-summary,
	.beamii-place2__meta-pill{
		transition: none !important;
	}
	.beamii-mapmodal__dialog{
		animation: none !important;
	}
}


/* ========================================================================
 * 22. PLACE TOP INTERACTION REBUILD
 * ------------------------------------------------------------------------
 * Version: 2.8.0
 * Ansvar:
 * - Giver place-view topbaren en ren navigationsrolle
 * - Erstatter den gamle sticky title/route bar med en utility-dock
 * - Bevarer share/favorit hooks uden at gentage hero-identiteten
 * ===================================================================== */

.beamii-place2 .topbar--place{
	background:
		linear-gradient(180deg, rgba(234,242,248,.40) 0%, rgba(234,242,248,.16) 46%, rgba(234,242,248,0) 100%);
}

.beamii-place2 .topbar--place .searchbar{
	max-width: var(--bp-content-max);
	padding: 8px 10px 8px 10px;
}

.beamii-place2 .topbar--place .searchbar-content{
	gap: 12px;
}

.beamii-place2 .topbar--place .topbar-place{
	flex: 1 1 auto;
	min-width: 0;
}

.beamii-place2 .topbar--place .topbar-place--utility{
	display: flex;
	align-items: center;
}

.beamii-place2 .topbar-place__backtrack{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	max-width: 100%;
	min-height: 44px;
	padding: 5px 14px 5px 6px;
	border-radius: 18px;
	border: 1px solid rgba(255,255,255,.10);
	background: rgba(255,255,255,.10);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
	color: rgba(255,255,255,.96);
	text-decoration: none;
	transition:
		transform .16s ease,
		background .16s ease,
		border-color .16s ease,
		box-shadow .16s ease;
}

.beamii-place2 .topbar-place__backtrack:hover,
.beamii-place2 .topbar-place__backtrack:focus-visible{
	transform: translateY(-1px);
	background: rgba(255,255,255,.14);
	border-color: rgba(255,255,255,.18);
	box-shadow:
		0 12px 24px rgba(11,26,40,.14),
		inset 0 1px 0 rgba(255,255,255,.08);
	outline: none;
}

.beamii-place2 .topbar-place__backtrack-icon{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	flex: 0 0 32px;
	border-radius: 999px;
	background: rgba(255,255,255,.12);
	color: rgba(255,255,255,.96);
}

.beamii-place2 .topbar-place__backtrack-copy{
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.beamii-place2 .topbar-place__backtrack-label{
	font-size: 10px;
	font-weight: 900;
	letter-spacing: .08em;
	text-transform: uppercase;
	line-height: 1;
	color: rgba(255,255,255,.66);
}

.beamii-place2 .topbar-place__backtrack-destination{
	font-size: 14px;
	font-weight: 850;
	line-height: 1.1;
	letter-spacing: -.01em;
	color: rgba(255,255,255,.96);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.beamii-place2__sticky-actions-wrap{
	display: flex;
	justify-content: flex-end;
	padding: 12px 12px 0;
}

.beamii-place2__sticky-actions{
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	width: auto;
	max-width: 100%;
	margin-left: auto;
	padding: 10px 12px 10px 14px;
	border-radius: 999px;
	background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80));
	border: 1px solid rgba(255,255,255,.68);
	box-shadow:
		0 18px 36px rgba(15,23,42,.14),
		inset 0 1px 0 rgba(255,255,255,.42);
	backdrop-filter: blur(18px) saturate(1.08);
	-webkit-backdrop-filter: blur(18px) saturate(1.08);
}

.beamii-place2__sticky-actions--utility{
	min-width: min(100%, 338px);
}

.beamii-place2__sticky-actions-meta{
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding-right: 4px;
}

.beamii-place2__sticky-actions-eyebrow{
	display: inline-flex;
	align-items: center;
	width: fit-content;
	font-size: .62rem;
	font-weight: 900;
	line-height: 1;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--bp-primary-3);
}

.beamii-place2__sticky-actions-hint{
	font-size: .78rem;
	line-height: 1.12;
	font-weight: 700;
	color: var(--bp-muted);
	white-space: nowrap;
}

.beamii-place2__sticky-actions-tools{
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	flex-wrap: nowrap;
}

.beamii-place2__sticky-btn{
	min-height: 46px;
	padding: 0 15px;
	border-radius: 999px;
	background: rgba(255,255,255,.92);
	border: 1px solid rgba(15,23,42,.08);
	box-shadow: 0 6px 18px rgba(15,23,42,.06);
}

.beamii-place2__sticky-btn--tool{
	min-width: 46px;
	padding-inline: 16px;
}

.beamii-place2__sticky-btn-text{
	font-size: .83rem;
	font-weight: 850;
}

@media (max-width: 900px){
	.beamii-place2 .topbar--place .searchbar{
		max-width: 100%;
	}

	.beamii-place2__sticky-actions-wrap{
		padding-inline: 14px;
	}

	.beamii-place2__sticky-actions--utility{
		min-width: 0;
		width: 100%;
	}
}

@media (max-width: 640px){
	.beamii-place2 .topbar--place .searchbar{
		padding: 7px 8px 7px 8px;
	}

	.beamii-place2 .topbar--place .searchbar-content{
		gap: 8px;
	}

	.beamii-place2 .topbar-place__backtrack{
		padding-right: 10px;
		gap: 8px;
	}

	.beamii-place2 .topbar-place__backtrack-label{
		font-size: 9px;
	}

	.beamii-place2 .topbar-place__backtrack-destination{
		font-size: 13px;
	}

	.beamii-place2__sticky-actions-wrap{
		padding: 10px 14px 0;
	}

	.beamii-place2__sticky-actions{
		width: 100%;
		padding: 9px 10px 9px 12px;
		gap: 10px;
	}

	.beamii-place2__sticky-actions-meta{
		display: none;
	}

	.beamii-place2__sticky-actions-tools{
		width: 100%;
		justify-content: space-between;
		gap: 10px;
	}

	.beamii-place2__sticky-btn,
	.beamii-place2__sticky-btn--tool{
		flex: 1 1 calc(50% - 5px);
		min-width: 0;
		padding-inline: 14px;
	}

	.beamii-place2__sticky-btn-text{
		font-size: .82rem;
	}
}

@media (max-width: 420px){
	.beamii-place2 .topbar-place__backtrack-copy{
		gap: 1px;
	}

	.beamii-place2 .topbar-place__backtrack-destination{
		font-size: 12px;
	}

	.beamii-place2__sticky-actions-wrap{
		padding-inline: 12px;
	}

	.beamii-place2__sticky-actions{
		padding-inline: 9px;
	}

	.beamii-place2__sticky-btn,
	.beamii-place2__sticky-btn--tool{
		padding-inline: 12px;
	}
}


/* ========================================================================
 * 20. PLACE DOCUMENT VIEWER
 * ------------------------------------------------------------------------
 * Version: 1.2.0
 * Ansvar:
 * - Giver PDF-viewer en mere native og fokuseret dokumentoplevelse
 * - Samler handlinger i kompakt document chrome i stedet for store stacked cards
 * - Prioriterer selve dokumentfladen og reducerer vertikal støj på mobil
 * ===================================================================== */

/* ========================================================================
 * 22. INTERN PDF-VIEW / DOKUMENTVISNING
 * ---------------------------------------------------------
 * Version: 2.0.1
 *
 * Ændringer i denne version:
 * - Skifter til en mere ren, dokument-først PDF.js-visning
 * - Fjerner den tunge "kort i kort"-følelse og rydder op i spacing
 * - Samler dokumentheader, toolbar og canvas-flade i en roligere struktur
 * - Skjuler bundnav + feedback-fab i dokument-view og lader dokumentet fylde
 * ===================================================================== */

.beamii-place2__document-page{
	--bp-content-max: min(1660px, calc(100vw - 28px));
	--beamii-doc-shell-gap: clamp(10px, 1vw, 14px);
	--beamii-doc-toolbar-size: 44px;
	--beamii-doc-toolbar-radius: 16px;
	--beamii-doc-surface: rgba(255,255,255,.82);
	--beamii-doc-surface-strong: rgba(255,255,255,.92);
	--beamii-doc-border: rgba(17,24,39,.08);
	--beamii-doc-shadow: 0 18px 40px rgba(15,23,42,.10);
	background:
		radial-gradient(circle at top, rgba(255,255,255,.36) 0%, rgba(255,255,255,0) 32%),
		linear-gradient(180deg, #d9e6ef 0%, #e7eff5 34%, #d7e4ed 100%);
}

.beamii-place2__document-page .bottom-nav,
.beamii-place2__document-page .beamii-bottom-more,
.beamii-place2__document-page .beamii-feedback-btn{
	display: none !important;
}

.beamii-place2__document-page .topbar--place .searchbar{
	padding: 6px 10px;
	max-width: min(1440px, calc(100vw - 22px));
}

.beamii-place2__document-page .topbar-place__backtrack{
	min-height: 40px;
	padding: 4px 10px 4px 6px;
	border-radius: 14px;
}

.beamii-place2__document-page .topbar-place__backtrack-label{
	display: none;
}

.beamii-place2__document-page .topbar-place__backtrack-copy{
	gap: 0;
}

.beamii-place2__document-page .topbar-place__backtrack-destination{
	font-size: .84rem;
}

.beamii-place2__document-shell{
	padding-bottom: max(24px, env(safe-area-inset-bottom, 0px));
}

.beamii-place2__document-wrap{
	display: flex;
	padding-top: max(108px, calc(var(--topbar-total-h) + 18px));
	padding-bottom: max(28px, env(safe-area-inset-bottom, 0px));
	min-height: calc(100dvh - max(8px, env(safe-area-inset-bottom, 0px)));
}

.beamii-place2__document-card{
	flex: 1 1 auto;
	min-height: 0;
	display: grid;
	grid-template-rows: auto minmax(0, 1fr);
	gap: 12px;
}

.beamii-place2__document-header{
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	border-radius: 24px;
	background: var(--beamii-doc-surface-strong);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border: 1px solid rgba(255,255,255,.52);
	box-shadow:
		0 12px 28px rgba(15,23,42,.07),
		inset 0 1px 0 rgba(255,255,255,.6);
}

.beamii-place2__document-summary{
	min-width: 0;
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	align-items: center;
	gap: 12px;
}

.beamii-place2__document-badge{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-height: 34px;
	padding: 0 12px;
	border-radius: 999px;
	background: rgba(220,38,38,.10);
	color: #b91c1c;
	font-weight: 900;
	font-size: .74rem;
	letter-spacing: .04em;
	text-transform: uppercase;
	white-space: nowrap;
}

.beamii-place2__document-copy{
	min-width: 0;
	display: grid;
	gap: 2px;
}

.beamii-place2__document-title{
	margin: 0;
	font-size: clamp(1.02rem, .96rem + .34vw, 1.24rem);
	line-height: 1.14;
	letter-spacing: -.02em;
	color: var(--bp-text-strong);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.beamii-place2__document-meta{
	margin: 0;
	font-size: .84rem;
	line-height: 1.35;
	color: var(--bp-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.beamii-place2__document-actions{
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	min-width: 0;
}

.beamii-place2__document-back,
.beamii-place2__document-tool,
.beamii-place2__pdf-control{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: var(--beamii-doc-toolbar-size);
	padding: 0 14px;
	border-radius: var(--beamii-doc-toolbar-radius);
	border: 1px solid var(--beamii-doc-border);
	background: rgba(255,255,255,.9);
	color: var(--bp-text-strong);
	text-decoration: none;
	font-weight: 800;
	box-shadow: 0 8px 18px rgba(15,23,42,.05);
	transition:
		transform .16s ease,
		background .16s ease,
		border-color .16s ease,
		box-shadow .16s ease,
		opacity .16s ease;
	white-space: nowrap;
}

.beamii-place2__document-back{
	padding-inline: 16px;
}

.beamii-place2__document-tool:hover,
.beamii-place2__document-tool:focus-visible,
.beamii-place2__document-back:hover,
.beamii-place2__document-back:focus-visible,
.beamii-place2__pdf-control:hover,
.beamii-place2__pdf-control:focus-visible{
	transform: translateY(-1px);
	background: #fff;
	border-color: rgba(25,143,209,.24);
	box-shadow: 0 10px 20px rgba(15,23,42,.08);
	outline: none;
}

.beamii-place2__document-tool--primary{
	background: linear-gradient(180deg, rgba(232,245,255,.98), rgba(219,238,255,.98));
	border-color: rgba(58,136,209,.16);
	color: var(--bp-primary-3);
}

.beamii-place2__pdf-shell{
	min-height: 0;
	display: grid;
	grid-template-rows: auto minmax(0, 1fr);
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,.72), rgba(246,250,253,.82));
	border: 1px solid rgba(255,255,255,.5);
	box-shadow: var(--beamii-doc-shadow);
	overflow: hidden;
}

.beamii-place2__pdf-toolbar{
	position: sticky;
	top: 0;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 14px;
	background: rgba(248,251,253,.88);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom: 1px solid rgba(17,24,39,.07);
}

.beamii-place2__pdf-status,
.beamii-place2__pdf-controls{
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.beamii-place2__pdf-status-chip{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 34px;
	padding: 0 12px;
	border-radius: 999px;
	background: rgba(16,32,51,.05);
	color: var(--bp-text-strong);
	font-size: .82rem;
	font-weight: 700;
}

.beamii-place2__pdf-status-chip--muted{
	background: rgba(58,136,209,.08);
	color: #1d4e89;
}

.beamii-place2__pdf-control{
	padding-inline: 12px;
	min-width: 44px;
}

.beamii-place2__pdf-control--wide{
	min-width: 98px;
}

.beamii-place2__pdf-control[disabled]{
	opacity: .55;
	pointer-events: none;
}

.beamii-place2__pdf-viewport{
	position: relative;
	min-height: 0;
	overflow: auto;
	padding: clamp(10px, 1.3vw, 18px);
	overscroll-behavior: contain;
	scrollbar-gutter: stable both-edges;
}

.beamii-place2__pdf-pages{
	display: grid;
	justify-items: center;
	align-content: start;
	gap: 20px;
	min-height: 100%;
}

.beamii-place2__pdf-page{
	position: relative;
	width: max-content;
	max-width: none;
	padding-top: 38px;
	background: #fff;
	border: 1px solid rgba(15,23,42,.10);
	border-radius: 18px;
	box-shadow:
		0 18px 34px rgba(15,23,42,.12),
		0 2px 6px rgba(15,23,42,.05);
	overflow: hidden;
}

.beamii-place2__pdf-page-label{
	position: absolute;
	top: 10px;
	left: 12px;
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: 0 10px;
	border-radius: 999px;
	background: rgba(16,32,51,.06);
	color: var(--bp-muted);
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .02em;
}

.beamii-place2__pdf-canvas{
	display: block;
	background: #fff;
}

.beamii-place2__pdf-loading,
.beamii-place2__pdf-error{
	display: grid;
	justify-items: center;
	align-content: center;
	gap: 12px;
	min-height: min(64dvh, 720px);
	text-align: center;
	padding: 28px 20px;
}

.beamii-place2__pdf-spinner{
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 3px solid rgba(58,136,209,.18);
	border-top-color: rgba(58,136,209,.85);
	animation: beamii-place2-pdf-spin .85s linear infinite;
}

@keyframes beamii-place2-pdf-spin{
	to{ transform: rotate(360deg); }
}

.beamii-place2__pdf-loading-text,
.beamii-place2__pdf-error-text{
	margin: 0;
	font-size: .94rem;
	line-height: 1.55;
	color: var(--bp-muted);
}

.beamii-place2__pdf-error-icon{
	width: 56px;
	height: 56px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 18px;
	background: rgba(255,241,242,.92);
	color: #be123c;
	font-size: 1.3rem;
}

.beamii-place2__pdf-error-copy{
	display: grid;
	gap: 6px;
	max-width: 620px;
}

.beamii-place2__pdf-error-title{
	margin: 0;
	font-size: clamp(1.02rem, .96rem + .34vw, 1.28rem);
	line-height: 1.18;
	color: var(--bp-text-strong);
}

.beamii-place2__pdf-error-actions{
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	justify-content: center;
}

.beamii-place2__pdf-noscript{
	margin-top: 8px;
	padding: 14px 16px;
	border-radius: 16px;
	background: rgba(255,255,255,.82);
	border: 1px solid rgba(17,24,39,.08);
	font-size: .9rem;
	color: var(--bp-muted);
}

@media (max-width: 1199px){
	.beamii-place2__document-page{
		--bp-content-max: min(1380px, calc(100vw - 18px));
	}
}

@media (max-width: 767px){
	.beamii-place2__document-page{
		--bp-content-max: calc(100vw - 10px);
		--beamii-doc-toolbar-size: 42px;
		--beamii-doc-toolbar-radius: 14px;
		--beamii-doc-shell-gap: 12px;
	}

	.beamii-place2__document-page .topbar--place .searchbar{
		padding: 5px 6px;
		max-width: calc(100vw - 8px);
	}

	.beamii-place2__document-page .topbar-place__backtrack{
		min-height: 38px;
		padding-right: 8px;
	}

	.beamii-place2__document-page .topbar-place__backtrack-destination{
		font-size: .8rem;
	}

	.beamii-place2__document-wrap{
		padding-top: max(100px, calc(var(--topbar-total-h) + 12px));
		padding-bottom: max(16px, env(safe-area-inset-bottom, 0px));
	}

	.beamii-place2__document-header{
		grid-template-columns: 1fr;
		align-items: stretch;
		gap: 10px;
		padding: 12px;
		border-radius: 20px;
	}

	.beamii-place2__document-summary{
		grid-template-columns: auto minmax(0, 1fr);
		align-items: start;
	}

	.beamii-place2__document-title{
		white-space: normal;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.beamii-place2__document-meta{
		white-space: normal;
	}

	.beamii-place2__document-actions{
		justify-content: stretch;
	}

	.beamii-place2__document-back{
		flex: 1 1 auto;
		min-width: 0;
	}

	.beamii-place2__document-tool{
		padding-inline: 12px;
		min-width: 42px;
	}

	.beamii-place2__document-tool span{
		display: none;
	}

	.beamii-place2__pdf-shell{
		border-radius: 22px;
	}

	.beamii-place2__pdf-toolbar{
		padding: 10px;
	}

	.beamii-place2__pdf-toolbar,
	.beamii-place2__pdf-status,
	.beamii-place2__pdf-controls{
		gap: 6px;
	}

	.beamii-place2__pdf-status-chip{
		min-height: 30px;
		padding-inline: 10px;
		font-size: .76rem;
	}

	.beamii-place2__pdf-control{
		min-width: 40px;
		padding-inline: 10px;
	}

	.beamii-place2__pdf-control--wide{
		min-width: 88px;
	}

	.beamii-place2__pdf-viewport{
		padding: 10px;
	}

	.beamii-place2__pdf-pages{
		gap: 14px;
	}

	.beamii-place2__pdf-page{
		padding-top: 34px;
		border-radius: 14px;
	}

	.beamii-place2__pdf-page-label{
		top: 8px;
		left: 10px;
	}

	.beamii-place2__pdf-loading,
	.beamii-place2__pdf-error{
		min-height: min(56dvh, 540px);
		padding-inline: 16px;
	}
}

@media (max-width: 520px){
	.beamii-place2__document-page{
		--bp-content-max: calc(100vw - 8px);
	}

	.beamii-place2__document-wrap{
		padding-inline: 4px;
		padding-top: max(100px, calc(var(--topbar-total-h) + 10px));
	}

	.beamii-place2__document-header{
		padding: 10px;
		border-radius: 18px;
	}

	.beamii-place2__document-badge{
		min-height: 30px;
		padding-inline: 10px;
		font-size: .7rem;
	}

	.beamii-place2__document-title{
		font-size: .98rem;
	}

	.beamii-place2__document-meta{
		font-size: .75rem;
	}

	.beamii-place2__pdf-status-chip--muted{
		display: none;
	}

	.beamii-place2__pdf-control--wide span{
		display: none;
	}

	.beamii-place2__pdf-control--wide{
		min-width: 42px;
	}
}

/* ========================================================================
 * 27. IMAGE VIEWER / LINKLISTE BILLEDER
 * ===================================================================== */

.beamii-imageviewer[hidden]{
	display: none !important;
}

.beamii-imageviewer{
	position: fixed;
	inset: 0;
	z-index: 10030;
	display: grid;
	place-items: end center;
	padding:
		max(12px, env(safe-area-inset-top))
		max(12px, env(safe-area-inset-right))
		max(12px, env(safe-area-inset-bottom))
		max(12px, env(safe-area-inset-left));
	background: rgba(7,13,24,.58);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

.beamii-imageviewer__backdrop{
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
}

.beamii-imageviewer__dialog{
	position: relative;
	z-index: 2;
	width: min(100%, 1080px);
	max-height: min(94dvh, 940px);
	display: grid;
	grid-template-rows: auto minmax(0, 1fr) auto;
	overflow: hidden;
	border-radius: 28px;
	background: rgba(250,252,255,.98);
	border: 1px solid rgba(255,255,255,.68);
	box-shadow:
		0 28px 72px rgba(7,13,24,.30),
		inset 0 1px 0 rgba(255,255,255,.62);
	animation: beamiiImageViewerUp .18s ease forwards;
}

@keyframes beamiiImageViewerUp{
	from{
		opacity: 0;
		transform: translateY(16px) scale(.985);
	}
	to{
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.beamii-imageviewer__topbar{
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 14px 12px;
	border-bottom: 1px solid rgba(12,18,32,.08);
	background: rgba(255,255,255,.92);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.beamii-imageviewer__copy{
	min-width: 0;
	display: grid;
	gap: 3px;
}

.beamii-imageviewer__eyebrow{
	font-size: .72rem;
	line-height: 1.2;
	font-weight: 900;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: rgba(25,143,209,.86);
}

.beamii-imageviewer__title{
	margin: 0;
	font-size: clamp(1rem, .94rem + .28vw, 1.28rem);
	font-weight: 950;
	line-height: 1.12;
	letter-spacing: -.025em;
	color: rgba(12,18,32,.94);
	word-break: break-word;
}

.beamii-imageviewer__meta{
	margin: 0;
	font-size: .84rem;
	line-height: 1.38;
	color: rgba(12,18,32,.62);
}

.beamii-imageviewer__topbar-actions{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex: 0 0 auto;
}

.beamii-imageviewer__counter{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 0 11px;
	border-radius: 999px;
	background: rgba(12,18,32,.055);
	color: rgba(12,18,32,.66);
	font-size: .78rem;
	font-weight: 850;
	white-space: nowrap;
}

.beamii-imageviewer__close,
.beamii-imageviewer__nav,
.beamii-imageviewer__action{
	-webkit-tap-highlight-color: transparent;
}

.beamii-imageviewer__close{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 40px;
	padding: 0 13px;
	border-radius: 999px;
	border: 1px solid rgba(12,18,32,.08);
	background: rgba(12,18,32,.055);
	color: rgba(12,18,32,.88);
	font-weight: 850;
	cursor: pointer;
}

.beamii-imageviewer__close:hover,
.beamii-imageviewer__close:focus-visible{
	background: rgba(12,18,32,.08);
	outline: none;
}

.beamii-imageviewer__body{
	position: relative;
	min-height: 0;
	display: grid;
	grid-template-columns: 44px minmax(0, 1fr) 44px;
	gap: 8px;
	align-items: center;
	padding: 10px;
	background:
		radial-gradient(circle at 50% 0%, rgba(25,143,209,.10), transparent 34%),
		linear-gradient(180deg, rgba(239,246,252,.82), rgba(230,238,247,.74));
}

.beamii-imageviewer__stage{
	position: relative;
	min-width: 0;
	min-height: min(52dvh, 620px);
	height: min(66dvh, 700px);
	display: grid;
	place-items: center;
	overflow: hidden;
	border-radius: 22px;
	background:
		linear-gradient(135deg, rgba(12,18,32,.92), rgba(24,35,52,.86)),
		repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 8px, transparent 8px 16px);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.beamii-imageviewer__image{
	display: block;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	border-radius: 12px;
	box-shadow: 0 14px 34px rgba(0,0,0,.24);
}

.beamii-imageviewer__image[hidden],
.beamii-imageviewer__loading[hidden],
.beamii-imageviewer__error[hidden]{
	display: none !important;
}

.beamii-imageviewer__loading,
.beamii-imageviewer__error{
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	align-content: center;
	gap: 12px;
	padding: 20px;
	text-align: center;
	color: rgba(255,255,255,.88);
}

.beamii-imageviewer__spinner{
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border: 3px solid rgba(255,255,255,.22);
	border-top-color: rgba(255,255,255,.88);
	animation: beamiiImageViewerSpin .8s linear infinite;
}

@keyframes beamiiImageViewerSpin{
	to{ transform: rotate(360deg); }
}

.beamii-imageviewer__error-icon{
	width: 54px;
	height: 54px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 18px;
	background: rgba(255,255,255,.12);
	color: #fff;
	font-size: 1.25rem;
}

.beamii-imageviewer__error-copy{
	display: grid;
	gap: 5px;
	max-width: 440px;
	font-size: .92rem;
	line-height: 1.45;
}

.beamii-imageviewer__error-copy strong{
	font-size: 1rem;
	color: #fff;
}

.beamii-imageviewer__nav{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	border: 1px solid rgba(255,255,255,.58);
	background: rgba(255,255,255,.86);
	color: rgba(12,18,32,.86);
	box-shadow: 0 12px 24px rgba(12,18,32,.13);
	cursor: pointer;
	transition: transform .16s ease, background .16s ease, opacity .16s ease;
}

.beamii-imageviewer__nav:hover,
.beamii-imageviewer__nav:focus-visible{
	transform: translateY(-1px);
	background: #fff;
	outline: none;
}

.beamii-imageviewer__nav[hidden]{
	display: none !important;
}

.beamii-imageviewer__footer{
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	padding: 12px 14px 14px;
	border-top: 1px solid rgba(12,18,32,.08);
	background: rgba(255,255,255,.95);
}

.beamii-imageviewer__action{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 42px;
	padding: 0 15px;
	border-radius: 999px;
	border: 1px solid rgba(12,18,32,.08);
	background: rgba(12,18,32,.055);
	color: rgba(12,18,32,.88);
	text-decoration: none;
	font-size: .9rem;
	font-weight: 850;
	transition: transform .16s ease, background .16s ease, box-shadow .16s ease;
}

.beamii-imageviewer__action:hover,
.beamii-imageviewer__action:focus-visible{
	transform: translateY(-1px);
	background: rgba(12,18,32,.075);
	color: rgba(12,18,32,.96);
	outline: none;
}

.beamii-imageviewer__action--primary{
	border-color: transparent;
	background: linear-gradient(135deg, var(--bp-primary-2) 0%, var(--bp-primary) 100%);
	color: #fff;
	box-shadow: 0 12px 24px var(--bp-primary-shadow);
}

.beamii-imageviewer__action--primary:hover,
.beamii-imageviewer__action--primary:focus-visible{
	color: #fff;
	filter: brightness(1.03);
}

.beamii-imageviewer__close:focus-visible,
.beamii-imageviewer__nav:focus-visible,
.beamii-imageviewer__action:focus-visible{
	outline: 2px solid rgba(25,143,209,.32);
	outline-offset: 2px;
}

@media (min-width: 760px){
	.beamii-imageviewer{
		place-items: center;
		padding: max(18px, env(safe-area-inset-top)) max(18px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(18px, env(safe-area-inset-left));
	}

	.beamii-imageviewer__topbar{
		padding: 16px 18px 14px;
	}

	.beamii-imageviewer__body{
		grid-template-columns: 54px minmax(0, 1fr) 54px;
		gap: 12px;
		padding: 14px;
	}

	.beamii-imageviewer__stage{
		min-height: min(58dvh, 700px);
		height: min(68dvh, 760px);
	}

	.beamii-imageviewer__nav{
		width: 50px;
		height: 50px;
	}

	.beamii-imageviewer__footer{
		padding: 14px 18px 16px;
	}
}

@media (max-width: 520px){
	.beamii-imageviewer__dialog{
		width: 100%;
		max-height: calc(100dvh - max(18px, env(safe-area-inset-top)) - max(18px, env(safe-area-inset-bottom)));
		border-radius: 24px;
	}

	.beamii-imageviewer__topbar{
		align-items: flex-start;
		padding: 12px;
	}

	.beamii-imageviewer__topbar-actions{
		align-items: flex-end;
		flex-direction: column-reverse;
		gap: 6px;
	}

	.beamii-imageviewer__close{
		width: 42px;
		padding: 0;
	}

	.beamii-imageviewer__close span{
		display: none;
	}

	.beamii-imageviewer__body{
		grid-template-columns: minmax(0, 1fr);
		padding: 8px;
	}

	.beamii-imageviewer__stage{
		min-height: min(54dvh, 540px);
		height: min(62dvh, 620px);
		border-radius: 18px;
	}

	.beamii-imageviewer__nav{
		position: absolute;
		z-index: 3;
		top: 50%;
		transform: translateY(-50%);
		background: rgba(255,255,255,.90);
	}

	.beamii-imageviewer__nav:hover,
	.beamii-imageviewer__nav:focus-visible{
		transform: translateY(-50%);
	}

	.beamii-imageviewer__nav--prev{
		left: 16px;
	}

	.beamii-imageviewer__nav--next{
		right: 16px;
	}

	.beamii-imageviewer__footer{
		display: grid;
		grid-template-columns: 1fr;
		gap: 8px;
		padding: 10px 12px 12px;
	}

	.beamii-imageviewer__action{
		width: 100%;
		min-height: 46px;
	}
}

/* ========================================================================
 * Gallery block - slider only
 * ===================================================================== */
.beamii-place2__gallery,
.beamii-place2__gallery--grid,
.beamii-place2__gallery--slider{
	display:grid;
	grid-auto-flow:column;
	grid-template-columns:none;
	grid-auto-columns:minmax(236px, 82%);
	gap:12px;
	overflow-x:auto;
	overflow-y:hidden;
	padding:2px 2px 8px;
	margin-inline:-2px;
	-webkit-overflow-scrolling:touch;
	scroll-snap-type:x mandatory;
	scroll-padding-inline:2px;
	scrollbar-width:none;
}

.beamii-place2__gallery::-webkit-scrollbar,
.beamii-place2__gallery--grid::-webkit-scrollbar,
.beamii-place2__gallery--slider::-webkit-scrollbar{
	display:none;
}

.beamii-place2__gallery-item{
	position:relative;
	display:block;
	min-width:0;
	min-height:0;
	aspect-ratio:4 / 3;
	border-radius:22px;
	isolation:isolate;
	text-decoration:none;
	color:#fff;
	background:rgba(12,18,32,.06);
	border:1px solid rgba(12,18,32,.07);
	box-shadow:0 10px 30px rgba(15,23,42,.08);
	scroll-snap-align:start;
	scroll-snap-stop:always;
	transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.beamii-place2__gallery-item:hover,
.beamii-place2__gallery-item:focus-visible{
	transform:translateY(-2px);
	box-shadow:0 16px 38px rgba(15,23,42,.14);
	border-color:rgba(25,143,209,.28);
	color:#fff;
}

.beamii-place2__gallery-item:focus-visible{
	outline:3px solid rgba(25,143,209,.22);
	outline-offset:3px;
}

.beamii-place2__gallery-media,
.beamii-place2__gallery-media img,
.beamii-place2__gallery-skeleton{
	position:absolute;
	inset:0;
	display:block;
	width:100%;
	height:100%;
}

.beamii-place2__gallery-media{
	overflow:hidden;
	border-radius:inherit;
	background:linear-gradient(135deg, rgba(225,238,247,.9), rgba(196,219,235,.9));
}

.beamii-place2__gallery-media::after{
	content:"";
	position:absolute;
	inset:0;
	z-index:2;
	background:linear-gradient(180deg, rgba(10,18,30,0) 38%, rgba(10,18,30,.62) 100%);
	pointer-events:none;
}

.beamii-place2__gallery-skeleton{
	z-index:0;
	background:linear-gradient(90deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.44) 45%, rgba(255,255,255,.18) 90%);
	background-size:220% 100%;
	animation:beamiiPlaceSkeletonPulse 1.35s ease-in-out infinite;
}

.beamii-place2__gallery-media img{
	z-index:1;
	object-fit:cover;
	min-height:0;
	transition:transform .35s ease, opacity .2s ease;
}

.beamii-place2__gallery-item:hover .beamii-place2__gallery-media img,
.beamii-place2__gallery-item:focus-visible .beamii-place2__gallery-media img{
	transform:scale(1.035);
}

.beamii-place2__gallery-caption{
	position:absolute;
	left:10px;
	right:10px;
	bottom:10px;
	z-index:3;
	display:grid;
	gap:2px;
	padding:10px 11px;
	border-radius:16px;
	background:rgba(7,13,23,.48);
	border:1px solid rgba(255,255,255,.16);
	box-shadow:0 8px 24px rgba(0,0,0,.16);
	backdrop-filter:blur(10px);
	-webkit-backdrop-filter:blur(10px);
}

.beamii-place2__gallery-caption strong{
	font-size:.88rem;
	line-height:1.18;
	font-weight:900;
	letter-spacing:-.01em;
	white-space:nowrap;
	overflow:hidden;
	text-overflow:ellipsis;
}

.beamii-place2__gallery-caption span{
	font-size:.74rem;
	line-height:1.25;
	color:rgba(255,255,255,.82);
	display:-webkit-box;
	-webkit-line-clamp:2;
	-webkit-box-orient:vertical;
	overflow:hidden;
}

.beamii-place2__gallery-counter{
	position:absolute;
	top:10px;
	right:10px;
	z-index:3;
	display:inline-flex;
	align-items:center;
	min-height:26px;
	padding:0 9px;
	border-radius:999px;
	background:rgba(7,13,23,.48);
	border:1px solid rgba(255,255,255,.16);
	color:#fff;
	font-size:.72rem;
	font-weight:900;
	backdrop-filter:blur(10px);
	-webkit-backdrop-filter:blur(10px);
}

@media (min-width: 760px){
	.beamii-place2__gallery,
	.beamii-place2__gallery--grid,
	.beamii-place2__gallery--slider{
		grid-auto-columns:minmax(280px, 42%);
	}
}

@media (min-width: 1100px){
	.beamii-place2__gallery,
	.beamii-place2__gallery--grid,
	.beamii-place2__gallery--slider{
		grid-auto-columns:minmax(320px, 34%);
	}
}

/* ========================================================================
 * Gallery v2 controls / loading state
 * ===================================================================== */
.beamii-place2__gallery-shell{
	position:relative;
	display:grid;
	gap:10px;
}

.beamii-place2__gallery-item.is-image-loaded .beamii-place2__gallery-skeleton{
	opacity:0;
	animation:none;
	transition:opacity .2s ease;
}

.beamii-place2__gallery-item.is-image-error .beamii-place2__gallery-media::before{
	content:"Billedet kunne ikke indlæses";
	position:absolute;
	inset:0;
	z-index:4;
	display:grid;
	place-items:center;
	padding:18px;
	text-align:center;
	font-size:.82rem;
	font-weight:900;
	color:rgba(15,23,42,.78);
	background:linear-gradient(135deg, rgba(248,250,252,.94), rgba(226,232,240,.94));
}

.beamii-place2__gallery-controls{
	display:flex;
	align-items:center;
	justify-content:center;
	gap:8px;
	min-height:38px;
}

.beamii-place2__gallery-control{
	display:inline-grid;
	place-items:center;
	width:38px;
	height:38px;
	border:1px solid rgba(12,18,32,.08);
	border-radius:999px;
	background:#fff;
	color:#0f172a;
	box-shadow:0 8px 20px rgba(15,23,42,.08);
	cursor:pointer;
	transition:transform .16s ease, opacity .16s ease, box-shadow .16s ease;
}

.beamii-place2__gallery-control:hover,
.beamii-place2__gallery-control:focus-visible{
	transform:translateY(-1px);
	box-shadow:0 12px 26px rgba(15,23,42,.12);
	outline:none;
}

.beamii-place2__gallery-control:focus-visible{
	box-shadow:0 0 0 3px rgba(25,143,209,.18), 0 12px 26px rgba(15,23,42,.12);
}

.beamii-place2__gallery-control:disabled{
	opacity:.42;
	cursor:not-allowed;
	transform:none;
}

.beamii-place2__gallery-status{
	display:inline-flex;
	align-items:center;
	justify-content:center;
	min-height:32px;
	padding:0 11px;
	border-radius:999px;
	background:rgba(15,23,42,.05);
	border:1px solid rgba(15,23,42,.07);
	color:rgba(15,23,42,.72);
	font-size:.76rem;
	font-weight:900;
}

/* =====================================================
   PLACE map modal polish
   Version: 2026-04-25
   Ansvar: Gør Leaflet attribution og BeaMii map markers diskrete i stedets mini/full map.
===================================================== */
#beamiiMiniMap .leaflet-control-attribution,
.beamii-place2 [data-beamii-mini-map] .leaflet-control-attribution,
#beamiiFullMap .leaflet-control-attribution{
	max-width:min(70vw, 320px);
	padding:3px 7px;
	border-radius:999px;
	background:rgba(255,255,255,.84);
	color:rgba(20,38,60,.56);
	box-shadow:0 8px 20px rgba(15,23,42,.10);
	font-size:9px;
}

#beamiiMiniMap .beamii-map-marker,
.beamii-place2 [data-beamii-mini-map] .beamii-map-marker,
#beamiiFullMap .beamii-map-marker{
	z-index:650 !important;
}

/* =====================================================
   PLACE APP SHELL EDGE-TO-EDGE GUARD
   Version: 2026-04-25
   Ansvar:
   - Holder sted-side topbar/bundnav i samme edge-to-edge app-shell stil
   - Overstyrer kun tidligere place-specifik max-width på topbaren
===================================================== */
@media (max-width: 760px){
	.beamii-place2 .topbar--place{
		background:
			linear-gradient(180deg, rgba(235,245,252,.96) 0%, rgba(235,245,252,.74) 64%, rgba(235,245,252,0) 100%);
	}

	.beamii-place2 .topbar--place .searchbar{
		width: 100%;
		max-width: none;
		margin: 0;
		padding: 8px 10px;
		border-radius: 0 0 22px 22px;
	}
}
/* =====================================================
   PLACE APP SHELL EDGE-TO-EDGE SQUARE GUARD
   Version: 2026-04-25
   Ansvar:
   - Holder sted-side topbar/bundnav i samme kantede edge-to-edge app-shell stil
   - Overstyrer kun tidligere place-specifik max-width/radius på topbaren
===================================================== */
@media (max-width: 760px){
	.beamii-place2 .topbar--place{
		background:
			linear-gradient(180deg, rgba(235,245,252,.98) 0%, rgba(235,245,252,.84) 66%, rgba(235,245,252,0) 100%);
	}

	.beamii-place2 .topbar--place .searchbar{
		width: 100%;
		max-width: none;
		margin: 0;
		padding: 8px 10px;
		border-radius: 0;
	}
}

