@import url("https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500&family=Cinzel:wght@600;700&family=Cormorant+Garamond:ital,wght@0,600;0,700;1,600&display=swap");

.pxl-footer-box {
	--bg: #0b0907;
	--bg-2: #13100c;
	--panel: #1a1510;
	--ink: #efe3ca;
	--ink-2: #c9b898;
	--ink-3: #8c7a5e;
	--gold: #d4b896;
	--gold-bright: #f4e4b8;
	--rule-2: rgba(212, 184, 150, 0.1);
	color: var(--ink);
	font-family: "Be Vietnam Pro", system-ui, sans-serif;
	font-weight: 400;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	box-sizing: border-box;
}

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

.pxl-footer-box .shell {
	max-width: 920px;
	margin: 0 auto;
	padding: 0 16px 60px;
	position: relative;
	z-index: 1;
}

.pxl-footer-box .frame {
	position: relative;
	border-radius: 28px;
	background:
		radial-gradient(ellipse at top, rgba(212, 184, 150, 0.06), transparent 50%),
		linear-gradient(180deg, var(--panel) 0%, var(--bg-2) 100%);
	box-shadow:
		0 1px 0 rgba(212, 184, 150, 0.1) inset,
		0 0 0 1px rgba(212, 184, 150, 0.18),
		0 30px 60px -30px rgba(0, 0, 0, 0.7),
		0 0 80px -40px rgba(212, 184, 150, 0.12);
}

.pxl-footer-box .frame::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	padding: 1px;
	background: linear-gradient(180deg,
			rgba(232, 201, 136, 0.55) 0%,
			rgba(168, 136, 96, 0.22) 50%,
			rgba(232, 201, 136, 0.4) 100%);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}

.pxl-footer-box .frame>.corn {
	position: absolute;
	width: 22px;
	height: 22px;
	border: 1px solid var(--gold);
	opacity: 0.7;
	pointer-events: none;
}

.pxl-footer-box .frame>.corn.tl {
	top: 10px;
	left: 10px;
	border-right: none;
	border-bottom: none;
	border-top-left-radius: 14px;
}

.pxl-footer-box .frame>.corn.tr {
	top: 10px;
	right: 10px;
	border-left: none;
	border-bottom: none;
	border-top-right-radius: 14px;
}

.pxl-footer-box .frame>.corn.bl {
	bottom: 10px;
	left: 10px;
	border-right: none;
	border-top: none;
	border-bottom-left-radius: 14px;
}

.pxl-footer-box .frame>.corn.br {
	bottom: 10px;
	right: 10px;
	border-left: none;
	border-top: none;
	border-bottom-right-radius: 14px;
}

/* === Demo landing-page-standalone: footer frame === */
.pxl-footer-box .frame.footer-box {
	padding: 60px 28px 40px;
	margin-top: 50px;
	margin-bottom: 8px;
	text-align: center;
}

.pxl-footer-box .footer-box .sub {
	display: block;
	text-align: center;
	margin-bottom: 18px;
	font-family: "Cinzel", serif;
	font-size: 10px;
	letter-spacing: 0.36em;
	color: var(--ink-3);
	text-transform: uppercase;
}

