/* ===========================================
   TAIWAN SELECT - 靜態版型樣式表
   =========================================== */

/* ===========================================
   1. 基礎設定
   =========================================== */
.page { 
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Noto Sans TC', 'Helvetica Neue', Arial, 'PingFang TC', 'Microsoft JhengHei', sans-serif; 
	color: #1A1A1A; 
	line-height: 1.6; 
}

.container { 
	max-width: 1200px; 
	margin: 0 auto; 
	padding: 0 16px; 
}

.block { 
	padding: 32px 0; 
}

.center { 
	text-align: center; 
}

/* ===========================================
   2. 頁首 (Header)
   =========================================== */
.hdr, .ft { 
	display: flex; 
	align-items: center; 
	justify-content: space-between; 
	padding: 16px 0; 
}

.static-header { 
	position: sticky; 
	top: 0; 
	z-index: 100; 
	background: #8B4513; 
	border-bottom: 1px solid #A0522D; 
}

.logo img { 
	height: 56px; 
}

.nav ul { 
	display: flex; 
	gap: 20px; 
	list-style: none; 
	margin: 0; 
	padding: 0; 
}

.nav a { 
	color: #fff; 
	font-weight: 600; 
	text-decoration: none; 
}

.nav a:hover, 
.nav a:focus { 
	color: #FFD700; 
	text-decoration: underline; 
	text-underline-offset: 2px; 
}

.nav a.active { 
	color: #FFD700; 
}

/* ===========================================
   3. 搜尋功能
   =========================================== */
.search { 
	position: relative; 
	margin-left: auto; 
}

.search-toggle { 
	appearance: none; 
	border: 1px solid #fff; 
	background: transparent; 
	border-radius: 999px; 
	padding: 8px 12px; 
	cursor: pointer; 
	font-weight: 600; 
	color: #fff; 
}

.search-panel { 
	position: absolute; 
	right: 0; 
	top: calc(100% + 8px); 
	width: min(92vw, 520px); 
	background: #fff; 
	border: 1px solid #e6e6e6; 
	border-radius: 12px; 
	box-shadow: 0 12px 40px rgba(0,0,0,.08); 
	padding: 16px; 
	display: none; 
}

.search.open .search-panel { 
	display: block; 
}

.search-row { 
	display: flex; 
	gap: 8px; 
}

.search-row input[type="text"] { 
	flex: 1; 
	border: 1px solid #e6e6e6; 
	border-radius: 8px; 
	padding: 10px 12px; 
}

.search-row .btn-adv { 
	background: transparent; 
	color: #8B4513; 
	text-decoration: underline; 
	text-underline-offset: 2px; 
	border: 0; 
	padding: 0 8px; 
	cursor: pointer; 
	font-weight: 600; 
}

.search-row .btn-submit { 
	background: #D2691E; 
	color: #fff; 
	border: 0; 
	border-radius: 8px; 
	padding: 10px 14px; 
	font-weight: 700; 
	cursor: pointer; 
}

/* ===========================================
   4. 按鈕樣式
   =========================================== */
.btn { 
	display: inline-block; 
	padding: 10px 16px; 
	background: #D2691E; 
	color: #fff; 
	text-decoration: none; 
	border-radius: 6px; 
	font-weight: 700; 
	font-size: 16px;
}

.btn:hover { 
	background: #CD853F; 
}

.btn-red {
	background: #D2691E;
	color: #fff;
	padding: 12px 24px;
	border-radius: 8px;
	text-decoration: none;
	font-weight: 700;
	display: inline-block;
	transition: background 0.3s ease;
}

.btn-red:hover {
	background: #CD853F;
}

/* ===========================================
   5. 標題樣式
   =========================================== */
.ttl { 
	font-size: 48px; 
	font-weight: 700; 
	letter-spacing: .02em; 
	text-align: center; 
	margin: 0 0 20px; 
}

.container .ttl + p { 
	color: #333; 
}

/* ===========================================
   6. Hero 區域 (滿版首頁)
   =========================================== */
.hero { 
	position: relative; 
	min-height: 100vh; 
	background: #8B4513;
	overflow: hidden;
}

.hero-background { 
	position: relative; 
	width: 100%; 
	height: 100vh; 
	overflow: hidden;
}

.hero-bg-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}

