/**
 * Pizza Max - "Trattoria Nocturne" Design System
 *
 * An atmospheric, warm aesthetic inspired by authentic Italian trattorias
 * at night - glowing ovens, textured walls, candlelit ambiance.
 */

/* ============================================
   CSS Custom Properties (Extended)
   ============================================ */
:root {
	/* Core Palette */
	--pm-coal: #0A0908;
	--pm-charcoal: #1A1714;
	--pm-ember: #E85A1B;
	--pm-gold: #D4A84B;
	--pm-cream: #F5F0E8;
	--pm-smoke: #8B8178;
	--pm-paper: #2A2520;

	/* Semantic */
	--pm-glow: rgba(232, 90, 27, 0.4);
	--pm-glow-soft: rgba(232, 90, 27, 0.15);
	--pm-shadow: rgba(10, 9, 8, 0.8);

	/* Typography */
	--pm-font-logo: 'Pacifico', cursive;
	--pm-font-display: 'Playfair Display', Georgia, serif;
	--pm-font-heading: 'Cormorant Garamond', Garamond, serif;
	--pm-font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;

	/* Spacing */
	--pm-space-xs: 0.25rem;
	--pm-space-sm: 0.5rem;
	--pm-space-md: 1rem;
	--pm-space-lg: 2rem;
	--pm-space-xl: 4rem;
	--pm-space-xxl: 8rem;

	/* Animation */
	--pm-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
	--pm-ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
	--pm-duration-fast: 0.2s;
	--pm-duration-normal: 0.4s;
	--pm-duration-slow: 0.8s;
}

/* ============================================
   Base & Global Styles
   ============================================ */

* {
	box-sizing: border-box;
}

/* Noise texture overlay */
body::before {
	content: '';
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 9999;
	opacity: 0.025;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
}

body {
	background: var(--pm-coal);
	color: var(--pm-cream);
	font-family: var(--pm-font-body);
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

html {
	scroll-behavior: smooth;
}

::selection {
	background: var(--pm-ember);
	color: var(--pm-cream);
}

img {
	max-width: 100%;
	height: auto;
}

/* ============================================
   Typography Refinements
   ============================================ */

h1, h2, h3 {
	font-family: var(--pm-font-heading);
	font-weight: 400;
	letter-spacing: 0.02em;
	color: var(--pm-cream);
}

h1 {
	font-family: var(--pm-font-display);
	font-style: italic;
}

.heading-decorated {
	position: relative;
	display: inline-block;
}

.heading-decorated::after {
	content: '';
	position: absolute;
	bottom: -0.5rem;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--pm-gold), transparent);
}

/* ============================================
   Header - Refined & Atmospheric
   ============================================ */

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	padding: var(--pm-space-md) var(--pm-space-lg);
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
}

.site-header::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, var(--pm-coal) 0%, transparent 100%);
	opacity: 0.8;
	transition: opacity var(--pm-duration-normal) var(--pm-ease-out);
	pointer-events: none;
}

.site-header.scrolled {
	background: rgba(10, 9, 8, 0.95);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-bottom: 1px solid rgba(212, 168, 75, 0.1);
}

.site-header.scrolled::before {
	opacity: 0;
}

.header-inner {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--pm-space-lg);
	position: relative;
	z-index: 1;
}

/* Logo */
.site-logo {
	font-family: var(--pm-font-logo);
	font-size: 1.5rem;
	color: var(--pm-cream);
	text-decoration: none;
	transition: color var(--pm-duration-fast) var(--pm-ease-out);
	position: relative;
}

.site-logo span {
	color: var(--pm-gold);
}

.site-logo::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 0;
	height: 1px;
	background: var(--pm-ember);
	transition: width var(--pm-duration-normal) var(--pm-ease-out);
}

.site-logo:hover {
	color: var(--pm-ember);
}

.site-logo:hover::after {
	width: 100%;
}

