/* ==========================================================================
   Nordic Beauty Solutions – Designsystem
   Design tokens (CSS-variabler) kan genbruges i Elementor Pro senere.
   ========================================================================== */

:root {
	--nbs-bg: #FBF8F3;            /* varm hvid */
	--nbs-bg-alt: #F4EEE4;        /* sand */
	--nbs-bg-deep: #EDE4D5;       /* dyb beige */
	--nbs-champagne: #C2A05E;     /* champagne/guld (fra logo) */
	--nbs-champagne-dark: #A0813F;
	--nbs-champagne-soft: #E9DCC2;
	--nbs-taupe: #8C7B66;
	--nbs-ink: #2C2A26;           /* næsten sort, varm */
	--nbs-ink-soft: #5F584D;
	--nbs-white: #FFFFFF;
	--nbs-line: #E6DCC9;
	--nbs-serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
	--nbs-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--nbs-radius: 18px;
	--nbs-radius-sm: 12px;
	--nbs-shadow: 0 12px 34px rgba(86, 70, 41, 0.10);
	--nbs-shadow-soft: 0 6px 18px rgba(86, 70, 41, 0.07);
	--nbs-maxw: 1180px;
}

/* ---------- Grundlag ---------- */

body.nbs {
	background: var(--nbs-bg);
	color: var(--nbs-ink);
	font-family: var(--nbs-sans);
	font-size: 16px;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
}

/* Diskret, luksuriøs grain-tekstur */
body.nbs::before {
	content: "";
	position: fixed;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	opacity: 0.035;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

body.nbs #page,
body.nbs .nbs-footer,
body.nbs .nbs-sticky-bar {
	position: relative;
	z-index: 1;
}

body.nbs h1, body.nbs h2, body.nbs h3,
body.nbs h4, body.nbs .entry-title {
	font-family: var(--nbs-serif);
	font-weight: 600;
	color: var(--nbs-ink);
	letter-spacing: 0.01em;
	line-height: 1.18;
}

body.nbs h1 { font-size: clamp(2.1rem, 5vw, 3.4rem); }
body.nbs h2 { font-size: clamp(1.7rem, 3.6vw, 2.4rem); }
body.nbs h3 { font-size: clamp(1.25rem, 2.4vw, 1.55rem); }

body.nbs a { color: var(--nbs-champagne-dark); }
body.nbs a:hover { color: var(--nbs-ink); }

.nbs-container {
	max-width: var(--nbs-maxw);
	margin: 0 auto;
	padding: 0 22px;
}

.nbs-kicker {
	display: inline-block;
	font-family: var(--nbs-sans);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--nbs-champagne-dark);
	margin-bottom: 14px;
}

.nbs-lead {
	font-size: 1.08rem;
	color: var(--nbs-ink-soft);
	max-width: 640px;
}

.nbs-center { text-align: center; }
.nbs-center .nbs-lead { margin-left: auto; margin-right: auto; }

/* ---------- Sektioner ---------- */

.nbs-section { padding: 84px 0; }
.nbs-section-alt { background: var(--nbs-bg-alt); }
.nbs-section-deep {
	background: linear-gradient(160deg, var(--nbs-bg-deep) 0%, var(--nbs-bg-alt) 100%);
}
.nbs-section-head { margin-bottom: 44px; }

/* ---------- Knapper ---------- */

.nbs-btn {
	display: inline-block;
	font-family: var(--nbs-sans);
	font-weight: 600;
	font-size: 0.95rem;
	letter-spacing: 0.03em;
	padding: 15px 32px;
	border-radius: 999px;
	text-decoration: none;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
	border: 1.5px solid transparent;
	cursor: pointer;
	text-align: center;
}

.nbs-btn:hover { transform: translateY(-2px); }

.nbs-btn-gold {
	background: linear-gradient(135deg, var(--nbs-champagne) 0%, var(--nbs-champagne-dark) 100%);
	color: var(--nbs-white) !important;
	box-shadow: 0 8px 22px rgba(162, 130, 65, 0.32);
}
.nbs-btn-gold:hover { box-shadow: 0 12px 28px rgba(162, 130, 65, 0.42); }