.hero-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, rgba(139, 69, 19, 0.7) 0%, rgba(160, 82, 45, 0.6) 50%, rgba(205, 133, 63, 0.5) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}

/* 裝飾圖案 */
.decorative-patterns {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 2;
}

.pattern {
	position: absolute;
	background: rgba(255,255,255,0.1);
	border-radius: 50%;
}

.pattern-1 {
	width: 200px;
	height: 200px;
	top: 10%;
	left: 5%;
	animation: float 8s ease-in-out infinite;
}

.pattern-2 {
	width: 150px;
	height: 150px;
	top: 60%;
	right: 10%;
	animation: float 6s ease-in-out infinite reverse;
}

.pattern-3 {
	width: 100px;
	height: 100px;
	top: 30%;
	right: 30%;
	animation: float 10s ease-in-out infinite;
}

/* 美食插圖 */
.food-illustrations {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 3;
}

.food-item {
	position: absolute;
	font-size: 48px;
	opacity: 0.7;
	animation: float 6s ease-in-out infinite;
}

/* 右上角水果 */
.food-item.pineapple-slice { top: 15%; right: 20%; animation-delay: 0s; font-size: 48px; }
.food-item.pineapple-whole { top: 20%; right: 15%; animation-delay: 0.5s; font-size: 44px; }
.food-item.mango-slice { top: 12%; right: 25%; animation-delay: 1s; font-size: 46px; }
.food-item.mango-whole { top: 25%; right: 30%; animation-delay: 1.5s; font-size: 42px; }

/* 中左側月餅 */
.food-item.mooncake-whole { top: 35%; left: 8%; animation-delay: 2s; font-size: 52px; }
.food-item.mooncake-slice { top: 40%; left: 12%; animation-delay: 2.5s; font-size: 50px; }

/* 下左側鳳梨酥 */
.food-item.pineapple-cake-whole { top: 70%; left: 5%; animation-delay: 3s; font-size: 46px; }
.food-item.pineapple-cake-slice { top: 75%; left: 9%; animation-delay: 3.5s; font-size: 44px; }

/* 下中左側醬油 */
.food-item.soy-sauce-bottle { top: 80%; left: 15%; animation-delay: 4s; font-size: 40px; }

/* 下中米飯 */
.food-item.rice-bowl { top: 85%; left: 45%; animation-delay: 4.5s; font-size: 44px; }

/* 下中右側紅燒肉 */
.food-item.braised-pork { top: 80%; right: 25%; animation-delay: 5s; font-size: 48px; }

/* 下右側茶飲 */
.food-item.tea-bottle { top: 75%; right: 10%; animation-delay: 5.5s; font-size: 42px; }

/* 中右側豬頭 */
.food-item.pig-head { top: 50%; right: 20%; animation-delay: 6s; font-size: 50px; }

/* 中右側鮪魚罐頭 */
.food-item.tuna-can { top: 45%; right: 15%; animation-delay: 6.5s; font-size: 46px; }

/* 裝飾水滴 */
.water-drop {
	position: absolute;
	background: rgba(255,255,255,0.3);
	border-radius: 50% 50% 50% 0;
	transform: rotate(-45deg);
	animation: drop-float 4s ease-in-out infinite;
}

.water-drop.drop-1 { width: 16px; height: 16px; top: 25%; left: 20%; animation-delay: 0s; }
.water-drop.drop-2 { width: 12px; height: 12px; top: 45%; left: 25%; animation-delay: 1s; }
.water-drop.drop-3 { width: 14px; height: 14px; top: 60%; right: 30%; animation-delay: 2s; }
.water-drop.drop-4 { width: 10px; height: 10px; top: 70%; right: 20%; animation-delay: 3s; }
.water-drop.drop-5 { width: 18px; height: 18px; top: 40%; right: 35%; animation-delay: 4s; }
.water-drop.drop-6 { width: 8px; height: 8px; top: 15%; left: 30%; animation-delay: 5s; }
.water-drop.drop-7 { width: 14px; height: 14px; top: 55%; left: 40%; animation-delay: 6s; }
.water-drop.drop-8 { width: 10px; height: 10px; top: 35%; right: 40%; animation-delay: 7s; }
.water-drop.drop-9 { width: 12px; height: 12px; top: 65%; left: 35%; animation-delay: 8s; }
.water-drop.drop-10 { width: 16px; height: 16px; top: 30%; left: 50%; animation-delay: 9s; }