/* Navigation */
.header-nav {
	display: flex;
	align-items: center;
	gap: var(--pm-space-xl);
}

.header-nav a {
	font-family: var(--pm-font-body);
	font-size: 0.8rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--pm-cream);
	text-decoration: none;
	position: relative;
	padding: var(--pm-space-sm) 0;
	transition: color var(--pm-duration-fast) var(--pm-ease-out);
}

.header-nav a::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--pm-gold);
	transform: scaleX(0);
	transform-origin: right;
	transition: transform var(--pm-duration-normal) var(--pm-ease-out);
}

.header-nav a:hover {
	color: var(--pm-gold);
}

.header-nav a:hover::before {
	transform: scaleX(1);
	transform-origin: left;
}

/* Header CTA Buttons */
.header-cta {
	display: flex;
	align-items: center;
	gap: var(--pm-space-md);
}

.header-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1.25rem;
	font-family: var(--pm-font-body);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	border: 1px solid transparent;
	transition: all var(--pm-duration-fast) var(--pm-ease-out);
}

.header-btn-secondary {
	color: var(--pm-cream);
	border-color: rgba(245, 240, 232, 0.2);
	background: transparent;
}

.header-btn-secondary:hover {
	border-color: var(--pm-gold);
	color: var(--pm-gold);
}

.header-btn-primary {
	background: var(--pm-ember);
	color: var(--pm-cream);
	position: relative;
	overflow: hidden;
}

.header-btn-primary::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--pm-gold);
	transform: translateX(-100%);
	transition: transform var(--pm-duration-normal) var(--pm-ease-out);
}

.header-btn-primary span {
	position: relative;
	z-index: 1;
}

.header-btn-primary:hover {
	color: var(--pm-coal);
}

.header-btn-primary:hover::before {
	transform: translateX(0);
}

/* ============================================
   Hero - Dramatic & Immersive
   ============================================ */

.hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.hero-background {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.hero-background img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: brightness(0.3) saturate(0.8);
}

/* Fire glow effect */
.hero-background::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 80% 50% at 50% 100%, var(--pm-glow-soft) 0%, transparent 60%),
		radial-gradient(ellipse 60% 40% at 30% 80%, rgba(212, 168, 75, 0.1) 0%, transparent 50%);
}

/* Vignette */
.hero-background::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at center, transparent 0%, var(--pm-coal) 100%);
	z-index: 1;
}

.hero-content {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 900px;
	padding: var(--pm-space-xl);
}

.hero-subtitle {
	font-family: var(--pm-font-body);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--pm-gold);
	margin-bottom: var(--pm-space-md);
	opacity: 0;
	animation: fadeUp 0.8s var(--pm-ease-out) 0.2s forwards;
}

.hero-title {
	font-family: var(--pm-font-logo);
	font-size: clamp(4rem, 15vw, 10rem);
	font-weight: 400;
	color: var(--pm-cream);
	line-height: 1;
	margin: 0 0 var(--pm-space-lg);
	opacity: 0;
	animation: fadeUp 0.8s var(--pm-ease-out) 0.4s forwards;
}

.hero-title span {
	color: var(--pm-gold);
}

.hero-description {
	font-family: var(--pm-font-heading);
	font-size: 1.5rem;
	color: var(--pm-smoke);
	max-width: 500px;
	margin: 0 auto var(--pm-space-xl);
	line-height: 1.5;
	opacity: 0;
	animation: fadeUp 0.8s var(--pm-ease-out) 0.6s forwards;
}

.hero-cta {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--pm-space-md);
	opacity: 0;
	animation: fadeUp 0.8s var(--pm-ease-out) 0.8s forwards;
	margin-bottom: 8rem;
}

