/*
 * Citymap Landing Page Styles
 * Depends on: main-v2.css (tokens, base, nav, footer)
 * Warm paper hero. Mobile-first. 390px base.
 */

/* ============================================================
   HERO (warm editorial, light bg)
   ============================================================ */
.pg-cm-hero {
	position: relative;
	background: linear-gradient(160deg, var(--pg-bone) 0%, var(--pg-paper) 60%, #E8DCC8 100%);
	overflow: hidden;
	padding: clamp(120px, 15vw, 150px) 0 clamp(64px, 8vw, 96px);
	color: var(--pg-ink);
}

/* Immersive night-map: cool glow + lit street grid toward the poster */
.pg-cm-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background: radial-gradient(135% 120% at 80% -6%, rgba(27, 32, 48, 0.24), rgba(31, 38, 64, 0.07) 42%, transparent 68%);
}
.pg-cm-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background-image:
		repeating-linear-gradient(0deg, rgba(42, 37, 31, 0.09) 0 1px, transparent 1px 32px),
		repeating-linear-gradient(90deg, rgba(42, 37, 31, 0.09) 0 1px, transparent 1px 32px),
		repeating-linear-gradient(38deg, rgba(201, 160, 119, 0.2) 0 1.6px, transparent 1.6px 68px);
	-webkit-mask-image: radial-gradient(150% 130% at 80% -2%, #000 22%, transparent 76%);
	mask-image: radial-gradient(150% 130% at 80% -2%, #000 22%, transparent 76%);
}

/* Street-map canvas is a poster-style decoration — keep it but hide the old dark starfield
   The poster-inner canvas (pgHeroStreets) is fine to keep as decorative poster preview */
.pg-cm-hero__canvas {
	display: none;
}

.pg-cm-hero__wrap {
	position: relative;
	z-index: 2;
}

.pg-cm-breadcrumb {
	font-size: 13px;
	color: var(--pg-warm-grey-text);
	margin-bottom: 22px;
}

.pg-cm-breadcrumb a {
	color: var(--pg-warm-grey-text);
	transition: color .2s ease;
}

.pg-cm-breadcrumb a:hover {
	color: var(--pg-brass-text);
}

.pg-cm-breadcrumb span[aria-hidden] {
	margin: 0 6px;
	opacity: .5;
}

.pg-cm-breadcrumb [aria-current] {
	color: var(--pg-brass-text);
}

.pg-cm-hero__grid {
	display: flex;
	flex-direction: column;
	gap: 52px;
	align-items: center;
}

.pg-cm-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	padding: 7px 15px;
	border: 1px solid rgba(182,137,63,.4);
	border-radius: var(--radius-pill);
	margin-bottom: 24px;
	font-size: 12px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--pg-brass-text);
	font-weight: 700;
}

.pg-cm-hero__badge-dot {
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--pg-brass);
	flex-shrink: 0;
}

.pg-cm-hero__h1 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(38px, 5vw, 62px);
	line-height: 1.03;
	letter-spacing: -.01em;
	margin: 0 0 20px;
	color: var(--pg-ink);
	text-wrap: balance;
}

.pg-cm-hero__sub {
	color: var(--pg-warm-grey-text);
	font-size: clamp(16px, 2vw, 18px);
	line-height: 1.6;
	margin: 0 0 32px;
	max-width: 30em;
}

.pg-cm-hero__cta-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 18px;
}

.pg-cm-hero__secondary {
	color: var(--pg-ink);
	font-size: 15.5px;
	border-bottom: 1px solid rgba(42,37,31,.35);
	padding-bottom: 3px;
	transition: border-color .25s ease, color .25s ease;
}

.pg-cm-hero__secondary:hover {
	border-color: var(--pg-brass);
	color: var(--pg-brass-text);
}

/* Poster visual */
.pg-cm-hero__visual {
	display: flex;
	justify-content: center;
	width: 100%;
}

.pg-cm-hero__poster-col {
	max-width: 360px;
	width: 100%;
}

.pg-cm-hero__poster-frame {
	background: var(--pg-ink);
	padding: 14px;
	border-radius: var(--radius-flat);
	box-shadow: 0 30px 70px rgba(27,26,23,.22);
}

.pg-cm-hero__poster-inner {
	position: relative;
	width: 100%;
	aspect-ratio: 3 / 4;
	background: #141a30;
	overflow: hidden;
	border: 1px solid rgba(182,137,63,.18);
}