/* Hero 內容 */
.hero-content {
	position: relative;
	z-index: 4;
	text-align: center;
	color: #fff;
	padding: 60px 40px;
	max-width: 800px;
	margin: 0 auto;
}

.hero-content h3 { 
	font-size: 56px; 
	line-height: 1.2; 
	margin: 0 0 24px; 
	font-weight: 700; 
	text-shadow: 3px 3px 6px rgba(0,0,0,0.7);
}

.hero-content p { 
	font-size: 28px; 
	line-height: 1.4; 
	margin: 0; 
	opacity: .95; 
	text-shadow: 2px 2px 4px rgba(0,0,0,0.7);
}

/* ===========================================
   7. 活動列表區塊
   =========================================== */
.taiwan-select-section {
	background: #fff;
	padding: 60px 20px;
	text-align: center;
}

.event-list-section {
	text-align: center;
	padding: 20px 0;
}

.event-list-section h3 {
	font-size: 28px;
	color: #8B4513;
	margin: 0 0 16px;
	font-weight: 700;
}

/* ===========================================
   8. 展覽卡片樣式
   =========================================== */
.exhibition-section {
	background: linear-gradient(135deg, #FFA500 0%, #FF8C00 100%);
	padding: 60px 0;
	margin: 0;
	position: relative;
	overflow: hidden;
	width: 100%;
}

.exhibition-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 120" preserveAspectRatio="none"><path d="M0,0V46.29c47.79,22.2,103.59,38.04,158,42.7C207.7,91.1,263.1,87.1,318,87.1c54.9,0,110.3,4,165.3,1.9C538.8,87.1,594,83.1,649,83.1c54.9,0,110.3,4,165.3,1.9C869.8,87.1,925,83.1,980,83.1c54.9,0,110.3,4,165.3,1.9C1254.8,87.1,1310,83.1,1365,83.1c54.9,0,110.3,4,165.3,1.9V0Z" opacity=".25" fill="%23ffffff"/><path d="M0,0V15.81C13,36.92,27.64,56.86,47.69,72.05,99.41,111.27,165,111,224.58,91.58c31.15-10.15,60.09-26.07,89.67-39.8,40.92-19,84.73-46,130.83-49.67,36.26-2.85,70.9,9.42,98.6,31.56,31.77,25.39,62.32,62,103.63,73,40.44,10.79,81.35-6.69,119.13-24.28s75.16-39,116.92-43.05c59.73-5.85,113.28,22.88,168.9,38.84,30.2,8.66,59,6.17,87.09-7.5,22.43-10.89,48-26.93,60.65-49.24V0Z" opacity=".5" fill="%23ffffff"/><path d="M0,0V5.63C149.93,59,314.09,71.32,475.83,42.57c43-7.64,84.23-20.12,127.61-26.46,59-8.63,112.48,12.24,165.56,35.4C827.93,77.22,886,95.24,951.2,90c86.53-7,172.46-45.71,248.8-84.81V0Z" fill="%23ffffff"/></svg>') repeat-x;
	opacity: 0.1;
	z-index: 1;
}

.exhibition-section .ttl {
	color: #fff;
	text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
	position: relative;
	z-index: 2;
}

.exhibition-section .cards {
	position: relative;
	z-index: 2;
}

/* ===========================================
   9. 卡片樣式
   =========================================== */
.cards { 
	display: grid; 
	grid-template-columns: repeat(3,1fr); 
	gap: 24px; 
}

.cards.list-cards .card {
	transition: transform .15s ease, box-shadow .15s ease;
}

.cards.list-cards .card:hover {
	transform: translateY(-2px); 
	box-shadow: 0 6px 20px rgba(0,0,0,.08);
}

.card { 
	display: block; 
	color: #1A1A1A; 
	text-decoration: none; 
	border: 1px solid #e6e6e6; 
	border-radius: 12px; 
	overflow: hidden; 
	background: #fff; 
}

.card img { 
	width: 100%; 
	height: 220px; 
	object-fit: cover; 
	display: block; 
}

.card h3 { 
	font-size: 20px; 
	line-height: 1.4; 
	padding: 12px 12px 0; 
	margin: 0; 
	font-weight: 700; 
}