.hero-scroll {
	position: absolute;
	bottom: var(--pm-space-lg);
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--pm-space-sm);
	color: var(--pm-smoke);
	font-size: 0.7rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	text-decoration: none;
	opacity: 0;
	animation:
		fadeUp 0.8s var(--pm-ease-out) 1.2s forwards,
		scrollBounce 1.5s ease-in-out 2s infinite;
	cursor: pointer;
}

.hero-scroll:hover {
	color: var(--pm-gold);
}

.hero-scroll-line {
	width: 1px;
	height: 60px;
	background: linear-gradient(180deg, var(--pm-gold) 0%, transparent 100%);
	animation: scrollPulse 2s ease-in-out infinite;
}

/* ============================================
   Buttons - Refined & Tactile
   ============================================ */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	padding: 1.125rem 2.25rem;
	font-family: var(--pm-font-body);
	font-size: 0.8rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
	border: none;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
}

.btn-primary {
	background: var(--pm-ember);
	color: var(--pm-cream);
	box-shadow:
		0 4px 20px rgba(232, 90, 27, 0.3),
		inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.btn-primary::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--pm-gold) 0%, var(--pm-ember) 100%);
	opacity: 0;
	transition: opacity var(--pm-duration-normal) var(--pm-ease-out);
}

.btn-primary:hover {
	transform: translateY(-2px);
	box-shadow:
		0 8px 30px rgba(232, 90, 27, 0.4),
		inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.btn-primary:hover::before {
	opacity: 1;
}

.btn-primary span {
	position: relative;
	z-index: 1;
}

.btn-secondary {
	background: transparent;
	color: var(--pm-cream);
	border: 1px solid rgba(245, 240, 232, 0.3);
}

.btn-secondary:hover {
	border-color: var(--pm-gold);
	color: var(--pm-gold);
	background: rgba(212, 168, 75, 0.05);
}

/* WP Block Buttons */
.wp-block-button__link {
	transition: all 0.3s var(--pm-ease-out);
	font-weight: 500;
	letter-spacing: 0.05em;
}

.wp-block-button__link:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(232, 90, 27, 0.35);
}

/* ============================================
   Sections - Atmospheric Backgrounds
   ============================================ */

.section {
	position: relative;
	padding: var(--pm-space-xl) var(--pm-space-lg);
}

.section-dark {
	background: var(--pm-coal);
}

.section-warm {
	background: var(--pm-charcoal);
	position: relative;
}

.section-warm::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 800px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--pm-paper), transparent);
}

.section-glow {
	position: relative;
}

.section-glow::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 60%;
	height: 300px;
	background: radial-gradient(ellipse at center bottom, var(--pm-glow-soft) 0%, transparent 70%);
	pointer-events: none;
}

.section-header {
	text-align: center;
	max-width: 700px;
	margin: 0 auto var(--pm-space-lg);
}

.section-label {
	font-family: var(--pm-font-body);
	font-size: 0.7rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--pm-ember);
	margin-bottom: var(--pm-space-md);
}

.section-title {
	font-family: var(--pm-font-logo);
	font-size: clamp(2rem, 5vw, 3.5rem);
	color: var(--pm-cream);
	margin: 0 0 var(--pm-space-md);
}

.section-description {
	font-size: 1.1rem;
	color: var(--pm-smoke);
	line-height: 1.7;
}

/* ============================================
   Pizza Cards - Elegant & Tactile
   ============================================ */

.pizzas-archive {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

.pizzas-grid,
.menu-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
	gap: var(--pm-space-lg);
	max-width: 1200px;
	margin: 0 auto;
}

.pizza-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
	opacity: 0;
	animation: fadeUp 0.5s var(--pm-ease-out) forwards;
}