.pg-cm-hero__poster-canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.pg-cm-hero__poster-pin {
	position: absolute;
	left: 54%;
	top: 40%;
	width: 14px;
	height: 14px;
	border-radius: 50% 50% 50% 0;
	background: var(--pg-brass);
	transform: translate(-50%, -100%) rotate(-45deg);
	box-shadow: 0 4px 10px rgba(0,0,0,.4);
}

.pg-cm-hero__poster-border {
	position: absolute;
	inset: 14px;
	border: 1px solid rgba(217,201,168,.22);
	pointer-events: none;
}

.pg-cm-hero__poster-caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 0 9% 9%;
	text-align: center;
	color: #EDEBF6;
}

.pg-cm-hero__poster-city {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 26px;
}

.pg-cm-hero__poster-coords {
	font-size: 9px;
	letter-spacing: .4em;
	text-transform: uppercase;
	color: #9DA4C4;
	margin-top: 7px;
	padding-left: .4em;
}

@media (min-width: 860px) {
	.pg-cm-hero__grid {
		display: grid;
		grid-template-columns: 1.04fr .96fr;
		gap: 56px;
		align-items: center;
	}
	.pg-cm-hero__visual {
		justify-content: flex-end;
	}
	.pg-cm-hero__poster-col {
		margin: 0 auto;
	}
}

/* ============================================================
   FEATURE
   ============================================================ */
.pg-cm-feature {
	padding: clamp(64px, 8vw, 96px) 0;
}

.pg-cm-feature__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 48px;
	align-items: center;
}

.pg-cm-feature__badge {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	padding: 7px 15px;
	border: 1px solid rgba(27,26,23,.14);
	border-radius: var(--radius-pill);
	margin-bottom: 24px;
	font-size: 12px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--pg-warm-grey-text);
	font-weight: 700;
}

.pg-cm-feature__badge-dot {
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--pg-brass);
	flex-shrink: 0;
}

.pg-cm-feature__h2 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(28px, 3.4vw, 46px);
	line-height: 1.06;
	letter-spacing: -.01em;
	margin: 0;
	color: var(--pg-ink);
	text-wrap: balance;
}

.pg-cm-feature__body {
	color: #4A4742;
	font-size: 17px;
	line-height: 1.7;
	margin: 0;
}

/* ============================================================
   SHAPES + KAARTSTIJLEN
   ============================================================ */
.pg-cm-options {
	padding: clamp(64px, 8vw, 96px) 0;
}

.pg-cm-options__h2 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(28px, 3.4vw, 46px);
	line-height: 1.06;
	letter-spacing: -.01em;
	margin: 0 0 36px;
	color: var(--pg-ink);
	text-wrap: balance;
}

.pg-cm-options__eyebrow {
	font-size: 12.5px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--pg-warm-grey-text);
	font-weight: 700;
	margin: 0 0 20px;
}

.pg-cm-shapes {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
	gap: 12px;
	margin-bottom: 40px;
}

.pg-cm-shape-card {
	border: 1px solid var(--pg-hairline);
	border-radius: var(--radius-sm);
	padding: 14px;
	text-align: center;
	background: var(--pg-card);
	transition: border-color .2s ease;
}

.pg-cm-shape-card--selected,
.pg-cm-shape-card:hover {
	border-color: var(--pg-brass);
	background: rgba(176,135,91,.06);
}

