/**
 * Tizzano Theme - Main Frontend Stylesheet
 * Mobile-first responsive design
 *
 * @package Tizzano
 * @since 1.0.0
 */

/* ==========================================================================
   CSS Custom Properties
   ========================================================================== */

:root {
	/* Colors from screenshot */
	--tizzano-dark: #2c3e50;
	--tizzano-dark-alt: #1a252f;
	--tizzano-teal: #3a8a8c;
	--tizzano-teal-dark: #2d6b6d;
	--tizzano-teal-light: #4aa3a5;
	--tizzano-white: #ffffff;
	--tizzano-light: #f5f5f5;
	--tizzano-text: #e0e0e0;
	--tizzano-text-muted: #aaaaaa;
	--tizzano-text-dark: #333333;
	--tizzano-accent: #5dade2;
	--tizzano-red: #e74c3c;
	--tizzano-border: rgba(255, 255, 255, 0.1);

	/* Typography */
	--tizzano-font: system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
	--tizzano-font-size-xs: 0.75rem;
	--tizzano-font-size-sm: 0.875rem;
	--tizzano-font-size-base: 1rem;
	--tizzano-font-size-lg: 1.125rem;
	--tizzano-font-size-xl: 1.5rem;
	--tizzano-font-size-2xl: 2rem;
	--tizzano-font-size-3xl: 2.5rem;

	/* Spacing */
	--tizzano-space-xs: 0.25rem;
	--tizzano-space-sm: 0.5rem;
	--tizzano-space-md: 1rem;
	--tizzano-space-lg: 1.5rem;
	--tizzano-space-xl: 2rem;
	--tizzano-space-2xl: 3rem;
	--tizzano-space-3xl: 4rem;

	/* Layout */
	--tizzano-max-width: 1200px;
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */

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

html {
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	margin: 0;
	padding: 0;
	font-family: var(--tizzano-font);
	font-size: var(--tizzano-font-size-base);
	line-height: 1.6;
	color: var(--tizzano-text);
	background-color: var(--tizzano-dark);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

a {
	color: inherit;
	text-decoration: none;
}

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

ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

h1, h2, h3, h4, h5, h6 {
	margin: 0;
	font-weight: 700;
	line-height: 1.2;
}

p {
	margin: 0 0 0.5rem;
}

/* Skip link */
.skip-link {
	position: absolute;
	top: -100%;
	left: 50%;
	transform: translateX(-50%);
	background: var(--tizzano-teal);
	color: var(--tizzano-white);
	padding: 0.5rem 1.5rem;
	z-index: 10000;
	border-radius: 0 0 4px 4px;
	font-weight: 600;
}

.skip-link:focus {
	top: 0;
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

/* ==========================================================================
   Information Bar
   ========================================================================== */

.tizzano-info-bar {
	text-align: center;
	font-size: var(--tizzano-font-size-sm);
	font-weight: 600;
	position: relative;
}

.tizzano-info-bar__inner {
	max-width: var(--tizzano-max-width);
	margin: 0 auto;
	padding: 0.6rem var(--tizzano-space-md);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--tizzano-space-md);
}

.tizzano-info-bar__text {
	margin: 0;
}

.tizzano-info-bar__close {
	background: none;
	border: none;
	color: inherit;
	font-size: 1.25rem;
	cursor: pointer;
	padding: 0 0.25rem;
	opacity: 0.7;
	line-height: 1;
}

.tizzano-info-bar__close:hover {
	opacity: 1;
}

.tizzano-info-bar.is-hidden {
	display: none;
}

/* ==========================================================================
   Contact Bar
   ========================================================================== */

.tizzano-contact-bar {
	background-color: var(--tizzano-dark-alt);
	border-bottom: 1px solid var(--tizzano-border);
	font-size: var(--tizzano-font-size-sm);
}

.tizzano-contact-bar__inner {
	max-width: var(--tizzano-max-width);
	margin: 0 auto;
	padding: 0.5rem var(--tizzano-space-md);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--tizzano-space-sm);
}

.tizzano-contact-bar__left {
	display: flex;
	align-items: center;
	gap: var(--tizzano-space-lg);
	flex-wrap: wrap;
}

.tizzano-contact-bar__link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--tizzano-text);
	transition: color 0.2s;
}

.tizzano-contact-bar__link:hover {
	color: var(--tizzano-accent);
}

.tizzano-contact-bar__right {
	display: flex;
	align-items: center;
	gap: var(--tizzano-space-sm);
}

.tizzano-contact-bar__social {
	color: var(--tizzano-text);
	transition: color 0.2s;
	display: inline-flex;
}