.pizza-card-link:nth-child(1) { animation-delay: 0.05s; }
.pizza-card-link:nth-child(2) { animation-delay: 0.1s; }
.pizza-card-link:nth-child(3) { animation-delay: 0.15s; }
.pizza-card-link:nth-child(4) { animation-delay: 0.2s; }
.pizza-card-link:nth-child(5) { animation-delay: 0.25s; }
.pizza-card-link:nth-child(6) { animation-delay: 0.3s; }
.pizza-card-link:nth-child(7) { animation-delay: 0.35s; }
.pizza-card-link:nth-child(8) { animation-delay: 0.4s; }
.pizza-card-link:nth-child(9) { animation-delay: 0.45s; }

.pizza-card {
	position: relative;
	background: var(--pm-charcoal);
	border: 1px solid rgba(245, 240, 232, 0.05);
	overflow: hidden;
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
	height: 100%;
}

.pizza-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(232, 90, 27, 0.05) 0%, transparent 50%);
	opacity: 0;
	transition: opacity var(--pm-duration-normal) var(--pm-ease-out);
	pointer-events: none;
}

.pizza-card-link:hover .pizza-card,
.pizza-card-link:focus .pizza-card {
	transform: translateY(-8px);
	border-color: rgba(212, 168, 75, 0.2);
	box-shadow:
		0 20px 40px rgba(0, 0, 0, 0.4),
		0 0 80px var(--pm-glow-soft);
}

.pizza-card-link:hover .pizza-card::before {
	opacity: 1;
}

/* Pizza Card Image */
.pizza-card__image {
	position: relative;
	aspect-ratio: 4/3;
	overflow: hidden;
}

.pizza-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--pm-duration-slow) var(--pm-ease-out);
}

.pizza-card-link:hover .pizza-card__image img {
	transform: scale(1.08);
}

.pizza-card__image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, var(--pm-charcoal) 100%);
	pointer-events: none;
}

/* Placeholder */
.pizza-card__image--placeholder {
	background: linear-gradient(135deg, var(--pm-paper) 0%, var(--pm-charcoal) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}

.pizza-placeholder {
	font-size: 4rem;
	opacity: 0.4;
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
}

.pizza-card-link:hover .pizza-placeholder {
	transform: scale(1.15) rotate(10deg);
	opacity: 0.6;
}

/* Badge */
.pizza-card__badge {
	position: absolute;
	top: var(--pm-space-md);
	right: var(--pm-space-md);
	padding: 0.4rem 0.8rem;
	font-family: var(--pm-font-body);
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background: var(--pm-ember);
	color: var(--pm-cream);
	z-index: 2;
}

.pizza-card__badge--new {
	background: var(--pm-ember);
}

.pizza-card__badge--selection {
	background: linear-gradient(135deg, var(--pm-gold) 0%, var(--pm-ember) 100%);
}

.pizza-card__image .pizza-card__badge:nth-child(2) {
	top: 44px;
}

/* Pizza Card Content */
.pizza-card__content {
	padding: var(--pm-space-lg);
	position: relative;
}

.pizza-card__category {
	font-family: var(--pm-font-body);
	font-size: 0.65rem;
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--pm-gold);
	margin-bottom: var(--pm-space-sm);
}

.pizza-card__title {
	font-family: var(--pm-font-heading);
	font-size: 1.5rem;
	color: var(--pm-cream);
	margin: 0 0 var(--pm-space-sm);
	line-height: 1.2;
	transition: color var(--pm-duration-fast) var(--pm-ease-out);
}

.pizza-card-link:hover .pizza-card__title {
	color: var(--pm-gold);
}

.pizza-card__description {
	font-size: 0.9rem;
	color: var(--pm-smoke);
	line-height: 1.6;
	margin-bottom: var(--pm-space-md);
	min-height: 45px;
}

.pizza-card__description p {
	margin: 0;
}

/* Pizza Card Footer */
.pizza-card__prices {
	display: flex;
	gap: var(--pm-space-xl);
	padding-top: var(--pm-space-md);
	border-top: 1px solid rgba(245, 240, 232, 0.05);
}

