/**
 * Colorful Street Style Pack
 * 
 * Vibrant, energetic design with bold colors and modern street art aesthetic
 * 
 * @package CafeHospitality
 */

:root {
	/* Colors */
	--cafe-primary: #ff6b6b;
	--cafe-secondary: #4ecdc4;
	--cafe-accent: #ffe66d;
	--cafe-text: #2d3436;
	--cafe-text-light: #636e72;
	--cafe-background: #ffffff;
	--cafe-surface: #f8f9fa;
	--cafe-border: #dfe6e9;
	--cafe-success: #00b894;
	--cafe-error: #d63031;

	/* Typography */
	--cafe-font-heading: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
	--cafe-font-body: 'Open Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	--cafe-font-size-base: 16px;
	--cafe-line-height: 1.6;

	/* Spacing */
	--cafe-spacing-xs: 0.5rem;
	--cafe-spacing-sm: 1rem;
	--cafe-spacing-md: 1.5rem;
	--cafe-spacing-lg: 2rem;
	--cafe-spacing-xl: 3rem;

	/* Borders */
	--cafe-border-radius: 12px;
	--cafe-border-radius-sm: 6px;
	--cafe-border-radius-lg: 16px;

	/* Shadows */
	--cafe-shadow-sm: 0 2px 8px rgba(255, 107, 107, 0.1);
	--cafe-shadow-md: 0 4px 16px rgba(255, 107, 107, 0.2);
	--cafe-shadow-lg: 0 8px 24px rgba(255, 107, 107, 0.3);

	/* Transitions */
	--cafe-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Global Styles */
body {
	font-family: var(--cafe-font-body);
	color: var(--cafe-text);
	background: var(--cafe-background);
	line-height: var(--cafe-line-height);
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--cafe-font-heading);
	font-weight: 800;
	color: var(--cafe-text);
	margin-bottom: var(--cafe-spacing-md);
	letter-spacing: -0.5px;
}

/* Buttons */
.wp-block-button__link,
.cafe-btn {
	background: linear-gradient(135deg, var(--cafe-primary) 0%, var(--cafe-secondary) 100%);
	color: #fff;
	padding: 14px 28px;
	border-radius: var(--cafe-border-radius);
	border: none;
	font-weight: 700;
	text-decoration: none;
	display: inline-block;
	transition: var(--cafe-transition);
	cursor: pointer;
	text-transform: uppercase;
	letter-spacing: 1px;
	box-shadow: var(--cafe-shadow-md);
	position: relative;
	overflow: hidden;
}

.wp-block-button__link::before,
.cafe-btn::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
	transition: left 0.5s;
}

.wp-block-button__link:hover::before,
.cafe-btn:hover::before {
	left: 100%;
}

.wp-block-button__link:hover,
.cafe-btn:hover {
	transform: translateY(-3px) scale(1.05);
	box-shadow: var(--cafe-shadow-lg);
}

.wp-block-button.is-style-cafe-secondary .wp-block-button__link,
.cafe-btn-secondary {
	background: var(--cafe-accent);
	color: var(--cafe-text);
}

.wp-block-button.is-style-cafe-secondary .wp-block-button__link:hover,
.cafe-btn-secondary:hover {
	background: #ffd93d;
	transform: translateY(-3px) scale(1.05);
}

/* Menu Cards */
.cafe-menu-card {
	background: var(--cafe-background);
	border: 3px solid var(--cafe-primary);
	border-radius: var(--cafe-border-radius-lg);
	padding: var(--cafe-spacing-md);
	transition: var(--cafe-transition);
	box-shadow: var(--cafe-shadow-sm);
	position: relative;
	overflow: hidden;
}

.cafe-menu-card::before {
	content: '';
	position: absolute;
	top: -50%;
	left: -50%;
	width: 200%;
	height: 200%;
	background: linear-gradient(
		45deg,
		transparent 30%,
		rgba(255, 107, 107, 0.1) 50%,
		transparent 70%
	);
	transform: rotate(45deg);
	transition: all 0.5s;
}