.pxl-footer-box .avatar {
	width: 130px;
	height: 130px;
	border-radius: 50%;
	margin: 0 auto;
	position: relative;
	background: radial-gradient(circle, #2a2218, #0b0907);
	border: 2px solid var(--gold);
	overflow: hidden;
	box-shadow:
		0 0 40px -8px rgba(232, 201, 136, 0.4),
		0 16px 32px -16px rgba(0, 0, 0, 0.7);
}

.pxl-footer-box .avatar::after {
	content: "";
	position: absolute;
	inset: 5px;
	border: 1px solid var(--gold);
	border-radius: 50%;
	opacity: 0.4;
	pointer-events: none;
}

.pxl-footer-box .avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.pxl-footer-box .role {
	margin-top: 20px;
	font-family: "Cinzel", serif;
	font-size: 12px;
	letter-spacing: 0.36em;
	color: var(--gold);
	text-transform: uppercase;
}

.pxl-footer-box .tagline {
	margin-top: 8px;
	font-family: "Cormorant Garamond", serif;
	font-style: italic;
	font-size: 19px;
	color: var(--ink-2);
}

.pxl-footer-box .tagline::before {
	content: "\201C";
	color: var(--gold);
	margin-right: 4px;
}

.pxl-footer-box .tagline::after {
	content: "\201D";
	color: var(--gold);
	margin-left: 4px;
}

.pxl-footer-box .footer-h {
	margin-top: 34px;
	font-family: "Cormorant Garamond", serif;
	font-weight: 700;
	font-size: 30px;
	text-align: center;
	padding-left: 0;
	line-height: 1.15;
	background: linear-gradient(180deg, #f4e4b8, #d4b896 50%, #a88860);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	filter: drop-shadow(0 1px 6px rgba(244, 216, 122, 0.4));
}

.pxl-footer-box .footer-h em {
	font-style: italic;
	font-weight: 600;
}

.pxl-footer-box .contact-list {
	margin-top: 22px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	text-align: left;
	max-width: 440px;
	margin-left: auto;
	margin-right: auto;
}

.pxl-footer-box .contact-row {
	display: grid;
	grid-template-columns: 46px 1fr;
	align-items: flex-start;
	gap: 14px;
	padding-left: 0;
	align-items: center;
}

.pxl-footer-box .contact-row .ico {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: radial-gradient(circle, #2a2218, #0b0907);
	border: 1px solid var(--gold);
	display: grid;
	place-items: center;
	color: var(--gold);
	box-shadow: 0 0 14px -4px rgba(232, 201, 136, 0.4);
	position: relative;
}

.pxl-footer-box .contact-row .ico::after {
	content: "";
	position: absolute;
	inset: 3px;
	border: 1px solid var(--gold);
	border-radius: 50%;
	opacity: 0.3;
}

.pxl-footer-box .contact-row .ico svg {
	width: 16px;
	height: 16px;
	stroke-width: 1.5;
}

.pxl-footer-box .contact-row .txt {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	column-gap: 0.35em;
	row-gap: 0.15em;
	font-size: 14px;
	color: var(--ink-2);
	line-height: 1.55;
}

.pxl-footer-box .contact-row .txt strong {
	color: var(--gold);
	font-weight: 500;
}

.pxl-footer-box .contact-row .txt a.pxl-footer-contact-tel {
	display: inline;
	color: var(--gold-bright);
	text-decoration: none;
	cursor: pointer;
	border-bottom: 1px solid rgba(212, 184, 150, 0.55);
	transition: color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
	font-family: "Cormorant Garamond", serif;
	font-weight: 700;
	font-size: 20px;
	letter-spacing: 0.02em;
}

.pxl-footer-box .contact-row .txt a.pxl-footer-contact-tel:hover {
	color: #fff1c8;
	border-bottom-color: rgba(244, 228, 192, 0.85);
	opacity: 0.98;
}

.pxl-footer-box .contact-row .txt a.pxl-footer-contact-tel b,
.pxl-footer-box .contact-row .txt a.pxl-footer-contact-tel strong {
	color: inherit;
	font: inherit;
	letter-spacing: inherit;
}

.pxl-footer-box .contact-row .txt b {
	color: var(--gold-bright);
	font-family: "Cormorant Garamond", serif;
	font-weight: 700;
	font-size: 20px;
	letter-spacing: 0.02em;
}

.pxl-footer-box .contact-list a {
	color: var(--gold);
	text-decoration: none;
	border-bottom: 1px solid rgba(212, 184, 150, 0.35);
	transition: color 0.2s ease, border-color 0.2s ease;
}

.pxl-footer-box .contact-list a:hover {
	color: #f0dcc0;
	border-bottom-color: rgba(240, 220, 192, 0.55);
}

@media (max-width: 560px) {
	.pxl-footer-box .footer-h {
		font-size: 26px;
	}

	.pxl-footer-box .frame.footer-box {
		padding: 48px 18px 36px;
	}
}