.pizza-card__price {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.pizza-card__price .size {
	font-size: 0.7rem;
	color: var(--pm-smoke);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: 500;
}

.pizza-card__price .amount {
	font-family: var(--pm-font-heading);
	font-size: 1.25rem;
	color: var(--pm-cream);
}

/* ============================================
   Menu Filters
   ============================================ */

.pizzas-filters,
.menu-filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--pm-space-sm);
	margin-bottom: var(--pm-space-xl);
}

.filter-btn {
	padding: 0.75rem 1.5rem;
	font-family: var(--pm-font-body);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--pm-smoke);
	background: transparent;
	border: 1px solid rgba(245, 240, 232, 0.1);
	cursor: pointer;
	transition: all var(--pm-duration-fast) var(--pm-ease-out);
	text-decoration: none;
}

.filter-btn:hover {
	color: var(--pm-cream);
	border-color: rgba(245, 240, 232, 0.3);
}

.filter-btn.active {
	color: var(--pm-coal);
	background: var(--pm-gold);
	border-color: var(--pm-gold);
}

/* ============================================
   Drinks Section
   ============================================ */

.drinks-section {
	background: var(--pm-charcoal);
	padding: var(--pm-space-xl) var(--pm-space-lg);
	margin-top: var(--pm-space-xxl);
	position: relative;
}

.drinks-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 600px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--pm-paper), transparent);
}

.drinks-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--pm-space-lg);
	max-width: 1100px;
	margin: 0 auto;
}

.drinks-category {
	text-align: center;
	background: rgba(10, 9, 8, 0.5);
	padding: var(--pm-space-lg);
	border: 1px solid rgba(245, 240, 232, 0.05);
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
}

.drinks-category:hover {
	border-color: rgba(212, 168, 75, 0.2);
	transform: translateY(-4px);
}

.drinks-category__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--pm-space-sm);
	margin-bottom: var(--pm-space-md);
	padding-bottom: var(--pm-space-md);
	border-bottom: 1px solid rgba(212, 168, 75, 0.2);
}

.drinks-category__icon {
	font-size: 2rem;
}

.drinks-category__title {
	font-family: var(--pm-font-heading);
	font-size: 1.25rem;
	color: var(--pm-cream);
	margin: 0;
}

.drinks-category__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--pm-space-sm);
}

.drinks-item {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: var(--pm-space-sm) 0;
}

.drinks-item__name {
	font-size: 0.9rem;
	color: var(--pm-cream);
}

.drinks-item__price {
	font-family: var(--pm-font-heading);
	font-size: 1rem;
	color: var(--pm-gold);
}

/* ============================================
   Loyalty Banner - Compact Horizontal
   ============================================ */

.loyalty-banner {
	background: linear-gradient(90deg, var(--pm-charcoal) 0%, rgba(232, 90, 27, 0.1) 50%, var(--pm-charcoal) 100%);
	border-top: 1px solid rgba(212, 168, 75, 0.15);
	border-bottom: 1px solid rgba(212, 168, 75, 0.15);
	padding: var(--pm-space-md) var(--pm-space-lg);
}

.loyalty-banner__inner {
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--pm-space-md);
	flex-wrap: wrap;
}

.loyalty-banner__icon {
	font-size: 1.75rem;
	background: linear-gradient(135deg, var(--pm-gold) 0%, var(--pm-ember) 100%);
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	flex-shrink: 0;
}

.loyalty-banner__text {
	display: flex;
	align-items: baseline;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.loyalty-banner__title {
	font-family: var(--pm-font-heading);
	font-size: 1.1rem;
	color: var(--pm-cream);
	font-weight: 500;
}

.loyalty-banner__highlight {
	font-family: var(--pm-font-display);
	font-size: 1.25rem;
	font-style: italic;
	color: var(--pm-gold);
}

.loyalty-banner__badge {
	font-size: 0.75rem;
	color: var(--pm-smoke);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 0.35rem 0.75rem;
	border: 1px solid rgba(245, 240, 232, 0.15);
	border-radius: 20px;
}

@media (max-width: 600px) {
	.loyalty-banner__inner {
		flex-direction: column;
		text-align: center;
		gap: var(--pm-space-sm);
	}

	.loyalty-banner__text {
		flex-direction: column;
		align-items: center;
		gap: 0.25rem;
	}
}

/* ============================================
   Hours & Location
   ============================================ */

.hours-location {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--pm-space-xl);
	max-width: 1000px;
	margin: 0 auto;
}