.pg-cm-shape-card__preview {
	width: 52px;
	height: 52px;
	margin: 0 auto 8px;
	background: linear-gradient(160deg, #161d3e, #241a45);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #E7DFFb;
	font-family: var(--font-display);
	font-size: 16px;
}

.pg-cm-shape-card__preview--circle  { clip-path: circle(50%); }
.pg-cm-shape-card__preview--heart   { clip-path: polygon(50% 88%,10% 56%,1% 35%,7% 17%,27% 11%,50% 26%,73% 11%,93% 17%,99% 35%,90% 56%); }
.pg-cm-shape-card__preview--classic { /* rect, no clip */ }
.pg-cm-shape-card__preview--square  { border-radius: 6px; }
.pg-cm-shape-card__preview--skyline { border-radius: 27px 27px 4px 4px; }
.pg-cm-shape-card__preview--hex     { clip-path: polygon(25% 5%,75% 5%,100% 50%,75% 95%,25% 95%,0 50%); }

.pg-cm-shape-card__label {
	display: block;
	font-weight: 700;
	font-size: 12.5px;
	color: var(--pg-ink);
}

/* Palettes / map styles */
.pg-cm-palettes {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

.pg-cm-palette-card {
	text-align: center;
}

.pg-cm-palette-card__swatch {
	width: 64px;
	height: 50px;
	border-radius: 7px;
	border: 1px solid rgba(27,26,23,.1);
}

.pg-cm-palette-card__swatch--klassiek  { background: linear-gradient(135deg, #0E1426, #2A3354); }
.pg-cm-palette-card__swatch--bordeaux  { background: linear-gradient(135deg, #3a1820, #7a2e3a); }
.pg-cm-palette-card__swatch--navy      { background: linear-gradient(135deg, #10233f, #1f4f7a); }
.pg-cm-palette-card__swatch--teal      { background: linear-gradient(135deg, #0f2a24, #1f6b54); }
.pg-cm-palette-card__swatch--amber     { background: linear-gradient(135deg, #2a2010, #3c2d14); }
.pg-cm-palette-card__swatch--parel     { background: linear-gradient(135deg, #F3ECDD, #E3D6BC); }

.pg-cm-palette-card__name {
	display: block;
	font-size: 11.5px;
	color: var(--pg-warm-grey-text);
	margin-top: 7px;
}

/* ============================================================
   CLOSING CTA (warm paper, ink text)
   ============================================================ */
.pg-cm-cta {
	position: relative;
	background: var(--pg-paper);
	border-top: 1px solid var(--pg-hairline);
	padding: clamp(80px, 10vw, 108px) 0;
	text-align: center;
	color: var(--pg-ink);
}

/* Hide the dark starfield canvas — it's decorative only in the poster artwork */
.pg-cta-stars {
	display: none;
}

.pg-cm-cta__wrap {
	position: relative;
	z-index: 1;
}

.pg-cm-cta__script {
	font-size: 32px;
	color: var(--pg-brass-text);
	margin-bottom: 6px;
}

.pg-cm-cta__h2 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(28px, 3.8vw, 52px);
	line-height: 1.05;
	color: var(--pg-ink);
	margin: 0 auto 28px;
	max-width: 15em;
	text-wrap: balance;
}

/* ============================================================
   FAQ
   ============================================================ */
.pg-cm-faq {
	background: var(--pg-bone);
	padding: clamp(64px, 8vw, 104px) 0;
}

.pg-cm-faq__inner {
	max-width: 880px;
	margin: 0 auto;
	padding: 0 clamp(20px, 5vw, 40px);
}

.pg-cm-faq__header {
	text-align: center;
	margin-bottom: 44px;
}

.pg-cm-faq__script {
	font-size: 30px;
	color: var(--pg-brass);
	line-height: .9;
	margin-bottom: 6px;
}

.pg-cm-faq__h2 {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(28px, 3.6vw, 46px);
	line-height: 1.06;
	letter-spacing: -.01em;
	color: var(--pg-ink);
	margin: 0;
	text-wrap: balance;
}

.pg-cm-faq__list {
	border-top: 1px solid rgba(27,26,23,.1);
}

.pg-cm-faq__list details {
	border-bottom: 1px solid rgba(27,26,23,.1);
}

.pg-cm-faq__list details summary {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	padding: 22px 4px;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(17px, 2vw, 21px);
	color: var(--pg-ink);
}

.pg-cm-faq__list details summary:hover {
	color: var(--pg-brass);
}

.pg-cm-faq__list details summary span:first-child {
	flex: 1 1 auto;
}

.pg-cm-faq__list details p {
	margin: 0;
	padding: 0 4px 24px;
	color: #5A554C;
	font-size: 15.5px;
	line-height: 1.72;
	max-width: 62em;
}

.pg-cm-faq__more {
	text-align: center;
	margin-top: 40px;
}

.pg-cm-faq__more a {
	display: inline-block;
	font-weight: 600;
	font-size: 15px;
	color: var(--pg-ink);
	border-bottom: 1px solid rgba(27,26,23,.25);
	padding-bottom: 3px;
	transition: color .2s ease, border-color .2s ease;
}

.pg-cm-faq__more a:hover {
	color: var(--pg-brass);
	border-color: var(--pg-brass);
}
