body { font-family: "Noto Sans TC", sans-serif; background-color: #fffafb; color: #4a3b32; margin: 0; padding: 0; line-height: 1.6; overflow-x: hidden; }

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

img { max-width: 100%; height: auto; display: block; }
.scroll-fade { opacity: 0; transform: translateY(30px); transition: opacity 0.8s ease, transform 0.8s ease; }
.scroll-fade.is-active { opacity: 1; transform: translateY(0); }

/* header */
header { position: fixed; top: 0; left: 0; width: 100%; background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(5px); box-shadow: 0 2px 15px rgba(230, 190, 195, 0.2); display: flex; justify-content: space-between; align-items: center; padding: 15px 5%; box-sizing: border-box; z-index: 999; transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
header.is-hidden { transform: translateY(-100%); }
header h1 { margin: 0; font-size: 20px; font-weight: 700; color: #d67a8b; letter-spacing: 1px; }
header nav { display: flex; gap: 30px; }
header nav a { font-size: 15px; font-weight: 500; color: #4a3b32; transition: color 0.3s ease; }
header nav a:hover { color: #d67a8b; }

main { margin-top: 60px; }

/* hero-section */
#hero-section { position: relative; height: 90vh; min-height: 600px; display: flex; align-items: center; justify-content: center; text-align: center; background: linear-gradient(135deg, #ffeef1 0%, #fffafb 100%) no-repeat 50% / cover; background-image: url(../img/img-hero.webp); overflow: hidden; padding: 0 5%; }
#hero-section::before { content: ""; inset: 0; position: absolute; background: radial-gradient( circle, rgba(255, 255, 255, 0.8) 0%, rgba(255, 255, 255, .1) 70% ); pointer-events: none; }
#hero-section .hero-content { position: relative; z-index: 2; max-width: 800px; }
#hero-section h2 { font-size: 48px; font-weight: 900; color: #b85c6d; margin: 0 0 20px; line-height: 1.2; letter-spacing: 2px; }
#hero-section .hero-subtitle { font-size: 20px; font-weight: 400; color: #7a655c; margin-bottom: 40px; }
#hero-section .hero-action { display: inline-block; padding: 15px 40px; background-color: #d67a8b; color: #fff; font-size: 16px; font-weight: 700; border-radius: 30px; letter-spacing: 1px; transition: background-color 0.3s ease, transform 0.3s ease; box-shadow: 0 10px 20px rgba(214, 122, 139, 0.3); }
#hero-section .hero-action:hover { background-color: #b85c6d; transform: translateY(-3px); }

/* guide-section */
#guide-section { padding: 100px 5%; background-color: #fff; }
#guide-section h2 { text-align: center; font-size: 36px; font-weight: 700; color: #4a3b32; margin-bottom: 60px; position: relative; }
#guide-section h2::after { content: ""; position: absolute; bottom: -15px; left: 50%; transform: translateX(-50%); width: 60px; height: 3px; background-color: #d67a8b; }
#guide-section .guide-list { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 40px; }
#guide-section .guide-item { display: flex; gap: 30px; align-items: flex-start; padding-bottom: 40px; border-bottom: 1px solid #ffeef1; }
#guide-section .guide-item:last-child { border-bottom: none; padding-bottom: 0; }
#guide-section .guide-left { flex: 0 0 120px; text-align: center; }
#guide-section .guide-subtitle { display: inline-block; background-color: #ffeef1; color: #d67a8b; font-weight: 700; padding: 5px 15px; border-radius: 20px; font-size: 14px; margin-bottom: 10px; }
#guide-section .guide-title { font-size: 20px; font-weight: 700; color: #332822; margin: 0; }
#guide-section .guide-right { flex: 1; padding-top: 5px; }
#guide-section .guide-text { font-size: 16px; color: #7a655c; margin: 0; line-height: 1.8; }

/* recommend-section */
#recommend-section { padding: 100px 5%; background-color: #fffafb; }
#recommend-section h2 { text-align: center; font-size: 36px; font-weight: 700; color: #4a3b32; margin-bottom: 60px; position: relative; }
#recommend-section h2::after { content: ""; position: absolute; bottom: -15px; left: 50%; transform: translateX(-50%); width: 60px; height: 3px; background-color: #d67a8b; }
#recommend-section .recommend-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; max-width: 1400px; margin: 0 auto; }
#recommend-section .recommend-item { background: #fff; border-radius: 20px; overflow: hidden; box-shadow: 0 15px 35px rgba(0, 0, 0, 0.03); transition: transform 0.4s ease, box-shadow 0.4s ease; cursor: pointer; }
#recommend-section .recommend-item:hover { transform: translateY(-10px); box-shadow: 0 20px 40px rgba(214, 122, 139, 0.15); }
#recommend-section .recommend-media { width: 100%; aspect-ratio: 4/3; background-color: #ffeef1; overflow: hidden; position: relative; display: flex; align-items: center; justify-content: center; }
#recommend-section .recommend-media img { object-fit: cover; aspect-ratio: 4 / 3; }
#recommend-section .recommend-media span { font-size: 14px; color: #d67a8b; font-weight: 500; letter-spacing: 2px; }
#recommend-section .recommend-content { padding: 30px 25px; }
#recommend-section .recommend-subtitle { font-size: 13px; color: #d67a8b; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; display: block; }
#recommend-section .recommend-title { font-size: 22px; font-weight: 700; margin: 0 0 15px; color: #332822; }
#recommend-section .recommend-text { font-size: 15px; color: #7a655c; margin: 0; line-height: 1.6; }

/* brand-section */
#brand-section { padding: 100px 5%; background-color: #fff; }
#brand-section h2 { text-align: center; font-size: 36px; font-weight: 700; color: #4a3b32; margin-bottom: 60px; position: relative; }
#brand-section h2::after { content: ""; position: absolute; bottom: -15px; left: 50%; transform: translateX(-50%); width: 60px; height: 3px; background-color: #d67a8b; }
#brand-section .brand-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; max-width: 1200px; margin: 0 auto; }
#brand-section .brand-item { text-align: center; transition: transform 0.3s ease; cursor: pointer; }
#brand-section .brand-item:hover { transform: translateY(-10px); }
#brand-section .brand-media { width: 140px; height: 140px; margin: 0 auto 20px; border-radius: 50%; background-color: #ffeef1; display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 20px rgba(214, 122, 139, 0.1); border: 4px solid #fff; overflow: hidden; }
#brand-section .brand-media img { object-fit: cover; aspect-ratio: 1 / 1; }
#brand-section .brand-media span { font-size: 13px; color: #d67a8b; font-weight: 500; }
#brand-section .brand-content { padding: 0 15px; }
#brand-section .brand-title { font-size: 22px; font-weight: 700; color: #332822; margin: 0 0 10px; }
#brand-section .brand-text { font-size: 15px; color: #7a655c; margin: 0; line-height: 1.6; }

/* discount-section */
#discount-section { padding: 100px 5%; background: linear-gradient(180deg, #fffafb 0%, #ffeef1 100%); }
#discount-section h2 { text-align: center; font-size: 36px; font-weight: 700; color: #4a3b32; margin-bottom: 60px; position: relative; }
#discount-section h2::after { content: ""; position: absolute; bottom: -15px; left: 50%; transform: translateX(-50%); width: 60px; height: 3px; background-color: #d67a8b; }
#discount-section .discount-list { max-width: 900px; margin: 0 auto; display: flex; flex-direction: column; gap: 20px; }
#discount-section .discount-item { background: #fff; border-radius: 15px; padding: 30px 40px; display: flex; justify-content: space-between; align-items: center; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.02); border-left: 5px solid #d67a8b; transition: transform 0.3s ease; }
#discount-section .discount-item:hover { transform: translateX(10px); }
#discount-section .discount-left { flex: 1; }
#discount-section .discount-title { font-size: 24px; font-weight: 700; color: #332822; margin: 0 0 5px; }
#discount-section .discount-text { font-size: 16px; color: #7a655c; margin: 0; }
#discount-section .discount-right { text-align: right; padding-left: 30px; }
#discount-section .discount-right strong { display: block; font-size: 36px; font-weight: 900; color: #b85c6d; line-height: 1; margin-bottom: 5px; }
#discount-section .discount-right span { font-size: 14px; color: #a18b82; font-weight: 500; }

/* footer */
footer { background-color: #332822; padding: 60px 5% 40px; text-align: center; }
footer .footer-logo { font-size: 24px; font-weight: 700; color: #fff; margin-bottom: 20px; display: inline-block; }
footer .footer-links { display: flex; justify-content: center; gap: 30px; margin-bottom: 40px; }
footer .footer-links a { color: #a18b82; font-size: 14px; transition: color 0.3s ease; }
footer .footer-links a:hover { color: #d67a8b; }
footer .footer-copyright { border-top: 1px solid rgba(255, 255, 255, 0.1); padding-top: 30px; color: #7a655c; font-size: 12px; }

@media (max-width: 1280px) {
	#recommend-section .recommend-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 960px) {
	#hero-section h2 { font-size: 38px; }
	#guide-section .guide-item { flex-direction: column; text-align: center; align-items: center; gap: 15px; }
	#recommend-section .recommend-grid { grid-template-columns: repeat(2, 1fr); }
	#brand-section .brand-grid { grid-template-columns: repeat(2, 1fr); }
	#discount-section .discount-item { flex-direction: column; text-align: center; padding: 30px; border-left: none; border-top: 5px solid #d67a8b; }
	#discount-section .discount-right { padding-left: 0; text-align: center; margin-top: 20px; padding-top: 20px; border-top: 1px dashed #eee; width: 100%; }
}
@media (max-width: 768px) {
	header h1 { font-size: 18px; }
	header nav { display: none; }
	#hero-section h2 { font-size: 32px; }
	#hero-section .hero-subtitle { font-size: 16px; }
	#guide-section h2 { font-size: 28px; }
	#recommend-section h2 { font-size: 28px; }
	#brand-section h2 { font-size: 28px; }
	#discount-section h2 { font-size: 28px; }
}
@media (max-width: 500px) {
	#hero-section h2 { font-size: 28px; }
	#recommend-section .recommend-grid { grid-template-columns: 1fr; }
	#brand-section .brand-grid { grid-template-columns: 1fr; }
	#discount-section .discount-title { font-size: 20px; }
	#discount-section .discount-right strong { font-size: 30px; }
}