.location-map {
	max-width: 1000px;
	margin: var(--pm-space-xl) auto 0;
	border-radius: 4px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.info-card,
.location-card {
	background: var(--pm-charcoal);
	border: 1px solid rgba(245, 240, 232, 0.05);
	padding: var(--pm-space-xl);
	position: relative;
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
}

.info-card::before,
.location-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: var(--pm-space-lg);
	right: var(--pm-space-lg);
	height: 3px;
	background: linear-gradient(90deg, var(--pm-ember), var(--pm-gold));
}

.info-card:hover,
.location-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.3);
}

.info-card-header {
	display: flex;
	align-items: center;
	gap: var(--pm-space-sm);
	margin-bottom: var(--pm-space-lg);
}

.info-card-icon {
	font-size: 1.75rem;
	line-height: 1;
}

.info-card-title {
	font-family: var(--pm-font-heading);
	font-size: 1.5rem;
	color: var(--pm-cream);
	margin: 0;
}

.hours-row {
	display: flex;
	justify-content: space-between;
	padding: var(--pm-space-sm) 0;
	border-bottom: 1px solid rgba(245, 240, 232, 0.05);
}

.hours-row:last-child {
	border-bottom: none;
}

.hours-day {
	color: var(--pm-cream);
	font-weight: 500;
}

.hours-time {
	color: var(--pm-smoke);
}

.hours-closed {
	color: var(--pm-ember);
	font-size: 0.85rem;
	margin-top: var(--pm-space-md);
}

.location-address {
	color: var(--pm-smoke);
	line-height: 1.8;
	margin-bottom: var(--pm-space-lg);
	font-style: normal;
}

.location-phone {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	font-family: var(--pm-font-heading);
	font-size: 1.5rem;
	color: var(--pm-gold);
	text-decoration: none;
	transition: color var(--pm-duration-fast) var(--pm-ease-out);
}

.location-phone:hover {
	color: var(--pm-ember);
}

/* ============================================
   Footer - Atmospheric
   ============================================ */

.site-footer {
	background: var(--pm-coal);
	border-top: 1px solid rgba(245, 240, 232, 0.05);
	position: relative;
}

.site-footer::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 200px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--pm-gold), transparent);
}

.footer-main {
	padding: var(--pm-space-xl) var(--pm-space-lg);
	max-width: 1200px;
	margin: 0 auto;
}

.footer-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr;
	gap: var(--pm-space-xl);
}

.footer-brand {
	padding-right: var(--pm-space-xl);
}

.footer-logo {
	font-family: var(--pm-font-logo);
	font-size: 1.75rem;
	color: var(--pm-cream);
	text-decoration: none;
	display: inline-block;
	margin-bottom: var(--pm-space-md);
	transition: color var(--pm-duration-fast) var(--pm-ease-out);
}

.footer-logo span {
	color: var(--pm-gold);
}

.footer-logo:hover {
	color: var(--pm-ember);
}

.footer-tagline {
	color: var(--pm-smoke);
	line-height: 1.7;
	margin-bottom: var(--pm-space-lg);
}

.footer-social {
	display: flex;
	gap: var(--pm-space-sm);
}

.social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: 1px solid rgba(245, 240, 232, 0.1);
	color: var(--pm-cream);
	text-decoration: none;
	transition: all var(--pm-duration-fast) var(--pm-ease-out);
}