.card .more { 
	display: inline-block; 
	margin: 12px; 
	color: #D2691E; 
	font-weight: 700; 
}

.card-yellow {
	background: linear-gradient(135deg, #FFF8DC 0%, #F0E68C 100%);
	box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}

.card-white {
	background: #fff;
	position: relative;
	box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}

.card-header {
	position: absolute;
	top: 12px;
	left: 12px;
	right: 12px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 2;
}

.taiwan-bear {
	font-size: 24px;
	background: rgba(255,255,255,0.9);
	padding: 4px 8px;
	border-radius: 50%;
}

.flags {
	font-size: 20px;
	background: rgba(255,255,255,0.9);
	padding: 4px 8px;
	border-radius: 8px;
}

.taiwan-select-logo {
	background: #8B4513;
	color: #fff;
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 700;
}

/* ===========================================
   10. 食品分類網格
   =========================================== */
.grid { 
	display: grid; 
	grid-template-columns: repeat(4,1fr); 
	gap: 20px; 
}

.grid-item { 
	display: flex; 
	flex-direction: column; 
	align-items: center; 
	gap: 10px; 
	text-decoration: none; 
	color: #8B4513; 
	background: transparent; 
	border-radius: 12px; 
	padding: 16px 8px; 
	border: 0; 
	position: relative;
}

.grid-item img { 
	width: 160px; 
	height: 160px; 
	object-fit: contain; 
	border-radius: 50%; 
	border: 2px solid #D2691E; 
	background: #fff; 
}

.grid-item span { 
	display: block; 
	margin-top: 6px; 
	font-weight: 700; 
	color: #8B4513; 
	text-align: center;
	font-size: 16px;
}

.category-icon {
	width: 160px;
	height: 160px;
	border-radius: 50%;
	border: 2px solid #D2691E;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 64px;
}

.category-icon.plant-based {
	background: linear-gradient(135deg, #90EE90, #32CD32);
	color: #fff;
}

.category-icon.halal {
	background: linear-gradient(135deg, #228B22, #006400);
	color: #fff;
}


/* ===========================================
   11. 頁腳樣式
   =========================================== */
.tsite-footer {
	background: #8B4513;
	color: #fff;
}

.footer-nav {
	background: #2F2F2F;
	padding: 12px 0;
}

.footer-nav-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.footer-links {
	display: flex;
	justify-content: center;
	gap: 40px;
	align-items: center;
	flex: 1;
}

.footer-links a {
	color: #E0E0E0;
	text-decoration: none;
	font-weight: 600;
	font-size: 26px;
	transition: color 0.3s ease;
	padding: 8px 50px;
}

.footer-links a:hover {
	color: #FFD700;
}

.back-to-top {
	background: #FF8C00;
	color: #fff;
	border: none;
	border-radius: 50%;
	width: 40px;
	height: 40px;
	font-size: 18px;
	font-weight: bold;
	cursor: pointer;
	margin-left: auto;
	transition: background 0.3s ease;
}

.back-to-top:hover {
	background: #FFA500;
}

.footer-main {
	background: #8B4513;
	padding: 32px 0;
}

.footer-content {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 40px;
}

.footer-logo {
	flex-shrink: 0;
}

.footer-logo h3 {
	color: #FF8C00;
	font-size: 24px;
	font-weight: 700;
	margin: 0;
}

.footer-info {
	flex: 1;
}

.footer-info p {
	margin: 8px 0;
	line-height: 1.6;
	color: #E0E0E0;
}

.footer-info a {
	color: #FFD700;
	text-decoration: none;
}

.footer-info a:hover {
	color: #fff;
	text-decoration: underline;
}

.footer-info .organized-by {
	color: #FFD700;
	margin-top: 16px;
}

.footer-info .organized-by strong {
	color: #FFD700;
}

/* ===========================================
   12. 動畫效果
   =========================================== */
@keyframes float {
	0%, 100% { transform: translateY(0px); }
	50% { transform: translateY(-10px); }
}

@keyframes drop-float {
	0%, 100% { transform: rotate(-45deg) translateY(0px); opacity: 0.3; }
	50% { transform: rotate(-45deg) translateY(-5px); opacity: 0.6; }
}

/* ===========================================
   13. 響應式設計
   =========================================== */
@media (max-width: 1199.98px) { 
	.cards { grid-template-columns: repeat(3,1fr); } 
}

@media (max-width: 991.98px) { 
	.cards { grid-template-columns: 1fr 1fr; } 
}

@media (max-width: 767.98px) { 
	.hdr { flex-wrap: wrap; gap: 12px; } 
	.cards { grid-template-columns: 1fr; } 
	.grid { grid-template-columns: 1fr 1fr; } 
	.logo img { height: 44px; }
	.hero { min-height: 80vh; }
	.hero-background { height: 80vh; }
	.hero-content h3 { font-size: 42px; }
	.hero-content p { font-size: 22px; }
	.footer-content {
		flex-direction: column;
		gap: 20px;
		text-align: center;
	}
	.footer-nav-content {
		flex-direction: column;
		gap: 16px;
	}
	.footer-links {
		flex-wrap: wrap;
		gap: 16px;
	}
	.exhibition-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 25px;
	}
	.banner-content {
		flex-direction: column;
		gap: 20px;
		text-align: center;
	}
	.banner-text h2 {
		font-size: 24px;
	}
	.event-table {
		min-width: 600px;
	}
	.event-table th,
	.event-table td {
		padding: 8px 6px;
		font-size: 14px;
	}
}

@media (max-width: 575.98px) { 
	.grid { grid-template-columns: 1fr; } 
	.hero { min-height: 70vh; }
	.hero-background { height: 70vh; }
	.hero-content h3 { font-size: 32px; }
	.hero-content p { font-size: 18px; }
	.ttl { font-size: 28px; }
	.banner-text h2 {
		font-size: 20px;
	}
	.taiwan-bear {
		font-size: 36px;
	}
	.food-items span {
		font-size: 24px;
	}
	.event-table {
		min-width: 500px;
	}
	.event-table th,
	.event-table td {
		padding: 6px 4px;
		font-size: 12px;
	}
	.timeline {
		padding-left: 20px;
	}
	.timeline::before {
		left: 10px;
	}
	.timeline-event::before {
		left: -10px;
	}
	.month-header {
		left: -10px;
		padding: 10px 15px;
	}
	.month-header h3 {
		font-size: 18px;
	}
	.event-date {
		min-width: 100px;
		padding: 12px 15px;
		font-size: 12px;
	}
	.event-content h4 {
		font-size: 16px;
	}
	.event-content p {
		font-size: 13px;
	}
	.contact-section {
		grid-template-columns: 1fr;
		gap: 20px;
		padding: 20px;
	}
	.exhibition-grid {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	.exhibition-logo {
		padding: 20px 15px;
		min-height: 100px;
	}
	.logo-main {
		font-size: 20px;
	}
	.fha-main {
		font-size: 24px;
	}
	.exhibition-title {
		font-size: 14px;
		padding: 12px 15px;
	}
}

/* ===========================================
   14. 活動列表頁面專用樣式
   =========================================== */
.page-title-section {
	background: #fff;
	padding: 40px 0;
	text-align: center;
	border-bottom: 1px solid #E0E0E0;
}

.page-title {
	font-size: 36px;
	color: #8B4513;
	font-weight: 700;
	margin: 0 0 12px 0;
}

.page-subtitle {
	font-size: 18px;
	color: #666;
	margin: 0;
}
.event-banner {
	margin: 40px 0;
	border-radius: 12px;
	position: relative;
	overflow: hidden;
	text-align: center;
}

.banner-image {
	width: 100%;
	height: auto;
	max-width: 100%;
	border-radius: 12px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.banner-content {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 40px;
	position: relative;
	z-index: 2;
}

.banner-illustration {
	display: flex;
	align-items: center;
	gap: 20px;
}

.taiwan-bear {
	font-size: 48px;
	animation: bounce 2s ease-in-out infinite;
}

.food-items {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.food-items span {
	font-size: 32px;
	animation: float 3s ease-in-out infinite;
}

.food-items .bubble-tea { animation-delay: 0s; }
.food-items .pineapple-cake { animation-delay: 0.5s; }
.food-items .fruits { animation-delay: 1s; }

.banner-text h2 {
	color: #fff;
	font-size: 32px;
	font-weight: 700;
	text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
	margin: 0;
}

.important-notices {
	background: #FFF8DC;
	border: 2px solid #FFD700;
	border-radius: 8px;
	padding: 20px;
	margin: 30px 0;
}

.notice-red {
	color: #D2691E;
	font-weight: 600;
	margin: 8px 0;
}

.newsletter-link {
	color: #D2691E;
	text-decoration: underline;
	font-weight: 600;
}

.contact-info {
	font-size: 18px;
	font-weight: 600;
	color: #8B4513;
	margin: 12px 0;
}

.disclaimer {
	font-size: 14px;
	color: #666;
	font-style: italic;
	margin: 8px 0 0;
}

.event-table-container {
	overflow-x: auto;
	margin: 30px 0;
	box-shadow: 0 4px 8px rgba(0,0,0,0.1);
	border-radius: 8px;
}

.event-table {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
	min-width: 800px;
}

.event-table th {
	background: #8B4513;
	color: #fff;
	padding: 16px 12px;
	text-align: left;
	font-weight: 700;
	border-bottom: 2px solid #A0522D;
}

.event-table td {
	padding: 12px;
	border-bottom: 1px solid #E0E0E0;
	vertical-align: top;
}

.event-table tr:hover {
	background: #FFF8DC;
}

.event-table a {
	color: #D2691E;
	text-decoration: none;
	font-weight: 600;
}

.event-table a:hover {
	color: #8B4513;
	text-decoration: underline;
}

.sub-event {
	background: #F5F5F5;
}

.sub-event td:first-child {
	border-left: 4px solid #D2691E;
}

.organized-by-section {
	background: #F0E68C;
	border-radius: 8px;
	padding: 20px;
	margin: 30px 0;
	text-align: center;
}

.organized-by-section p {
	margin: 4px 0;
	color: #8B4513;
	font-weight: 600;
}

.organized-by-section p:first-child {
	font-size: 18px;
	font-weight: 700;
}

/* ===========================================
   15. 展覽網格樣式
   =========================================== */
.breadcrumb-section {
	background: #F5F5F5;
	padding: 12px 0;
	border-bottom: 1px solid #E0E0E0;
}

.breadcrumb {
	font-size: 14px;
	color: #666;
}

.breadcrumb a {
	color: #D2691E;
	text-decoration: none;
}

.breadcrumb a:hover {
	text-decoration: underline;
}

.exhibition-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
	margin: 40px 0;
}

.exhibition-card {
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.1);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	position: relative;
}

.exhibition-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}

.exhibition-card.taiwan-select {
	border: 3px solid #FF8C00;
}

.exhibition-logo {
	padding: 30px 20px;
	text-align: center;
	background: linear-gradient(135deg, #F8F9FA 0%, #E9ECEF 100%);
	min-height: 120px;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Natural Products Expo West Logo */
.logo-npew {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
}

.starburst {
	font-size: 32px;
	animation: sparkle 2s ease-in-out infinite;
}

.logo-text {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.main-text {
	font-size: 18px;
	font-weight: 700;
	color: #333;
	line-height: 1.2;
}

.sub-text {
	font-size: 14px;
	font-weight: 600;
	color: #666;
	letter-spacing: 1px;
}

/* FOODEX JAPAN Logo */
.logo-foodex {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}

.logo-subtitle {
	font-size: 10px;
	color: #666;
	text-align: center;
	line-height: 1.2;
}

.logo-main {
	font-size: 24px;
	font-weight: 700;
	color: #DC143C;
	letter-spacing: 1px;
}

.logo-japanese {
	font-size: 12px;
	color: #333;
	font-weight: 600;
}

.taiwan-select-badge {
	background: #FF8C00;
	color: #fff;
	padding: 4px 12px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 700;
	margin-top: 8px;
}

/* IFE Logo */
.logo-ife {
	display: flex;
	align-items: center;
	justify-content: center;
}

.ife-square {
	width: 60px;
	height: 60px;
	border: 3px dashed #20B2AA;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	font-weight: 700;
	color: #20B2AA;
}

/* FHA Logo */
.logo-fha {
	display: flex;
	align-items: center;
	gap: 15px;
}

.apple-icon {
	font-size: 32px;
}

.fha-text {
	display: flex;
	flex-direction: column;
}

.fha-main {
	font-size: 28px;
	font-weight: 700;
	color: #228B22;
	line-height: 1;
}

.fha-sub {
	font-size: 12px;
	color: #228B22;
	font-weight: 600;
	letter-spacing: 0.5px;
}

.exhibition-date {
	background: #333;
	color: #fff;
	padding: 8px 16px;
	font-size: 14px;
	font-weight: 600;
	text-align: center;
	position: relative;
	z-index: 2;
}

.exhibition-title {
	padding: 16px 20px;
	font-size: 16px;
	font-weight: 600;
	color: #333;
	line-height: 1.3;
	text-align: center;
}

/* Animations */
@keyframes sparkle {
	0%, 100% { transform: scale(1) rotate(0deg); }
	50% { transform: scale(1.1) rotate(180deg); }
}

/* ===========================================
   16. 時間軸樣式 (保留作為備用)
   =========================================== */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline {
	position: relative;
	padding-left: 30px;
}

.timeline::before {
	content: '';
	position: absolute;
	left: 15px;
	top: 0;
	bottom: 0;
	width: 3px;
	background: linear-gradient(to bottom, #8B4513, #D2691E, #FF8C00);
	border-radius: 2px;
}

.timeline-month {
	margin-bottom: 40px;
	position: relative;
}

.month-header {
	background: #8B4513;
	color: #fff;
	padding: 12px 20px;
	border-radius: 8px;
	margin-bottom: 20px;
	position: relative;
	left: -15px;
	box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

.month-header h3 {
	margin: 0;
	font-size: 20px;
	font-weight: 700;
}

.timeline-events {
	position: relative;
}

.timeline-event {
	display: flex;
	margin-bottom: 20px;
	position: relative;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);
	overflow: hidden;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.timeline-event:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.timeline-event::before {
	content: '';
	position: absolute;
	left: -15px;
	top: 50%;
	transform: translateY(-50%);
	width: 12px;
	height: 12px;
	background: #D2691E;
	border: 3px solid #fff;
	border-radius: 50%;
	box-shadow: 0 0 0 3px #8B4513;
}

.sub-event::before {
	background: #FF8C00;
	width: 8px;
	height: 8px;
}

.event-date {
	background: #F0E68C;
	color: #8B4513;
	padding: 16px 20px;
	font-weight: 700;
	font-size: 14px;
	min-width: 120px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	border-right: 2px solid #D2691E;
}

.sub-event .event-date {
	background: #F5F5F5;
	color: #666;
	border-right: 2px solid #FF8C00;
}

.event-content {
	flex: 1;
	padding: 16px 20px;
}

.event-content h4 {
	margin: 0 0 8px;
	color: #8B4513;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.3;
}

.event-content p {
	margin: 0;
	color: #666;
	font-size: 14px;
	line-height: 1.4;
}

.sub-event .event-content h4 {
	color: #666;
	font-size: 16px;
}

.sub-event .event-content p {
	color: #999;
	font-size: 13px;
}

.contact-section {
	background: #FFF8DC;
	border: 2px solid #FFD700;
	border-radius: 12px;
	padding: 30px;
	margin: 40px 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: start;
}

.contact-info p,
.organized-by p {
	margin: 8px 0;
	color: #8B4513;
	font-size: 16px;
}

.contact-info strong,
.organized-by strong {
	color: #D2691E;
	font-weight: 700;
}

.contact-info a {
	color: #D2691E;
	text-decoration: none;
	font-weight: 600;
}

.contact-info a:hover {
	text-decoration: underline;
}

/* ===========================================
   15. 參展商頁面樣式
   =========================================== */
.companies-section {
    padding: 40px 0;
    background: #fff;
}

.companies-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 20px !important;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    width: 100%;
    justify-content: center;
}

.companies-grid .exhibitor-card {
    flex: 0 0 calc(50% - 10px) !important;
    max-width: calc(50% - 10px) !important;
    min-width: 250px;
}

@media (max-width: 480px) {
    .companies-grid {
        flex-direction: column;
        gap: 15px;
        padding: 0 10px;
    }
    
    .companies-grid .exhibitor-card {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
}


@media (max-width: 768px) and (min-width: 481px) {
    .companies-grid {
        padding: 0 15px;
    }
    
    .companies-grid .exhibitor-card {
        flex: 0 0 calc(50% - 8px) !important;
        max-width: calc(50% - 8px) !important;
        min-width: 180px;
    }
}
.breadcrumb-section {
    background: #f8f8f8;
    padding: 15px 0;
    border-bottom: 1px solid #ddd;
}

.breadcrumb {
    font-size: 14px;
    color: #666;
}

.breadcrumb a {
    color: #8B4513;
    text-decoration: none;
}

.breadcrumb a:hover {
    text-decoration: underline;
}

.exhibitors-section {
    padding: 60px 0;
    background: #fff;
}

.section-title {
    font-size: 36px;
    color: #8B4513;
    text-align: center;
    margin-bottom: 50px;
    font-weight: 700;
}

.exhibitors-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
}

.exhibitor-card {
    background: #fff !important;
    border: 2px solid #D2691E !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
    display: block !important;
    width: 100% !important;
}

.exhibitor-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

.exhibitor-image {
    width: 100%;
    height: 200px;
    overflow: hidden;
    position: relative;
}

.exhibitor-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.exhibitor-info {
    padding: 20px;
}

.exhibitor-name {
    font-size: 18px;
    font-weight: 700;
    color: #8B4513;
    margin-bottom: 8px;
    line-height: 1.3;
}

.exhibitor-english {
    font-size: 14px;
    color: #666;
    font-style: italic;
    margin-bottom: 12px;
}

.exhibitor-products {
    font-size: 14px;
    color: #555;
    line-height: 1.5;
    margin-bottom: 15px;
}

.exhibitor-link {
    display: inline-block;
    background: #D2691E;
    color: #fff;
    padding: 8px 16px;
    border-radius: 6px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: background 0.3s ease;
}

.exhibitor-link:hover {
    background: #B8571A;
    color: #fff;
}

/* 響應式設計 - 參展商頁面 */
@media (max-width: 767.98px) {
    .exhibitors-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .section-title {
        font-size: 28px;
    }
    
    .exhibitor-card {
        margin: 0 10px;
    }
}

/* ===========================================
   16. 其他樣式
   =========================================== */
.meta { margin: 8px 0 12px; color: #333; }
.attachments { margin: 12px 0 24px; }
.attachments li { margin: 6px 0; }
.gallery { margin: 16px 0 24px; }
.gallery .card img { height: 260px; }

/* ===========================================
   17. 新增展覽卡片樣式
   =========================================== */

/* SIAL Canada Logo */
.logo-sial {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: linear-gradient(135deg, #FF6B6B, #FF8E8E);
	border-radius: 8px;
	padding: 20px;
}

.sial-text {
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	margin-bottom: 4px;
}

.sial-sub {
	font-size: 14px;
	color: #fff;
	opacity: 0.9;
}

/* Taiwan Expo Logo */
.logo-taiwan-expo {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: linear-gradient(135deg, #4ECDC4, #44A08D);
	border-radius: 8px;
	padding: 20px;
	gap: 12px;
}

.taiwan-flag {
	font-size: 32px;
}

.expo-text {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.expo-main {
	font-size: 18px;
	font-weight: 700;
	color: #fff;
	margin-bottom: 2px;
}

.expo-sub {
	font-size: 12px;
	color: #fff;
	opacity: 0.9;
}

/* Trade Mission Logo */
.logo-trade-mission {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: linear-gradient(135deg, #667eea, #764ba2);
	border-radius: 8px;
	padding: 20px;
}

.mission-flags {
	font-size: 24px;
	margin-bottom: 8px;
}

.mission-text {
	font-size: 14px;
	font-weight: 600;
	color: #fff;
	text-align: center;
}

/* Fine Food Australia Logo */
.logo-fine-food {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: linear-gradient(135deg, #f093fb, #f5576c);
	border-radius: 8px;
	padding: 20px;
	position: relative;
}

.fine-food-text {
	font-size: 20px;
	font-weight: 700;
	color: #fff;
	margin-bottom: 4px;
}

.fine-food-sub {
	font-size: 14px;
	color: #fff;
	opacity: 0.9;
}

/* Anuga Logo */
.logo-anuga {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: linear-gradient(135deg, #FFD700, #FFA500);
	border-radius: 8px;
	padding: 20px;
}

.anuga-text {
	font-size: 24px;
	font-weight: 700;
	color: #8B4513;
	margin-bottom: 4px;
}

.anuga-sub {
	font-size: 14px;
	color: #8B4513;
	opacity: 0.8;
}

/* 展覽Logo圖片樣式 */
.exhibition-logo-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	border-radius: 8px;
}