.tizzano-contact-bar__social:hover {
	color: var(--tizzano-accent);
}

.tizzano-icon {
	flex-shrink: 0;
}

/* ==========================================================================
   Header / Branding
   ========================================================================== */

.site-header {
	background-color: var(--tizzano-dark);
	border-bottom: 1px solid var(--tizzano-border);
}

.tizzano-branding__inner {
	max-width: var(--tizzano-max-width);
	margin: 0 auto;
	padding: var(--tizzano-space-lg) var(--tizzano-space-md);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--tizzano-space-xl);
	flex-wrap: wrap;
}

.tizzano-branding__left,
.tizzano-branding__right {
	flex: 1;
	display: flex;
	align-items: center;
	min-width: 0;
}

.tizzano-branding__left {
	justify-content: flex-end;
}

.tizzano-branding__right {
	justify-content: flex-start;
	gap: var(--tizzano-space-lg);
}

.tizzano-branding__illustration {
	opacity: 0.6;
}

.tizzano-branding__center {
	text-align: center;
	flex-shrink: 0;
}

.tizzano-branding__title {
	font-size: var(--tizzano-font-size-3xl);
	color: var(--tizzano-white);
	letter-spacing: 0.15em;
	margin-bottom: 0.15rem;
}

.tizzano-branding__subtitle {
	font-size: var(--tizzano-font-size-sm);
	color: var(--tizzano-text-muted);
	letter-spacing: 0.3em;
	text-transform: uppercase;
	margin: 0;
}

.tizzano-branding__logo img {
	max-height: 80px;
	width: auto;
}

.tizzano-branding__facebook {
	background: var(--tizzano-white);
	border-radius: 4px;
	padding: 0.5rem;
	max-width: 200px;
	min-width: 160px;
}

.tizzano-fb-placeholder {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: #333;
	font-size: var(--tizzano-font-size-sm);
	padding: 0.25rem;
}

/* Hide illustrations and FB widget on small screens */
@media (max-width: 767px) {
	.tizzano-branding__left,
	.tizzano-branding__right .tizzano-branding__illustration,
	.tizzano-branding__facebook {
		display: none;
	}

	.tizzano-branding__title {
		font-size: var(--tizzano-font-size-2xl);
	}
}

@media (min-width: 768px) and (max-width: 991px) {
	.tizzano-branding__facebook {
		display: none;
	}
}

/* ==========================================================================
   Hero Section
   ========================================================================== */

.tizzano-hero {
	text-align: center;
	color: var(--tizzano-white);
}

.tizzano-hero__inner {
	max-width: var(--tizzano-max-width);
	margin: 0 auto;
	padding: var(--tizzano-space-2xl) var(--tizzano-space-md);
}

.tizzano-hero__title {
	font-size: var(--tizzano-font-size-xl);
	margin-bottom: var(--tizzano-space-md);
	font-weight: 400;
}

.tizzano-hero__title strong,
.tizzano-hero__title b {
	font-weight: 700;
}

.tizzano-hero__description {
	font-size: var(--tizzano-font-size-sm);
	max-width: 700px;
	margin: 0 auto var(--tizzano-space-md);
	opacity: 0.9;
	line-height: 1.7;
}

.tizzano-hero__hours {
	font-size: var(--tizzano-font-size-sm);
	font-style: italic;
	opacity: 0.85;
	margin: 0;
}

@media (min-width: 768px) {
	.tizzano-hero__title {
		font-size: var(--tizzano-font-size-2xl);
	}

	.tizzano-hero__inner {
		padding: var(--tizzano-space-3xl) var(--tizzano-space-xl);
	}
}

/* ==========================================================================
   Menu Tabs
   ========================================================================== */

.tizzano-menu-tabs {
	background-color: var(--tizzano-dark);
	border-top: 1px solid var(--tizzano-border);
	border-bottom: 1px solid var(--tizzano-border);
	position: sticky;
	top: 0;
	z-index: 100;
}

.tizzano-menu-tabs__inner {
	max-width: var(--tizzano-max-width);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	gap: 0;
}

.tizzano-menu-tabs__inner::-webkit-scrollbar {
	display: none;
}