.social-link:hover {
	border-color: var(--pm-gold);
	color: var(--pm-gold);
	background: rgba(212, 168, 75, 0.1);
	transform: translateY(-2px);
}

.footer-column-title {
	font-family: var(--pm-font-body);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--pm-cream);
	margin-bottom: var(--pm-space-lg);
}

.footer-hours {
	display: flex;
	flex-direction: column;
	gap: var(--pm-space-md);
}

.footer-hours-row {
	color: var(--pm-smoke);
	font-size: 0.9rem;
	line-height: 1.6;
}

.footer-hours-row strong {
	color: var(--pm-cream);
	font-weight: 500;
	display: block;
}

.footer-closed {
	color: var(--pm-ember);
	font-size: 0.8rem;
	margin-top: var(--pm-space-sm);
}

.footer-address {
	color: var(--pm-smoke);
	font-style: normal;
	line-height: 1.7;
	margin-bottom: var(--pm-space-md);
}

.footer-phone {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--pm-gold);
	text-decoration: none;
	font-weight: 500;
	transition: color var(--pm-duration-fast) var(--pm-ease-out);
}

.footer-phone:hover {
	color: var(--pm-ember);
}

.footer-bottom {
	background: rgba(0, 0, 0, 0.3);
	padding: var(--pm-space-md) var(--pm-space-lg);
}

.footer-bottom-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--pm-space-md);
}

.footer-copyright,
.footer-services {
	color: var(--pm-smoke);
	font-size: 0.8rem;
}

/* ============================================
   About Section
   ============================================ */

.about-section {
	padding: var(--pm-space-xxl) var(--pm-space-lg);
	text-align: center;
}

.about-features {
	display: flex;
	justify-content: center;
	gap: var(--pm-space-lg);
	flex-wrap: wrap;
	margin-top: var(--pm-space-xl);
}

.about-feature {
	display: flex;
	align-items: center;
	gap: var(--pm-space-md);
	padding: var(--pm-space-md) var(--pm-space-lg);
	background: var(--pm-charcoal);
	border: 1px solid rgba(245, 240, 232, 0.05);
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
}

.about-feature:hover {
	border-color: rgba(212, 168, 75, 0.2);
	transform: translateY(-2px);
}

.about-feature-icon {
	font-size: 1.75rem;
}

.about-feature-text {
	text-align: left;
}

.about-feature-title {
	font-family: var(--pm-font-heading);
	font-size: 1.1rem;
	color: var(--pm-cream);
}

.about-feature-desc {
	font-size: 0.85rem;
	color: var(--pm-smoke);
}

/* ============================================
   Single Pizza Page
   ============================================ */

.single-pizza-header {
	position: relative;
	min-height: 60vh;
	display: flex;
	align-items: flex-end;
	padding-bottom: var(--pm-space-xl);
}

.single-pizza-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.single-pizza-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: brightness(0.4) saturate(0.8);
}

.single-pizza-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 0%, var(--pm-coal) 90%);
}

.single-pizza-content {
	position: relative;
	z-index: 1;
	max-width: 800px;
	padding: 0 var(--pm-space-lg);
}

.single-pizza-category {
	font-size: 0.7rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--pm-gold);
	margin-bottom: var(--pm-space-sm);
}

.single-pizza-title {
	font-family: var(--pm-font-display);
	font-size: clamp(2.5rem, 6vw, 4rem);
	font-style: italic;
	color: var(--pm-cream);
	margin-bottom: var(--pm-space-md);
}

.single-pizza-ingredients {
	font-family: var(--pm-font-heading);
	font-size: 1.25rem;
	color: var(--pm-smoke);
	line-height: 1.6;
}

.single-pizza-body {
	padding: var(--pm-space-xl) var(--pm-space-lg);
	max-width: 800px;
}