.cafe-menu-card:hover::before {
	animation: streetShine 1s ease-in-out;
}

@keyframes streetShine {
	0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
	100% { transform: translateX(100%) translateY(100%) rotate(45deg); }
}

.cafe-menu-card:hover {
	box-shadow: var(--cafe-shadow-lg);
	transform: translateY(-8px) rotate(1deg);
	border-color: var(--cafe-secondary);
}

.cafe-menu-card-image {
	width: 100%;
	height: 200px;
	object-fit: cover;
	border-radius: var(--cafe-border-radius);
	margin-bottom: var(--cafe-spacing-md);
	border: 2px solid var(--cafe-accent);
}

.cafe-menu-card-title {
	font-size: 1.5rem;
	font-weight: 800;
	margin-bottom: var(--cafe-spacing-xs);
	color: var(--cafe-primary);
	font-family: var(--cafe-font-heading);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.cafe-menu-card-description {
	color: var(--cafe-text-light);
	font-size: 0.9rem;
	margin-bottom: var(--cafe-spacing-md);
}

.cafe-menu-card-price {
	font-size: 2rem;
	font-weight: 900;
	background: linear-gradient(135deg, var(--cafe-primary), var(--cafe-secondary));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	margin-bottom: var(--cafe-spacing-md);
}

/* Hero Section */
.cafe-hero {
	background: linear-gradient(135deg, var(--cafe-primary) 0%, var(--cafe-secondary) 50%, var(--cafe-accent) 100%);
	padding: var(--cafe-spacing-xl) 0;
	text-align: center;
	border-radius: var(--cafe-border-radius-lg);
	margin-bottom: var(--cafe-spacing-xl);
	position: relative;
	overflow: hidden;
}

.cafe-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: 
		radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.1) 0%, transparent 50%),
		radial-gradient(circle at 80% 80%, rgba(255, 255, 255, 0.1) 0%, transparent 50%);
}

.cafe-hero-title {
	font-size: 4rem;
	font-weight: 900;
	margin-bottom: var(--cafe-spacing-md);
	color: #fff;
	text-shadow: 3px 3px 0 rgba(0, 0, 0, 0.2);
	position: relative;
	z-index: 1;
	text-transform: uppercase;
	letter-spacing: 2px;
}

.cafe-hero-subtitle {
	font-size: 1.5rem;
	color: rgba(255, 255, 255, 0.95);
	margin-bottom: var(--cafe-spacing-lg);
	position: relative;
	z-index: 1;
	font-weight: 600;
}

/* Header */
.site-header {
	background: var(--cafe-background);
	border-bottom: 4px solid var(--cafe-primary);
	padding: var(--cafe-spacing-md) 0;
	box-shadow: var(--cafe-shadow-sm);
}

/* Footer */
.site-footer {
	background: linear-gradient(135deg, var(--cafe-primary), var(--cafe-secondary));
	padding: var(--cafe-spacing-xl) 0;
	margin-top: var(--cafe-spacing-xl);
	color: #fff;
}

/* Branch Selector */
.cafe-branch-selector {
	padding: var(--cafe-spacing-md);
	background: var(--cafe-surface);
	border: 3px solid var(--cafe-accent);
	border-radius: var(--cafe-border-radius);
	margin-bottom: var(--cafe-spacing-md);
}

.cafe-branch-selector select {
	width: 100%;
	padding: 12px;
	border: 2px solid var(--cafe-primary);
	border-radius: var(--cafe-border-radius-sm);
	background: var(--cafe-background);
	color: var(--cafe-text);
	font-size: var(--cafe-font-size-base);
	font-weight: 600;
}

/* Grid Layouts */
.cafe-menu-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--cafe-spacing-lg);
	margin: var(--cafe-spacing-lg) 0;
}

/* Responsive */
@media (max-width: 768px) {
	.cafe-menu-grid {
		grid-template-columns: 1fr;
	}

	.cafe-hero-title {
		font-size: 2.5rem;
	}
}

