* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body { background: #f6f7fb; color: #182033; font-family: "Noto Sans TC", sans-serif; line-height: 1.8; overflow-x: hidden; }

a { color: inherit; text-decoration: none; }

img { display: block; height: auto; max-width: 100%; }

header { align-items: center; backdrop-filter: blur(18px); background: rgba(255, 255, 255, 0.82); border-bottom: 1px solid rgba(24, 32, 51, 0.08); display: flex; justify-content: space-between; left: 0; padding: 18px 7%; position: fixed; top: 0; width: 100%; z-index: 20; }
header .site-brand { align-items: center; display: flex; gap: 12px; }
header .brand-mark { align-items: center; background: linear-gradient(135deg, #7c3cff, #00d4ff); border-radius: 16px; box-shadow: 0 12px 30px rgba(124, 60, 255, 0.25); color: #fff; display: flex; font-size: 16px; font-weight: 900; height: 42px; justify-content: center; width: 42px; }
header h1 { color: #111827; font-size: 20px; font-weight: 900; letter-spacing: 0.02em; }
header nav { align-items: center; display: flex; gap: 28px; }
header nav a { color: #3d465d; font-size: 15px; font-weight: 700; position: relative; transition: color 0.3s ease; }
header nav a:after { background: linear-gradient(90deg, #7c3cff, #00d4ff); border-radius: 99px; bottom: -8px; content: ""; height: 3px; left: 0; position: absolute; transform: scaleX(0); transform-origin: left; transition: transform 0.3s ease; width: 100%; }
header nav a:hover { color: #7c3cff; }
header nav a:hover:after { transform: scaleX(1); }
header .header-action { background: #111827; border-radius: 999px; color: #fff; font-size: 14px; font-weight: 700; padding: 10px 18px; transition: background 0.3s ease, transform 0.3s ease; }
header .header-action:hover { background: #7c3cff; transform: translateY(-2px); }

main { padding-top: 78px; }

#hero-section { background: radial-gradient( circle at 15% 20%, rgba(124, 60, 255, 0.18), transparent 30% ), radial-gradient( circle at 85% 10%, rgba(0, 212, 255, 0.18), transparent 28% ), linear-gradient(135deg, #ffffff 0%, #edf2ff 100%); min-height: 760px; overflow: hidden; padding: 96px 7% 90px; position: relative; }
#hero-section:before { background: linear-gradient( 135deg, rgba(124, 60, 255, 0.13), rgba(0, 212, 255, 0.08) ); border-radius: 50%; content: ""; height: 520px; position: absolute; right: -220px; top: 90px; width: 520px; }
#hero-section .hero-grid { align-items: center; display: grid; gap: 58px; grid-template-columns: 1.02fr 0.98fr; margin: 0 auto; max-width: 1240px; position: relative; z-index: 2; }
#hero-section .hero-kicker { align-items: center; background: rgba(124, 60, 255, 0.08); border: 1px solid rgba(124, 60, 255, 0.18); border-radius: 999px; color: #6d35e8; display: inline-flex; font-size: 14px; font-weight: 900; gap: 8px; margin-bottom: 22px; padding: 8px 16px; }
#hero-section .hero-kicker:before { background: #00d4ff; border-radius: 50%; box-shadow: 0 0 0 7px rgba(0, 212, 255, 0.16); content: ""; height: 8px; width: 8px; }
#hero-section h2 { color: #101828; font-size: 58px; font-weight: 900; letter-spacing: -0.05em; line-height: 1.16; margin-bottom: 24px; }
#hero-section .hero-text { color: #596174; font-size: 18px; margin-bottom: 34px; max-width: 620px; }
#hero-section .hero-actions { align-items: center; display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 42px; }
#hero-section .hero-primary { background: linear-gradient(135deg, #7c3cff, #00b7ff); border-radius: 999px; box-shadow: 0 18px 42px rgba(124, 60, 255, 0.28); color: #fff; font-size: 16px; font-weight: 900; padding: 14px 24px; transition: box-shadow 0.3s ease, transform 0.3s ease; }
#hero-section .hero-primary:hover { box-shadow: 0 24px 54px rgba(0, 183, 255, 0.28); transform: translateY(-3px); }
#hero-section .hero-secondary { background: rgba(255, 255, 255, 0.78); border: 1px solid rgba(24, 32, 51, 0.1); border-radius: 999px; color: #273044; font-size: 16px; font-weight: 900; padding: 14px 24px; transition: border 0.3s ease, color 0.3s ease, transform 0.3s ease; }
#hero-section .hero-secondary:hover { border-color: rgba(124, 60, 255, 0.35); color: #7c3cff; transform: translateY(-3px); }
#hero-section .hero-list { display: grid; gap: 14px; max-width: 600px; }
#hero-section .hero-item { align-items: flex-start; background: rgba(255, 255, 255, 0.76); border: 1px solid rgba(24, 32, 51, 0.08); border-radius: 20px; box-shadow: 0 18px 44px rgba(28, 35, 55, 0.06); display: flex; gap: 14px; padding: 16px; transition: border 0.3s ease, transform 0.3s ease; }
#hero-section .hero-item:hover { border-color: rgba(124, 60, 255, 0.22); transform: translateX(4px); }
#hero-section .hero-icon { align-items: center; background: linear-gradient( 135deg, rgba(124, 60, 255, 0.12), rgba(0, 212, 255, 0.16) ); border-radius: 14px; color: #6d35e8; display: flex; flex: 0 0 auto; font-size: 18px; font-weight: 900; height: 42px; justify-content: center; width: 42px; }
#hero-section .hero-item-title { color: #182033; font-size: 16px; font-weight: 900; margin-bottom: 2px; }
#hero-section .hero-item-text { color: #6b7280; font-size: 14px; }
#hero-section .hero-media { position: relative; }
#hero-section .hero-figure { background: rgba(255, 255, 255, 0.72); border: 1px solid rgba(255, 255, 255, 0.72); border-radius: 38px; box-shadow: 0 28px 78px rgba(36, 47, 83, 0.16); overflow: hidden; padding: 16px; position: relative; transform: rotate(2deg); transition: transform 0.6s ease; }
#hero-section .hero-figure:hover { transform: rotate(0deg) translateY(-8px); }
#hero-section .hero-image { border-radius: 28px; min-height: 430px; object-fit: cover; width: 100%; }
#hero-section .hero-panel { background: rgba(17, 24, 39, 0.9); border: 1px solid rgba(255, 255, 255, 0.18); border-radius: 24px; bottom: 36px; box-shadow: 0 24px 52px rgba(17, 24, 39, 0.2); color: #fff; left: -32px; padding: 18px; position: absolute; width: 245px; }
#hero-section .panel-label { color: #b8c2d8; font-size: 13px; font-weight: 700; margin-bottom: 6px; }
#hero-section .panel-title { font-size: 22px; font-weight: 900; line-height: 1.3; margin-bottom: 10px; }
#hero-section .panel-bar { background: rgba(255, 255, 255, 0.14); border-radius: 999px; height: 9px; overflow: hidden; }
#hero-section .panel-bar span { background: linear-gradient(90deg, #7c3cff, #00d4ff); border-radius: 999px; display: block; height: 100%; width: 72%; }
#hero-section .hero-badge { align-items: center; animation: badge-float 4.8s ease-in-out infinite; background: #fff; border-radius: 22px; box-shadow: 0 20px 48px rgba(30, 41, 59, 0.13); color: #182033; display: flex; font-size: 14px; font-weight: 900; gap: 10px; padding: 13px 16px; position: absolute; right: -24px; top: 48px; }
#hero-section .hero-badge span { align-items: center; background: #ff3d71; border-radius: 50%; color: #fff; display: flex; height: 30px; justify-content: center; width: 30px; }

#platform-section { background: #111827; color: #fff; overflow: hidden; padding: 106px 7%; position: relative; }
#platform-section:before { background: radial-gradient( circle, rgba(0, 212, 255, 0.18), transparent 60% ); content: ""; height: 600px; left: -180px; position: absolute; top: -180px; width: 600px; }
#platform-section .platform-content { margin: 0 auto 52px; max-width: 820px; position: relative; text-align: center; z-index: 2; }
#platform-section .section-label { color: #6ee7ff; font-size: 15px; font-weight: 900; letter-spacing: 0.16em; margin-bottom: 12px; text-transform: uppercase; }
#platform-section h2 { font-size: 42px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.25; margin-bottom: 18px; }
#platform-section .platform-text { color: #b9c3d7; font-size: 17px; }
#platform-section .platform-grid { display: grid; gap: 22px; grid-template-columns: repeat(4, 1fr); margin: 0 auto; max-width: 1240px; position: relative; z-index: 2; }
#platform-section .platform-item { background: rgba(255, 255, 255, 0.07); border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 28px; min-height: 295px; overflow: hidden; padding: 24px; position: relative; transition: background 0.35s ease, border 0.35s ease, transform 0.35s ease; }
#platform-section .platform-item:hover { background: rgba(255, 255, 255, 0.11); border-color: rgba(110, 231, 255, 0.28); transform: translateY(-8px); }
#platform-section .platform-image { border-radius: 22px; height: 132px; margin-bottom: 22px; object-fit: cover; width: 100%; }
#platform-section .platform-title { font-size: 21px; font-weight: 900; margin-bottom: 9px; }
#platform-section .platform-description { color: #c7d2e6; font-size: 15px; }
#platform-section .platform-number { bottom: -20px; color: rgba(255, 255, 255, 0.07); font-size: 84px; font-weight: 900; line-height: 1; position: absolute; right: 14px; }

#work-section { background: #fff; padding: 106px 7%; }
#work-section .work-grid { align-items: center; display: grid; gap: 64px; grid-template-columns: 0.9fr 1.1fr; margin: 0 auto; max-width: 1240px; }
#work-section .work-media { position: relative; }
#work-section .work-figure { background: #edf2ff; border-radius: 34px; overflow: hidden; padding: 14px; position: relative; }
#work-section .work-image { border-radius: 24px; height: 540px; object-fit: cover; width: 100%; }
#work-section .work-card { background: #fff; border: 1px solid rgba(24, 32, 51, 0.08); border-radius: 24px; bottom: 30px; box-shadow: 0 24px 54px rgba(30, 41, 59, 0.14); padding: 20px; position: absolute; right: -26px; width: 250px; }
#work-section .work-card-title { color: #111827; font-size: 18px; font-weight: 900; margin-bottom: 10px; }
#work-section .work-card-text { color: #667085; font-size: 14px; }
#work-section .section-label { color: #7c3cff; font-size: 15px; font-weight: 900; letter-spacing: 0.16em; margin-bottom: 12px; text-transform: uppercase; }
#work-section h2 { color: #101828; font-size: 42px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.25; margin-bottom: 18px; }
#work-section .work-text { color: #596174; font-size: 17px; margin-bottom: 34px; }
#work-section .work-list { display: grid; gap: 18px; }
#work-section .work-item { align-items: flex-start; border-bottom: 1px solid rgba(24, 32, 51, 0.09); display: flex; gap: 18px; padding-bottom: 18px; transition: transform 0.3s ease; }
#work-section .work-item:hover { transform: translateX(6px); }
#work-section .work-icon { align-items: center; background: #f0eaff; border-radius: 18px; color: #7c3cff; display: flex; flex: 0 0 auto; font-size: 18px; font-weight: 900; height: 48px; justify-content: center; width: 48px; }
#work-section .work-title { color: #182033; font-size: 19px; font-weight: 900; margin-bottom: 5px; }
#work-section .work-description { color: #6b7280; font-size: 15px; }

#income-section { background: linear-gradient(180deg, #f6f7fb 0%, #ffffff 100%); padding: 106px 7%; position: relative; }
#income-section .income-content { margin: 0 auto 52px; max-width: 820px; text-align: center; }
#income-section .section-label { color: #00a7d8; font-size: 15px; font-weight: 900; letter-spacing: 0.16em; margin-bottom: 12px; text-transform: uppercase; }
#income-section h2 { color: #101828; font-size: 42px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.25; margin-bottom: 18px; }
#income-section .income-text { color: #596174; font-size: 17px; }
#income-section .income-grid { display: grid; gap: 24px; grid-template-columns: repeat(3, 1fr); margin: 0 auto; max-width: 1240px; }
#income-section .income-item { background: #fff; border: 1px solid rgba(24, 32, 51, 0.08); border-radius: 30px; box-shadow: 0 20px 56px rgba(30, 41, 59, 0.07); overflow: hidden; padding: 28px; position: relative; transition: border 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease; }
#income-section .income-item:hover { border-color: rgba(0, 212, 255, 0.36); box-shadow: 0 26px 68px rgba(0, 164, 216, 0.12); transform: translateY(-8px); }
#income-section .income-icon { align-items: center; background: linear-gradient(135deg, #ecf8ff, #f4edff); border-radius: 22px; color: #008fc2; display: flex; font-size: 28px; font-weight: 900; height: 64px; justify-content: center; margin-bottom: 24px; width: 64px; }
#income-section .income-title { color: #182033; font-size: 22px; font-weight: 900; margin-bottom: 10px; }
#income-section .income-description { color: #667085; font-size: 15px; margin-bottom: 22px; }
#income-section .income-tag { background: rgba(124, 60, 255, 0.08); border-radius: 999px; color: #6d35e8; display: inline-flex; font-size: 13px; font-weight: 900; padding: 7px 12px; }

#equipment-section { background: #101828; color: #fff; overflow: hidden; padding: 106px 7%; position: relative; }
#equipment-section:after { background: radial-gradient( circle, rgba(124, 60, 255, 0.2), transparent 60% ); bottom: -240px; content: ""; height: 650px; position: absolute; right: -200px; width: 650px; }
#equipment-section .equipment-grid { align-items: center; display: grid; gap: 64px; grid-template-columns: 1fr 1fr; margin: 0 auto; max-width: 1240px; position: relative; z-index: 2; }
#equipment-section .section-label { color: #6ee7ff; font-size: 15px; font-weight: 900; letter-spacing: 0.16em; margin-bottom: 12px; text-transform: uppercase; }
#equipment-section h2 { font-size: 42px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.25; margin-bottom: 18px; }
#equipment-section .equipment-text { color: #b9c3d7; font-size: 17px; margin-bottom: 34px; }
#equipment-section .equipment-list { display: grid; gap: 15px; }
#equipment-section .equipment-item { align-items: center; background: rgba(255, 255, 255, 0.07); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 20px; display: flex; gap: 16px; padding: 17px; transition: background 0.3s ease, transform 0.3s ease; }
#equipment-section .equipment-item:hover { background: rgba(255, 255, 255, 0.11); transform: translateX(6px); }
#equipment-section .equipment-icon { align-items: center; background: linear-gradient(135deg, #7c3cff, #00b7ff); border-radius: 16px; display: flex; flex: 0 0 auto; font-size: 19px; font-weight: 900; height: 46px; justify-content: center; width: 46px; }
#equipment-section .equipment-title { font-size: 18px; font-weight: 900; margin-bottom: 2px; }
#equipment-section .equipment-description { color: #c8d0df; font-size: 14px; }
#equipment-section .equipment-media { position: relative; }
#equipment-section .equipment-figure { background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 36px; overflow: hidden; padding: 16px; }
#equipment-section .equipment-image { border-radius: 26px; height: 520px; object-fit: cover; width: 100%; }
#equipment-section .equipment-float { animation: badge-float 5.2s ease-in-out infinite; background: #fff; border-radius: 24px; box-shadow: 0 24px 52px rgba(0, 0, 0, 0.22); color: #111827; left: -28px; padding: 18px; position: absolute; top: 44px; width: 232px; }
#equipment-section .equipment-float-title { font-size: 18px; font-weight: 900; margin-bottom: 7px; }
#equipment-section .equipment-float-text { color: #667085; font-size: 14px; }

#plan-section { background: #fff; padding: 106px 7%; }
#plan-section .plan-content { margin: 0 auto 52px; max-width: 820px; text-align: center; }
#plan-section .section-label { color: #7c3cff; font-size: 15px; font-weight: 900; letter-spacing: 0.16em; margin-bottom: 12px; text-transform: uppercase; }
#plan-section h2 { color: #101828; font-size: 42px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.25; margin-bottom: 18px; }
#plan-section .plan-text { color: #596174; font-size: 17px; }
#plan-section .plan-list { counter-reset: plan-counter; display: grid; gap: 20px; margin: 0 auto; max-width: 980px; }
#plan-section .plan-item { align-items: flex-start; background: linear-gradient(135deg, #ffffff, #f5f7ff); border: 1px solid rgba(24, 32, 51, 0.08); border-radius: 28px; box-shadow: 0 18px 44px rgba(30, 41, 59, 0.06); counter-increment: plan-counter; display: grid; gap: 20px; grid-template-columns: 90px 1fr; padding: 28px; position: relative; transition: border 0.3s ease, transform 0.3s ease; }
#plan-section .plan-item:hover { border-color: rgba(124, 60, 255, 0.28); transform: translateY(-5px); }
#plan-section .plan-number { align-items: center; background: #111827; border-radius: 22px; color: #fff; display: flex; font-size: 26px; font-weight: 900; height: 70px; justify-content: center; width: 70px; }
#plan-section .plan-number:before { content: "0" counter(plan-counter); }
#plan-section .plan-title { color: #182033; font-size: 22px; font-weight: 900; margin-bottom: 8px; }
#plan-section .plan-description { color: #667085; font-size: 15px; }

#faq-section { background: linear-gradient(135deg, #edf2ff, #ffffff); padding: 106px 7%; }
#faq-section .faq-grid { display: grid; gap: 56px; grid-template-columns: 0.82fr 1.18fr; margin: 0 auto; max-width: 1240px; }
#faq-section .section-label { color: #00a7d8; font-size: 15px; font-weight: 900; letter-spacing: 0.16em; margin-bottom: 12px; text-transform: uppercase; }
#faq-section h2 { color: #101828; font-size: 42px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.25; margin-bottom: 18px; }
#faq-section .faq-text { color: #596174; font-size: 17px; }
#faq-section .faq-list { display: grid; gap: 16px; }
#faq-section .faq-item { background: rgba(255, 255, 255, 0.78); border: 1px solid rgba(24, 32, 51, 0.08); border-radius: 24px; box-shadow: 0 18px 42px rgba(30, 41, 59, 0.06); padding: 24px; transition: border 0.3s ease, transform 0.3s ease; }
#faq-section .faq-item:hover { border-color: rgba(0, 183, 255, 0.28); transform: translateY(-4px); }
#faq-section .faq-title { color: #182033; font-size: 19px; font-weight: 900; margin-bottom: 8px; }
#faq-section .faq-description { color: #667085; font-size: 15px; }

#cta-section { background: #fff; padding: 106px 7%; }
#cta-section .cta-content { background: radial-gradient( circle at 12% 20%, rgba(255, 255, 255, 0.26), transparent 26% ), linear-gradient(135deg, #7c3cff, #00b7ff); border-radius: 42px; box-shadow: 0 28px 76px rgba(124, 60, 255, 0.24); color: #fff; margin: 0 auto; max-width: 1180px; overflow: hidden; padding: 66px 7%; position: relative; text-align: center; }
#cta-section .cta-content:after { background: rgba(255, 255, 255, 0.16); border-radius: 50%; bottom: -100px; content: ""; height: 260px; position: absolute; right: -80px; width: 260px; }
#cta-section h2 { font-size: 42px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.25; margin: 0 auto 18px; max-width: 780px; position: relative; z-index: 2; }
#cta-section .cta-text { color: rgba(255, 255, 255, 0.86); font-size: 17px; margin: 0 auto 30px; max-width: 720px; position: relative; z-index: 2; }
#cta-section .cta-link { background: #fff; border-radius: 999px; color: #6d35e8; display: inline-flex; font-size: 16px; font-weight: 900; padding: 14px 26px; position: relative; transition: box-shadow 0.3s ease, transform 0.3s ease; z-index: 2; }
#cta-section .cta-link:hover { box-shadow: 0 18px 42px rgba(17, 24, 39, 0.18); transform: translateY(-3px); }

footer { background: #0b1020; color: #d9e2f2; padding: 46px 7%; }
footer .footer-content { align-items: center; display: flex; gap: 24px; justify-content: space-between; margin: 0 auto; max-width: 1240px; }
footer .footer-title { color: #fff; font-size: 18px; font-weight: 900; margin-bottom: 6px; }
footer .footer-text { color: #9aa7bd; font-size: 14px; }
footer .footer-nav { display: flex; flex-wrap: wrap; gap: 18px; justify-content: flex-end; }
footer .footer-nav a { color: #b8c2d8; font-size: 14px; font-weight: 700; transition: color 0.3s ease; }
footer .footer-nav a:hover { color: #6ee7ff; }
.scroll-reveal { opacity: 0; transform: translateY(34px); transition: opacity 0.78s ease, transform 0.78s ease; }
.scroll-reveal.is-active { opacity: 1; transform: translateY(0); }

@keyframes badge-float { 0% { transform: translateY(0); } 50% { transform: translateY(-12px); } 100% { transform: translateY(0); } }

@media (max-width: 1280px) {
	header { padding: 16px 5%; }
	#hero-section { padding: 92px 5% 84px; }
	#hero-section h2 { font-size: 50px; }
	#platform-section { padding: 96px 5%; }
	#platform-section .platform-grid { grid-template-columns: repeat(2, 1fr); }
	#work-section { padding: 96px 5%; }
	#income-section { padding: 96px 5%; }
	#equipment-section { padding: 96px 5%; }
	#plan-section { padding: 96px 5%; }
	#faq-section { padding: 96px 5%; }
	#cta-section { padding: 96px 5%; }
	footer { padding: 44px 5%; }
}
@media (max-width: 960px) {
	header nav { display: none; }
	main { padding-top: 74px; }
	#hero-section .hero-grid { gap: 42px; grid-template-columns: 1fr; }
	#hero-section h2 { font-size: 46px; }
	#hero-section .hero-media { max-width: 640px; }
	#hero-section .hero-panel { left: 20px; }
	#hero-section .hero-badge { right: 18px; }
	#work-section .work-grid { gap: 44px; grid-template-columns: 1fr; }
	#work-section .work-card { right: 20px; }
	#income-section .income-grid { grid-template-columns: 1fr; }
	#equipment-section .equipment-grid { gap: 44px; grid-template-columns: 1fr; }
	#equipment-section .equipment-media { max-width: 640px; }
	#equipment-section .equipment-float { left: 20px; }
	#faq-section .faq-grid { gap: 36px; grid-template-columns: 1fr; }
	footer .footer-content { align-items: flex-start; flex-direction: column; }
	footer .footer-nav { justify-content: flex-start; }
}
@media (max-width: 768px) {
	header h1 { font-size: 17px; }
	header .header-action { display: none; }
	#hero-section { min-height: auto; padding: 72px 5% 66px; }
	#hero-section h2 { font-size: 38px; }
	#hero-section .hero-text { font-size: 16px; }
	#hero-section .hero-actions { align-items: stretch; flex-direction: column; }
	#hero-section .hero-primary { text-align: center; }
	#hero-section .hero-secondary { text-align: center; }
	#hero-section .hero-image { min-height: 360px; }
	#hero-section .hero-panel { position: relative; bottom: auto; left: auto; margin-top: 16px; width: 100%; }
	#hero-section .hero-badge { display: none; }
	#platform-section h2 { font-size: 34px; }
	#platform-section .platform-grid { grid-template-columns: 1fr; }
	#work-section h2 { font-size: 34px; }
	#work-section .work-image { height: 420px; }
	#work-section .work-card { position: relative; bottom: auto; margin-top: 16px; right: auto; width: 100%; }
	#income-section h2 { font-size: 34px; }
	#equipment-section h2 { font-size: 34px; }
	#equipment-section .equipment-image { height: 420px; }
	#equipment-section .equipment-float { position: relative; left: auto; margin-top: 16px; top: auto; width: 100%; }
	#plan-section h2 { font-size: 34px; }
	#plan-section .plan-item { grid-template-columns: 1fr; }
	#faq-section h2 { font-size: 34px; }
	#cta-section h2 { font-size: 34px; }
	#cta-section .cta-content { border-radius: 32px; padding: 54px 8%; }
}
@media (max-width: 500px) {
	header { padding: 14px 18px; }
	header .brand-mark { border-radius: 14px; height: 38px; width: 38px; }
	header h1 { font-size: 15px; }
	#hero-section { padding: 58px 18px 54px; }
	#hero-section h2 { font-size: 32px; }
	#hero-section .hero-kicker { font-size: 13px; }
	#hero-section .hero-item { border-radius: 18px; padding: 14px; }
	#hero-section .hero-figure { border-radius: 28px; padding: 10px; }
	#hero-section .hero-image { border-radius: 22px; min-height: 300px; }
	#platform-section { padding: 70px 18px; }
	#platform-section h2 { font-size: 29px; }
	#platform-section .platform-item { border-radius: 24px; padding: 20px; }
	#work-section { padding: 70px 18px; }
	#work-section h2 { font-size: 29px; }
	#work-section .work-image { height: 340px; }
	#work-section .work-item { gap: 14px; }
	#income-section { padding: 70px 18px; }
	#income-section h2 { font-size: 29px; }
	#income-section .income-item { border-radius: 24px; padding: 22px; }
	#equipment-section { padding: 70px 18px; }
	#equipment-section h2 { font-size: 29px; }
	#equipment-section .equipment-image { height: 340px; }
	#equipment-section .equipment-item { align-items: flex-start; }
	#plan-section { padding: 70px 18px; }
	#plan-section h2 { font-size: 29px; }
	#plan-section .plan-item { border-radius: 24px; padding: 22px; }
	#faq-section { padding: 70px 18px; }
	#faq-section h2 { font-size: 29px; }
	#cta-section { padding: 70px 18px; }
	#cta-section h2 { font-size: 29px; }
	footer { padding: 36px 18px; }
}