.nbs-btn-ghost {
	background: transparent;
	border-color: var(--nbs-champagne);
	color: var(--nbs-ink) !important;
}
.nbs-btn-ghost:hover { background: var(--nbs-champagne-soft); }

.nbs-btn-sm { padding: 10px 22px; font-size: 0.85rem; }

.nbs-btn-row {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	align-items: center;
}

.nbs-textlink {
	font-weight: 600;
	font-size: 0.92rem;
	text-decoration: none;
	border-bottom: 1px solid var(--nbs-champagne);
	padding-bottom: 2px;
}

/* ---------- Astra header-forfining ---------- */

body.nbs .site-header,
body.nbs .main-header-bar,
body.nbs .ast-primary-header-bar {
	background: rgba(251, 248, 243, 0.94);
	backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--nbs-line);
	box-shadow: none;
}

body.nbs .main-header-menu a {
	font-family: var(--nbs-sans);
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--nbs-ink);
}

body.nbs .main-header-menu a:hover { color: var(--nbs-champagne-dark); }

body.nbs .nbs-menu-cta a {
	background: linear-gradient(135deg, var(--nbs-champagne) 0%, var(--nbs-champagne-dark) 100%);
	color: #fff !important;
	border-radius: 999px;
	padding: 10px 24px !important;
	margin-left: 10px;
	line-height: 1 !important;
}

body.nbs .custom-logo { max-height: 64px; width: auto; }

/* Skjul Astras egen footer – temaet leverer sin egen premium-footer */
body.nbs .site-footer { display: none; }

/* Fuldbredde-templates: ophæv Astras indholdscontainer */
body.nbs-fullwidth #content .ast-container,
body.nbs-fullwidth #content .ast-container-inner {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
}
body.nbs-fullwidth #content #primary { padding: 0; margin: 0; }

/* ---------- Hero ---------- */

.nbs-hero {
	position: relative;
	overflow: hidden;
	padding: 110px 0 96px;
	background:
		radial-gradient(900px 480px at 85% -10%, rgba(194, 160, 94, 0.16) 0%, transparent 60%),
		radial-gradient(700px 420px at -10% 110%, rgba(194, 160, 94, 0.12) 0%, transparent 55%),
		linear-gradient(165deg, #FBF8F3 0%, #F2EBDE 100%);
}

.nbs-hero h1 { max-width: 720px; margin-bottom: 20px; }
.nbs-hero .nbs-lead { margin-bottom: 34px; }
.nbs-hero-sub { margin-top: 22px; font-size: 0.92rem; }

.nbs-hero-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 26px;
	margin-top: 46px;
	padding-top: 26px;
	border-top: 1px solid var(--nbs-line);
	font-size: 0.85rem;
	color: var(--nbs-ink-soft);
}

.nbs-hero-badges span::before {
	content: "";
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--nbs-champagne);
	margin-right: 9px;
	vertical-align: 2px;
}

/* ---------- Kort & grids ---------- */

.nbs-grid {
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.nbs-grid-3 { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }

.nbs-card {
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: var(--nbs-radius);
	padding: 30px 28px;
	box-shadow: var(--nbs-shadow-soft);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	display: flex;
	flex-direction: column;
}

.nbs-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--nbs-shadow);
}

.nbs-card h3 { margin: 0 0 10px; }
.nbs-card h3 a { color: var(--nbs-ink); text-decoration: none; }
.nbs-card p { color: var(--nbs-ink-soft); font-size: 0.95rem; margin: 0 0 16px; }

.nbs-card-meta {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	font-size: 0.85rem;
	color: var(--nbs-taupe);
	margin-bottom: 18px;
}

.nbs-card-meta strong { color: var(--nbs-champagne-dark); font-weight: 600; }

.nbs-card-actions { margin-top: auto; display: flex; gap: 10px; flex-wrap: wrap; }