.single-pizza-prices {
	display: flex;
	gap: var(--pm-space-lg);
	margin-bottom: var(--pm-space-xl);
	padding-bottom: var(--pm-space-xl);
	border-bottom: 1px solid rgba(245, 240, 232, 0.1);
}

.single-pizza-price {
	flex: 1;
	text-align: center;
	background: var(--pm-charcoal);
	padding: var(--pm-space-lg);
	border: 1px solid rgba(245, 240, 232, 0.05);
	transition: all var(--pm-duration-normal) var(--pm-ease-out);
}

.single-pizza-price:hover {
	border-color: rgba(212, 168, 75, 0.2);
	transform: translateY(-2px);
}

.single-pizza-price__size {
	font-size: 0.75rem;
	color: var(--pm-smoke);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: var(--pm-space-xs);
	display: block;
}

.single-pizza-price__amount {
	font-family: var(--pm-font-heading);
	font-size: 2rem;
	color: var(--pm-cream);
	display: block;
}

/* ============================================
   Animations
   ============================================ */

@keyframes fadeUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes scrollPulse {
	0%, 100% {
		opacity: 0.3;
		transform: scaleY(1);
	}
	50% {
		opacity: 1;
		transform: scaleY(1.2);
	}
}

@keyframes scrollBounce {
	0%, 100% {
		transform: translateX(-50%) translateY(0);
	}
	50% {
		transform: translateX(-50%) translateY(10px);
	}
}

@keyframes glow {
	0%, 100% {
		box-shadow: 0 0 20px var(--pm-glow-soft);
	}
	50% {
		box-shadow: 0 0 40px var(--pm-glow);
	}
}

.reveal {
	opacity: 0;
	transform: translateY(40px);
	transition: all 0.8s var(--pm-ease-out);
}

.reveal.visible {
	opacity: 1;
	transform: translateY(0);
}

/* ============================================
   Responsive
   ============================================ */

@media (max-width: 1024px) {
	.footer-grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--pm-space-lg);
	}

	.footer-brand {
		grid-column: 1 / -1;
		padding-right: 0;
		text-align: center;
	}

	.footer-social {
		justify-content: center;
	}

	.hours-location {
		grid-template-columns: 1fr;
	}

	.drinks-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.pizzas-grid,
	.menu-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.header-nav {
		display: none;
	}

	.hero-title {
		font-size: clamp(3rem, 12vw, 5rem);
	}

	.hero-description {
		font-size: 1.2rem;
	}

	.pizzas-grid,
	.menu-grid {
		grid-template-columns: 1fr;
	}

	.footer-grid {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.footer-bottom-inner {
		flex-direction: column;
		text-align: center;
	}

	.loyalty-details {
		flex-direction: column;
		gap: var(--pm-space-md);
	}

	.drinks-grid {
		grid-template-columns: 1fr;
	}

	.about-features {
		flex-direction: column;
		align-items: center;
	}
}

@media (max-width: 480px) {
	.btn {
		width: 100%;
	}

	.hero-cta {
		flex-direction: column;
	}

	.pizzas-filters,
	.menu-filters {
		flex-direction: column;
		align-items: stretch;
	}

	.filter-btn {
		text-align: center;
	}

	.pizza-card__prices {
		flex-direction: column;
		gap: var(--pm-space-sm);
	}

	.pizza-card__price {
		flex-direction: row;
		justify-content: space-between;
	}
}

/* ============================================
   Accessibility
   ============================================ */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

a:focus-visible,
button:focus-visible,
.wp-block-button__link:focus-visible {
	outline: 2px solid var(--pm-gold);
	outline-offset: 2px;
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ============================================
   Print Styles
   ============================================ */

@media print {
	body::before,
	header,
	footer,
	.hero-scroll {
		display: none !important;
	}

	body {
		background: white !important;
		color: black !important;
	}

	.pizza-card {
		break-inside: avoid;
		box-shadow: none;
		border: 1px solid #ccc;
	}
}