.tizzano-menu-tabs__tab {
	display: flex;
	align-items: center;
	gap: var(--tizzano-space-sm);
	padding: var(--tizzano-space-md) var(--tizzano-space-lg);
	color: var(--tizzano-text-muted);
	font-size: var(--tizzano-font-size-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	white-space: nowrap;
	border-bottom: 3px solid transparent;
	transition: color 0.2s, border-color 0.2s;
	flex-shrink: 0;
}

.tizzano-menu-tabs__tab:hover {
	color: var(--tizzano-white);
}

.tizzano-menu-tabs__tab.is-active {
	color: var(--tizzano-white);
	border-bottom-color: var(--tizzano-teal);
	background-color: rgba(58, 138, 140, 0.15);
}

.tizzano-menu-tabs__icon {
	width: 36px;
	height: 36px;
	object-fit: contain;
	opacity: 0.7;
}

.tizzano-menu-tabs__tab.is-active .tizzano-menu-tabs__icon {
	opacity: 1;
}

@media (max-width: 767px) {
	.tizzano-menu-tabs__tab {
		padding: var(--tizzano-space-sm) var(--tizzano-space-md);
		font-size: var(--tizzano-font-size-xs);
	}

	.tizzano-menu-tabs__icon {
		width: 28px;
		height: 28px;
	}
}

/* ==========================================================================
   Menu Grid
   ========================================================================== */

.tizzano-menu-grid {
	background-color: var(--tizzano-dark);
	padding: var(--tizzano-space-xl) 0;
}

.tizzano-menu-grid__inner {
	max-width: var(--tizzano-max-width);
	margin: 0 auto;
	padding: 0 var(--tizzano-space-md);
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--tizzano-space-2xl);
}

@media (min-width: 768px) {
	.tizzano-menu-grid__inner {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--tizzano-space-xl);
	}
}

@media (min-width: 992px) {
	.tizzano-menu-grid__inner {
		grid-template-columns: repeat(4, 1fr);
		gap: var(--tizzano-space-lg);
	}
}

/* ==========================================================================
   Menu Category
   ========================================================================== */

.tizzano-menu-category {
	padding-top: var(--tizzano-space-md);
}

.tizzano-menu-category__title {
	font-size: var(--tizzano-font-size-lg);
	color: var(--tizzano-white);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--tizzano-space-lg);
	padding-bottom: var(--tizzano-space-sm);
	border-bottom: 1px solid var(--tizzano-border);
}

/* ==========================================================================
   Menu Item
   ========================================================================== */

.tizzano-menu-item {
	margin-bottom: var(--tizzano-space-lg);
}

.tizzano-menu-item__header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: var(--tizzano-space-sm);
}

.tizzano-menu-item__name {
	font-size: var(--tizzano-font-size-base);
	font-weight: 700;
	color: var(--tizzano-white);
	line-height: 1.3;
}

.tizzano-menu-item__size {
	font-weight: 400;
	font-size: var(--tizzano-font-size-sm);
	color: var(--tizzano-text-muted);
	margin-left: 0.3em;
}

.tizzano-menu-item__price {
	font-weight: 700;
	color: var(--tizzano-teal-light);
	font-size: var(--tizzano-font-size-base);
	white-space: nowrap;
	flex-shrink: 0;
}

.tizzano-menu-item__ingredients {
	font-size: var(--tizzano-font-size-sm);
	color: var(--tizzano-text-muted);
	margin-top: 0.15rem;
	margin-bottom: 0;
	line-height: 1.4;
	font-style: italic;
}

/* Price variants (multiple sizes) */
.tizzano-menu-item__variants {
	display: flex;
	flex-wrap: wrap;
	gap: var(--tizzano-space-sm) var(--tizzano-space-md);
	margin-top: 0.25rem;
}

.tizzano-menu-item__variant {
	display: inline-flex;
	align-items: baseline;
	gap: 0.3em;
	font-size: var(--tizzano-font-size-sm);
}

.variant-label {
	color: var(--tizzano-text-muted);
}

.variant-price {
	font-weight: 700;
	color: var(--tizzano-teal-light);
}

/* Allergen badges */
.tizzano-allergens {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	margin-top: 0.35rem;
}

.tizzano-allergen-badge {
	display: inline-block;
	font-size: 0.65rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	padding: 0.1rem 0.35rem;
	border-radius: 2px;
	background-color: rgba(93, 173, 226, 0.2);
	color: var(--tizzano-accent);
	line-height: 1.4;
}