.nbs-card-icon {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: var(--nbs-champagne-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 18px;
	color: var(--nbs-champagne-dark);
}
.nbs-card-icon svg { width: 26px; height: 26px; }

/* Kategorikort */
.nbs-kategori-kort { text-decoration: none; }
.nbs-kategori-kort .nbs-count {
	font-size: 0.8rem;
	color: var(--nbs-taupe);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* ---------- Trust ---------- */

.nbs-trust-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.nbs-trust-item {
	background: rgba(255, 255, 255, 0.65);
	border: 1px solid var(--nbs-line);
	border-radius: var(--nbs-radius-sm);
	padding: 22px 20px;
}

.nbs-trust-item h3 { font-family: var(--nbs-sans); font-size: 0.98rem; font-weight: 600; margin: 0 0 6px; }
.nbs-trust-item p { font-size: 0.88rem; color: var(--nbs-ink-soft); margin: 0; }

/* ---------- Forløb (Før du booker) ---------- */

.nbs-steps {
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	counter-reset: nbs-step;
}

.nbs-step {
	position: relative;
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: var(--nbs-radius-sm);
	padding: 26px 22px 22px;
	counter-increment: nbs-step;
}

.nbs-step::before {
	content: counter(nbs-step, decimal-leading-zero);
	font-family: var(--nbs-serif);
	font-size: 1.6rem;
	color: var(--nbs-champagne);
	display: block;
	margin-bottom: 8px;
}

.nbs-step h3 { font-family: var(--nbs-sans); font-size: 1rem; font-weight: 600; margin: 0 0 6px; }
.nbs-step p { font-size: 0.9rem; color: var(--nbs-ink-soft); margin: 0; }

/* ---------- Priser ---------- */

.nbs-pris-nav {
	position: sticky;
	top: 0;
	z-index: 30;
	display: flex;
	gap: 8px;
	overflow-x: auto;
	padding: 12px 0;
	background: var(--nbs-bg);
	border-bottom: 1px solid var(--nbs-line);
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.nbs-pris-nav::-webkit-scrollbar { display: none; }

.nbs-pris-nav a {
	flex: 0 0 auto;
	font-size: 0.85rem;
	font-weight: 500;
	text-decoration: none;
	color: var(--nbs-ink);
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: 999px;
	padding: 8px 18px;
	white-space: nowrap;
}
.nbs-pris-nav a:hover { border-color: var(--nbs-champagne); color: var(--nbs-champagne-dark); }

.nbs-accordion {
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: var(--nbs-radius-sm);
	margin-bottom: 14px;
	overflow: hidden;
}

.nbs-accordion > button {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	background: none;
	border: 0;
	padding: 20px 24px;
	font-family: var(--nbs-serif);
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--nbs-ink);
	cursor: pointer;
	text-align: left;
}

.nbs-accordion > button::after {
	content: "+";
	font-family: var(--nbs-sans);
	font-size: 1.3rem;
	color: var(--nbs-champagne-dark);
	transition: transform 0.2s ease;
}

.nbs-accordion.open > button::after { transform: rotate(45deg); }
.nbs-accordion-body { display: none; padding: 0 24px 10px; }
.nbs-accordion.open .nbs-accordion-body { display: block; }

.nbs-prisliste { list-style: none; margin: 0; padding: 0; }

.nbs-prislinje {
	display: flex;
	align-items: baseline;
	gap: 14px;
	padding: 14px 0;
	border-top: 1px solid var(--nbs-line);
	flex-wrap: wrap;
}
.nbs-prislinje:first-child { border-top: 0; }

.nbs-prislinje .navn { flex: 1 1 260px; font-weight: 500; font-size: 0.95rem; }
.nbs-prislinje .navn small { display: block; font-weight: 400; color: var(--nbs-taupe); font-size: 0.82rem; }
.nbs-prislinje .tid { flex: 0 0 auto; color: var(--nbs-taupe); font-size: 0.85rem; }
.nbs-prislinje .pris { flex: 0 0 auto; font-weight: 600; color: var(--nbs-champagne-dark); font-size: 0.98rem; min-width: 86px; text-align: right; }
.nbs-prislinje .book { flex: 0 0 auto; }

.nbs-prislinje .book a {
	font-size: 0.78rem;
	font-weight: 600;
	text-decoration: none;
	border: 1px solid var(--nbs-champagne);
	border-radius: 999px;
	padding: 6px 14px;
	color: var(--nbs-champagne-dark);
}
.nbs-prislinje .book a:hover { background: var(--nbs-champagne); color: #fff; }

/* ---------- FAQ ---------- */

.nbs-faq-item {
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: var(--nbs-radius-sm);
	margin-bottom: 10px;
	overflow: hidden;
}

.nbs-faq-item > button {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	background: none;
	border: 0;
	padding: 16px 20px;
	font-family: var(--nbs-sans);
	font-size: 0.98rem;
	font-weight: 600;
	color: var(--nbs-ink);
	cursor: pointer;
	text-align: left;
}

.nbs-faq-item > button::after {
	content: "+";
	color: var(--nbs-champagne-dark);
	font-size: 1.15rem;
	transition: transform 0.2s ease;
	flex: 0 0 auto;
}

.nbs-faq-item.open > button::after { transform: rotate(45deg); }
.nbs-faq-body { display: none; padding: 0 20px 18px; color: var(--nbs-ink-soft); font-size: 0.93rem; }
.nbs-faq-item.open .nbs-faq-body { display: block; }

/* ---------- Anmeldelser ---------- */

.nbs-review {
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: var(--nbs-radius);
	padding: 28px 26px;
	box-shadow: var(--nbs-shadow-soft);
}

.nbs-review .stjerner { color: var(--nbs-champagne); letter-spacing: 3px; margin-bottom: 10px; font-size: 0.95rem; }
.nbs-review blockquote { margin: 0 0 14px; font-family: var(--nbs-serif); font-size: 1.1rem; font-style: italic; line-height: 1.5; }
.nbs-review cite { font-style: normal; font-size: 0.85rem; color: var(--nbs-taupe); }

/* ---------- CTA-sektion ---------- */

.nbs-cta-panel {
	background:
		radial-gradient(640px 300px at 90% -20%, rgba(255, 255, 255, 0.20) 0%, transparent 60%),
		linear-gradient(135deg, #3A352C 0%, #57503F 100%);
	border-radius: calc(var(--nbs-radius) + 6px);
	padding: clamp(40px, 7vw, 76px);
	text-align: center;
	color: #F6F1E7;
}

.nbs-cta-panel h2 { color: #fff; margin-bottom: 12px; }
.nbs-cta-panel p { color: rgba(246, 241, 231, 0.85); max-width: 560px; margin: 0 auto 30px; }
.nbs-cta-panel .nbs-btn-row { justify-content: center; }
.nbs-cta-panel .nbs-btn-ghost { border-color: rgba(246, 241, 231, 0.6); color: #F6F1E7 !important; }
.nbs-cta-panel .nbs-btn-ghost:hover { background: rgba(255, 255, 255, 0.1); }

/* ---------- Behandlingsside (single) ---------- */

.nbs-b-hero { padding: 76px 0 56px; }
.nbs-b-hero .nbs-lead { margin-bottom: 28px; }

.nbs-fakta {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	margin: 36px 0 0;
}

.nbs-fakta-item {
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: var(--nbs-radius-sm);
	padding: 16px 18px;
}

.nbs-fakta-item .label {
	display: block;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--nbs-taupe);
	margin-bottom: 4px;
}

.nbs-fakta-item .vaerdi { font-weight: 600; font-size: 0.98rem; color: var(--nbs-ink); }

.nbs-b-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 48px;
	align-items: start;
}

.nbs-b-indhold section { margin-bottom: 46px; }
.nbs-b-indhold h2 {
	font-size: 1.55rem;
	margin-bottom: 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--nbs-line);
}
.nbs-b-indhold p, .nbs-b-indhold li { color: var(--nbs-ink-soft); font-size: 0.97rem; }

.nbs-b-aside {
	position: sticky;
	top: 90px;
}

.nbs-b-aside .nbs-card { gap: 4px; }
.nbs-b-aside .nbs-card .nbs-btn { width: 100%; margin-top: 10px; }
.nbs-b-aside .pris-fra { font-family: var(--nbs-serif); font-size: 1.9rem; color: var(--nbs-champagne-dark); }
.nbs-b-aside .pris-fra small { font-family: var(--nbs-sans); font-size: 0.8rem; color: var(--nbs-taupe); display: block; }

.nbs-disclaimer {
	font-size: 0.82rem;
	color: var(--nbs-taupe);
	background: var(--nbs-bg-alt);
	border-radius: var(--nbs-radius-sm);
	padding: 14px 18px;
	margin-top: 26px;
}

/* Relaterede behandlinger */
.nbs-relaterede { margin-top: 26px; }

/* ---------- Arkiv (behandlingsoversigt) ---------- */

.nbs-arkiv-hero { padding: 70px 0 30px; }

.nbs-kategori-pills {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin: 24px 0 8px;
}

.nbs-kategori-pills a {
	font-size: 0.85rem;
	font-weight: 500;
	text-decoration: none;
	color: var(--nbs-ink);
	background: var(--nbs-white);
	border: 1px solid var(--nbs-line);
	border-radius: 999px;
	padding: 8px 18px;
}

.nbs-kategori-pills a.aktiv,
.nbs-kategori-pills a:hover {
	background: var(--nbs-champagne);
	border-color: var(--nbs-champagne);
	color: #fff;
}

/* ---------- Standardsider ---------- */

.nbs-page-hero { padding: 70px 0 40px; }
.nbs-page-content { padding-bottom: 80px; }
.nbs-page-content .nbs-prose { max-width: 760px; }
.nbs-prose h2 { margin-top: 2em; }
.nbs-prose p, .nbs-prose li { color: var(--nbs-ink-soft); }

/* ---------- Footer ---------- */

.nbs-footer {
	background: #2F2B24;
	color: #CFC7B8;
	margin-top: 0;
	font-size: 0.92rem;
}

.nbs-footer-grid {
	display: grid;
	gap: 38px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	padding-top: 64px;
	padding-bottom: 48px;
}

.nbs-footer h3 {
	color: #fff;
	font-family: var(--nbs-sans);
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	margin-bottom: 16px;
}

.nbs-footer ul { list-style: none; margin: 0; padding: 0; }
.nbs-footer li { margin-bottom: 8px; }
.nbs-footer a { color: #CFC7B8; text-decoration: none; }
.nbs-footer a:hover { color: var(--nbs-champagne); }

.nbs-footer-logo img { max-height: 56px; width: auto; filter: brightness(10); }
.nbs-footer-logotext { font-family: var(--nbs-serif); font-size: 1.3rem; color: #fff; }
.nbs-footer-brand p { font-size: 0.88rem; line-height: 1.6; }
.nbs-footer .nbs-btn { margin-top: 8px; }

.nbs-footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding: 20px 0;
	font-size: 0.8rem;
	color: #99917F;
}
.nbs-footer-bottom p { margin: 0; }

/* ---------- Sticky mobilbar ---------- */

.nbs-sticky-bar {
	display: none;
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 999;
	background: rgba(251, 248, 243, 0.97);
	backdrop-filter: blur(10px);
	border-top: 1px solid var(--nbs-line);
	padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
	gap: 10px;
}

.nbs-sticky-bar a {
	flex: 1;
	text-align: center;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	padding: 13px 8px;
	border-radius: 999px;
	color: var(--nbs-ink);
	border: 1.5px solid var(--nbs-line);
	background: var(--nbs-white);
}

.nbs-sticky-bar .nbs-sticky-book {
	background: linear-gradient(135deg, var(--nbs-champagne) 0%, var(--nbs-champagne-dark) 100%);
	color: #fff;
	border-color: transparent;
	flex: 1.4;
}

/* ---------- Responsivt ---------- */

@media (max-width: 921px) {
	.nbs-b-layout { grid-template-columns: 1fr; }
	.nbs-b-aside { position: static; }
}

@media (max-width: 768px) {
	.nbs-section { padding: 56px 0; }
	.nbs-hero { padding: 64px 0 56px; }
	.nbs-sticky-bar { display: flex; }
	body.nbs { padding-bottom: 74px; } /* plads til sticky bar */
	.nbs-footer-grid { padding-top: 44px; }
	.nbs-prislinje .tid { display: none; }
	.nbs-btn { width: 100%; }
	.nbs-btn-row .nbs-btn { width: auto; flex: 1 1 auto; }
}

@media (prefers-reduced-motion: reduce) {
	.nbs-btn, .nbs-card { transition: none; }
}