.tizzano-allergen-badge--gluten { background-color: rgba(230, 126, 34, 0.2); color: #e67e22; }
.tizzano-allergen-badge--milk { background-color: rgba(241, 196, 15, 0.2); color: #f1c40f; }
.tizzano-allergen-badge--eggs { background-color: rgba(243, 156, 18, 0.2); color: #f39c12; }
.tizzano-allergen-badge--fish { background-color: rgba(52, 152, 219, 0.2); color: #3498db; }
.tizzano-allergen-badge--nuts { background-color: rgba(160, 106, 66, 0.2); color: #c0835a; }
.tizzano-allergen-badge--crustaceans { background-color: rgba(231, 76, 60, 0.2); color: #e74c3c; }
.tizzano-allergen-badge--soy { background-color: rgba(46, 204, 113, 0.2); color: #2ecc71; }
.tizzano-allergen-badge--celery { background-color: rgba(39, 174, 96, 0.2); color: #27ae60; }
.tizzano-allergen-badge--mustard { background-color: rgba(241, 196, 15, 0.2); color: #d4ac0d; }
.tizzano-allergen-badge--sesame { background-color: rgba(211, 184, 140, 0.2); color: #d3b88c; }
.tizzano-allergen-badge--sulphites { background-color: rgba(155, 89, 182, 0.2); color: #9b59b6; }
.tizzano-allergen-badge--lupin { background-color: rgba(142, 68, 173, 0.2); color: #8e44ad; }
.tizzano-allergen-badge--molluscs { background-color: rgba(149, 165, 166, 0.2); color: #95a5a6; }
.tizzano-allergen-badge--peanuts { background-color: rgba(211, 84, 0, 0.2); color: #d35400; }

/* ==========================================================================
   Footer
   ========================================================================== */

.site-footer {
	background-color: var(--tizzano-dark-alt);
	border-top: 1px solid var(--tizzano-border);
}

.tizzano-footer {
	position: relative;
}

.tizzano-footer__map {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 0;
	overflow: hidden;
}

.tizzano-footer__map iframe {
	width: 100%;
	height: 100%;
	border: 0;
	filter: brightness(0.4) grayscale(0.5);
}

.tizzano-footer__overlay {
	position: relative;
	z-index: 1;
	padding: var(--tizzano-space-2xl) var(--tizzano-space-md);
}

.tizzano-footer__inner {
	max-width: var(--tizzano-max-width);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--tizzano-space-lg);
	flex-wrap: wrap;
}

.tizzano-footer__address {
	font-size: var(--tizzano-font-size-sm);
	color: var(--tizzano-text);
	margin: 0;
	text-align: center;
}

.tizzano-footer__text {
	font-size: var(--tizzano-font-size-sm);
	color: var(--tizzano-text-muted);
	text-align: center;
}

.tizzano-footer__social {
	display: flex;
	align-items: center;
	gap: var(--tizzano-space-sm);
	padding-left: var(--tizzano-space-md);
	border-left: 1px solid var(--tizzano-border);
}

.tizzano-footer__social-link {
	color: var(--tizzano-text);
	transition: color 0.2s;
	display: inline-flex;
}

.tizzano-footer__social-link:hover {
	color: var(--tizzano-accent);
}

.tizzano-footer__legal {
	text-align: center;
	margin-top: var(--tizzano-space-md);
	max-width: var(--tizzano-max-width);
	margin-left: auto;
	margin-right: auto;
}

.tizzano-footer__legal a {
	font-size: var(--tizzano-font-size-xs);
	color: var(--tizzano-text-muted);
	text-decoration: underline;
}

.tizzano-footer__legal a:hover {
	color: var(--tizzano-white);
}

@media (max-width: 767px) {
	.tizzano-footer__social {
		border-left: none;
		padding-left: 0;
	}
}

/* ==========================================================================
   Generic Page Content
   ========================================================================== */

.tizzano-page-content {
	max-width: 800px;
	margin: 0 auto;
	padding: var(--tizzano-space-2xl) var(--tizzano-space-md);
	color: var(--tizzano-text);
}

.tizzano-page-content .entry-title {
	font-size: var(--tizzano-font-size-2xl);
	color: var(--tizzano-white);
	margin-bottom: var(--tizzano-space-xl);
}

.tizzano-page-content .entry-content p {
	margin-bottom: var(--tizzano-space-md);
	line-height: 1.8;
}

.tizzano-page-content .entry-content a {
	color: var(--tizzano-accent);
	text-decoration: underline;
}

/* 404 Page */
.tizzano-404 {
	text-align: center;
	padding: var(--tizzano-space-3xl) var(--tizzano-space-md);
}

.tizzano-btn {
	display: inline-block;
	background: var(--tizzano-teal);
	color: var(--tizzano-white);
	padding: 0.75rem 1.5rem;
	border-radius: 4px;
	font-weight: 600;
	transition: background 0.2s;
	margin-top: var(--tizzano-space-md);
}

.tizzano-btn:hover {
	background: var(--tizzano-teal-dark);
}

/* ==========================================================================
   Focus Styles (Accessibility)
   ========================================================================== */

:focus-visible {
	outline: 2px solid var(--tizzano-accent);
	outline-offset: 2px;
}

a:focus:not(:focus-visible),
button:focus:not(:focus-visible) {
	outline: none;
}
