/* ============ FONTS ============ */
@font-face { font-family: '粒線體'; src: url('fonts/openlihsianti.woff2') format('woff2'); font-display: swap; unicode-range: U+0020, U+0022-0023, U+0027-002A, U+002D-0039, U+0040-005B, U+005D-007E, U+00D7, U+2014, U+2026, U+203B, U+2190-2193, U+2260, U+2460-2467, U+25C6, U+2640, U+3000-3002, U+3008-3011, U+30FB, U+4E00, U+4E03, U+4E08-4E0B, U+4E0D, U+4E16, U+4E1F, U+4E26, U+4E2D, U+4E32, U+4E3B, U+4E45, U+4E4B, U+4E5D, U+4E5F, U+4E7E, U+4E82, U+4E86, U+4E8B-4E8C, U+4E92, U+4E94, U+4E9B, U+4EA4, U+4EAB, U+4EAE, U+4EBA, U+4EC0, U+4ECA-4ECB, U+4ED6, U+4ED8, U+4EE3-4EE5, U+4EF0, U+4EF6, U+4EFB, U+4EFD, U+4F2F-4F30, U+4F34, U+4F38, U+4F46, U+4F48, U+4F4D-4F4F, U+4F55, U+4F5C, U+4F60, U+4F75, U+4F7F, U+4F86, U+4F8B, U+4F9D, U+4FBF, U+4FC2-4FC4, U+4FDD, U+4FE1, U+4FEE, U+500B, U+500D, U+5011, U+5019, U+503C, U+504F, U+505A, U+505C, U+5065, U+5074-5077, U+5099, U+50AC, U+50B3, U+50CF, U+50DA, U+50F9, U+5100, U+512A, U+5143, U+5145, U+5148-5149, U+514B, U+514D, U+5152, U+5165, U+5167-5169, U+516C-516D, U+5171, U+5176-5177, U+518D, U+5192, U+51A4, U+51B7, U+51FA, U+5206-5207, U+520A, U+5217, U+5224-5225, U+5229-522A, U+5230, U+5236-5237, U+523A-523B, U+5247, U+524D, U+525B, U+5269-526A, U+526F, U+5275, U+5283, U+5287, U+529B, U+529F-52A0, U+52A9, U+52C1, U+52C7, U+52D5, U+52D9, U+52DD-52DE, U+52E2, U+52F3, U+52FE, U+5305, U+5316-5317, U+532F, U+5339, U+5340-5341, U+5343, U+5347-5348, U+534A, U+5354, U+535A, U+5361, U+5373, U+537B, U+539F, U+53AD, U+53BB, U+53C3, U+53C8, U+53CA-53CB, U+53CD, U+53D6-53D7, U+53E3, U+53E5-53E6, U+53EA-53EC, U+53EF-53F0, U+53F2-53F3, U+53F8, U+5403-5404, U+5408, U+540C-540D, U+5411, U+542B, U+5435, U+5438, U+5448, U+544A, U+5462, U+5468, U+5473, U+547C-547D, U+548C, U+5496, U+54C1, U+54E1, U+54E5, U+54EA, U+54ED, U+54F2, U+552F, U+5546, U+554A, U+554F, U+555F, U+5561, U+5584, U+558A, U+5594, U+559A, U+559C, U+55AE, U+55CE, U+5662, U+5668, U+5695, U+56B4, U+56DB, U+56DE, U+56E0, U+56F0, U+56FA, U+570D, U+5713, U+5716, U+5718, U+5728, U+5730, U+5740, U+5747, U+574A, U+5751, U+5782, U+578B, U+57DF, U+57F7, U+57F9-57FA, U+5806, U+5831, U+5834, U+584A, U+5854, U+585E, U+586B, U+5883, U+589E, U+58D3, U+58DE, U+58EB, U+5916, U+591A, U+591C, U+5920, U+5925, U+5927, U+5929-592B, U+592E, U+5931, U+593E, U+594F, U+5957, U+5967, U+596E, U+5973, U+5979, U+597D, U+5982, U+59B3, U+59CB, U+5A92, U+5B50, U+5B54, U+5B57-5B58, U+5B63-5B64, U+5B78, U+5B83, U+5B88-5B89, U+5B8C, U+5B98, U+5B9A, U+5BA2-5BA4, U+5BAE, U+5BB6, U+5BB9, U+5BBF, U+5BC4, U+5BC6, U+5BDF, U+5BE6-5BE7, U+5BE9, U+5BEB, U+5C01, U+5C08, U+5C0A-5C0B, U+5C0D-5C0F, U+5C11, U+5C1A, U+5C31, U+5C3E, U+5C40, U+5C4F, U+5C55, U+5C64, U+5C6C, U+5C71, U+5CB8, U+5CF0, U+5D4C, U+5DE1, U+5DE5-5DE7, U+5DEE, U+5DF1-5DF2, U+5E02-5E03, U+5E0C, U+5E2B, U+5E2D, U+5E33, U+5E36, U+5E38, U+5E45, U+5E55, U+5E63, U+5E6B, U+5E73-5E74, U+5E7B, U+5E7E, U+5E8A, U+5E8F, U+5E95, U+5EA6, U+5EAB, U+5EB6-5EB7, U+5EF6, U+5EFA, U+5F0F, U+5F15, U+5F35, U+5F37, U+5F48, U+5F59, U+5F62, U+5F69, U+5F71, U+5F80, U+5F85, U+5F88, U+5F8B-5F8C, U+5F91, U+5F97, U+5F9E, U+5FA9-5FAA, U+5FAE, U+5FB7, U+5FBD, U+5FC3, U+5FC5, U+5FD7-5FD8, U+5FEB, U+5FF5, U+5FFD, U+600E, U+6012, U+601D, U+6027-6028, U+6046, U+6069, U+606F, U+6089, U+60C5, U+60F3, U+6109, U+610F, U+611B, U+611F, U+614B, U+6162-6163, U+6167, U+616E, U+618A, U+6191, U+61A4, U+61B6, U+61C2, U+61C7, U+61C9, U+61F7, U+6210-6211, U+6216, U+622A, U+6230, U+6232-6233, U+6236, U+6240-6241, U+624B, U+624D, U+6253, U+6258, U+626E, U+6279, U+627E-6280, U+6284, U+628A, U+6291-6293, U+6295-6297, U+62AC, U+62B1, U+62B5, U+62BD, U+62C6, U+62C9, U+62CD, U+62D2, U+62D6, U+62DB-62DC, U+62EC, U+62FC, U+62FE-62FF, U+6301, U+6307, U+6309, U+6311, U+6349, U+6355, U+6372, U+6383, U+6389, U+638C, U+6392, U+639B, U+63A1, U+63A5, U+63A8, U+63CF-63D0, U+63D2, U+63DA-63DB, U+63E1, U+63EE, U+63F4, U+640D, U+641C, U+641E, U+642C-642D, U+6458, U+6488, U+6495, U+64A4, U+64AD, U+64B0, U+64C7, U+64CA-64CB, U+64CD-64CE, U+64D4, U+64DA, U+64E0, U+64EC, U+64F4, U+64FE, U+6524, U+652F, U+6536, U+6539, U+653E-653F, U+6545, U+6548, U+6557-6559, U+6563, U+6574, U+6578, U+6582, U+6587, U+6599, U+659C, U+65AF-65B0, U+65B7, U+65B9, U+65BC, U+65C5, U+65CB, U+65D7, U+65E5-65E6, U+65E9, U+660E, U+6613, U+661F, U+6628, U+662F, U+6642, U+665A, U+6668, U+666F-6670, U+667A, U+6696-6697, U+66B1, U+66B4, U+66C6, U+66F4, U+66F8, U+66FF-6700, U+6703, U+6708-6709, U+670B, U+670D, U+6717, U+671B, U+671F, U+672A-672C, U+6750, U+675F, U+6771, U+677F, U+6789, U+6790, U+679C, U+67B6, U+67D0, U+67D3, U+67E5, U+6821, U+6838-6839, U+683C, U+6846, U+6848, U+684C, U+687F, U+689D, U+68E7, U+695A, U+696D, U+6975, U+69CB, U+69CD, U+69D3, U+6A02, U+6A0A, U+6A13, U+6A19, U+6A1E, U+6A21, U+6A23, U+6A39, U+6A58, U+6A5F, U+6A6B, U+6A94, U+6AA2, U+6B04, U+6B0A, U+6B21, U+6B3E, U+6B61-6B65, U+6B6A, U+6B77-6B78, U+6B7B, U+6B8A, U+6BB5, U+6BCD, U+6BCF, U+6BD2, U+6BD4, U+6BDB, U+6BEB, U+6C23, U+6C34, U+6C38, U+6C42, U+6C7A, U+6C88-6C89, U+6C92, U+6CC1, U+6CD5, U+6CE1-6CE2, U+6CE8, U+6D0B, U+6D1E, U+6D29, U+6D3B, U+6D3E, U+6D41, U+6D6A, U+6D77, U+6D88-6D89, U+6DAF, U+6DE1, U+6DE8, U+6DF1, U+6DF7, U+6DFA, U+6E05, U+6E1B, U+6E2C, U+6E32, U+6E90, U+6E96, U+6E9D, U+6EAB, U+6ED1, U+6EFE, U+6F02, U+6F0F, U+6F14, U+6F2C, U+6F38, U+6F54, U+6FC3, U+6FFE, U+700F, U+7063, U+7070, U+70BA, U+70C8, U+7121, U+7126, U+7136, U+7167, U+719F, U+71C8, U+71DF, U+7206, U+7236, U+723D-723E, U+7246-7248, U+724C, U+725B, U+7267, U+7269, U+7279, U+72AF, U+72C0, U+7336, U+734E, U+7368, U+7387, U+7389, U+738B, U+73A9, U+73ED, U+73FE, U+7403, U+7406, U+74B0, U+751A, U+751F, U+7522, U+7528, U+7530-7531, U+754C, U+7559, U+7565, U+756B, U+7570, U+7576, U+758A, U+7591, U+75B2, U+75DB, U+7626, U+767B-767E, U+7684, U+76AE, U+76E3-76E4, U+76EE, U+76F2, U+76F4, U+76F8, U+76FE, U+7701, U+770B, U+771F, U+773C, U+773E, U+7761, U+7763, U+77AD, U+77DB, U+77E5, U+77ED, U+7814, U+7838, U+786C, U+788E, U+789F, U+78BA, U+78BC, U+78DA, U+78E8, U+790E, U+793A, U+793E, U+795D, U+7968, U+7981, U+798F, U+79AA, U+79AE, U+79C1, U+79D2, U+79D8, U+79E9, U+79FB, U+7A00, U+7A05, U+7A0B, U+7A0D, U+7A2E, U+7A31, U+7A3F, U+7A4D, U+7A57, U+7A69, U+7A74, U+7A76, U+7A7A, U+7A7F, U+7A81, U+7A84, U+7A97, U+7AAE, U+7ACB, U+7AD9, U+7AE0, U+7AEF, U+7AF6, U+7B28, U+7B2C, U+7B46, U+7B49, U+7B54, U+7B56, U+7B97, U+7BA1, U+7BAD, U+7BB1, U+7BC0, U+7BC4, U+7BC7, U+7BE9, U+7C21, U+7C3D, U+7C3F, U+7C4C-7C4D, U+7C64, U+7C73, U+7C92, U+7C97, U+7CBE, U+7CCA, U+7CD6, U+7CFB, U+7D00, U+7D04-7D05, U+7D0B, U+7D0D, U+7D14, U+7D19-7D1A, U+7D20, U+7D22, U+7D2B, U+7D2F-7D30, U+7D39, U+7D42, U+7D44, U+7D50, U+7D55, U+7D66, U+7D71, U+7D81, U+7D93, U+7DA0, U+7DAD, U+7DB1-7DB2, U+7DB4, U+7DCA, U+7DD2, U+7DDA, U+7DE3, U+7DE8, U+7DF4, U+7DFB, U+7E2E, U+7E31, U+7E3D, U+7E41, U+7E54, U+7E5E, U+7E6A, U+7E7C, U+7E8C, U+7E96, U+7F3A, U+7F50, U+7F6E, U+7F72, U+7F75, U+7F8E, U+7FA4, U+7FA9, U+7FD2, U+7FF0, U+7FFB, U+8001, U+8003, U+8005, U+800C, U+8010, U+8017, U+804A, U+8056, U+8058, U+806F-8070, U+8072, U+8077, U+807D, U+80B2, U+80CC, U+80FD, U+8106, U+8108, U+8139, U+813E, U+8166, U+8173, U+8178, U+81A0, U+81A8, U+81C9, U+81E8, U+81EA, U+81F3-81F4, U+81FA, U+8207-8208, U+820C, U+822C, U+8239, U+8272, U+82B1, U+82E5-82E6, U+8349, U+8403, U+842C, U+8431, U+843D, U+8457, U+8490, U+84B8, U+84CB, U+85A6, U+85AA, U+85C9, U+85CD, U+85CF, U+85E5, U+8607, U+8655, U+865B, U+865F, U+8679, U+86C7, U+87A2, U+883B, U+884C, U+8853, U+885D, U+8868, U+888B, U+88AB, U+88DC-88DD, U+88E1, U+88FD, U+8907, U+897F, U+8981, U+8986, U+898B, U+898F, U+8996, U+89AA, U+89BA, U+89BD, U+89C0, U+89D2, U+89E3, U+89F8, U+8A00, U+8A02, U+8A08, U+8A0A, U+8A0E, U+8A13, U+8A18, U+8A23, U+8A2A, U+8A2D, U+8A34, U+8A3A-8A3B, U+8A55, U+8A5E, U+8A62, U+8A66, U+8A69, U+8A71-8A73, U+8A87, U+8A8C-8A8D, U+8A95, U+8A9E, U+8AA0, U+8AA4, U+8AAA, U+8AB0, U+8AB2, U+8ABF, U+8ACB, U+8AD6, U+8AEE, U+8AFE, U+8B1B, U+8B1D, U+8B49, U+8B58, U+8B5C, U+8B66, U+8B70, U+8B77, U+8B80, U+8B8A, U+8B93, U+8B9A, U+8C50, U+8C61, U+8C6B, U+8C8C, U+8CA0-8CA1, U+8CAB-8CAC, U+8CBB-8CBC, U+8CC7, U+8CE3, U+8CE6, U+8CEA, U+8D70, U+8D77, U+8D85, U+8D8A, U+8D9F, U+8DA3, U+8DA8, U+8DB3, U+8DD1, U+8DDF, U+8DE1, U+8DE8, U+8DEF, U+8DF3, U+8E29, U+8E64, U+8EAB, U+8EB2, U+8ECC, U+8EF8, U+8F03, U+8F09, U+8F15, U+8F29-8F2A, U+8F2F, U+8F38, U+8F49, U+8FA6, U+8FA8, U+8FCE, U+8FD1, U+8FED, U+8FF0, U+8FF7, U+8FFD, U+9001, U+9003, U+9006, U+900F-9010, U+9014, U+9019-901A, U+901F-9020, U+9023, U+9031-9032, U+903C, U+9047, U+904A-904B, U+904D-904E, U+9053-9054, U+9060, U+9069, U+9075, U+9078, U+907A, U+907F, U+9084, U+908A, U+908F, U+90A3, U+90A6, U+90E8, U+90FD, U+914D, U+9192, U+919C, U+91CB, U+91CD, U+91CF, U+91D1, U+9215, U+929C, U+92B7, U+92F8, U+9304, U+9322, U+932F, U+9336, U+9375, U+93E1, U+9418, U+9435, U+9577, U+9580, U+9583, U+9589, U+958B, U+9593, U+95B1, U+95C6, U+95DC, U+9632, U+963F, U+9644, U+964C-964D, U+9650, U+9662, U+9664, U+966A, U+9670, U+9678, U+967D, U+968A, U+968E, U+9694, U+969B, U+96A8, U+96AA, U+96B1, U+96C6, U+96D9, U+96DC, U+96E3, U+96EA, U+96F2, U+96F6, U+96FB, U+9700, U+9732, U+9748, U+975C, U+975E, U+9760, U+9762, U+97F3, U+97FF, U+9801-9802, U+9805-9806, U+9808, U+9810, U+9818, U+982D, U+983B, U+984C-984D, U+984F, U+9858, U+985E, U+9867, U+986F, U+98A8, U+98C4, U+98DF, U+98F2, U+98FE, U+990A, U+9918, U+9935, U+993E, U+994B, U+9996, U+99AC, U+9A45, U+9A57, U+9A5F, U+9AA8, U+9AD4, U+9AD8, U+9B06, U+9B42, U+9B54, U+9EBC, U+9EC3, U+9ED8, U+9EDE, U+9F20, U+9F4A, U+9F52, U+9F61, U+9F8D, U+FF01, U+FF08-FF09, U+FF0B-FF0C, U+FF0F, U+FF1A-FF1B, U+FF1D, U+FF1F, U+FF5C, U+FF5E; }
@font-face { font-family: '金萱9'; src: url('fonts/jinxuanlatte-heavy.woff2') format('woff2'); font-display: swap; unicode-range: U+0020-0023, U+0027-002A, U+002C-003A, U+0041-005B, U+005D-007E, U+00A9, U+00D7, U+2014, U+2026, U+203B, U+2190-2193, U+2212, U+2260, U+22EF, U+2460-2467, U+2500, U+2502, U+2514, U+251C, U+25C6, U+2640, U+3000-3002, U+3008-3011, U+30FB, U+4E00, U+4E03, U+4E08-4E0B, U+4E0D, U+4E16, U+4E1F, U+4E26, U+4E2D, U+4E32, U+4E3B, U+4E45, U+4E4B, U+4E5D, U+4E5F, U+4E7E, U+4E82, U+4E86, U+4E8B-4E8C, U+4E92, U+4E94, U+4E9B, U+4EA4, U+4EAB, U+4EAE, U+4EBA, U+4EC0, U+4ECA-4ECB, U+4ED6, U+4ED8, U+4EE3-4EE5, U+4EF0, U+4EF6, U+4EFB, U+4EFD, U+4F2F-4F30, U+4F34, U+4F38, U+4F46, U+4F48, U+4F4D-4F4F, U+4F55, U+4F5C, U+4F60, U+4F75, U+4F7F, U+4F86, U+4F8B, U+4F9D, U+4FBF, U+4FC2-4FC4, U+4FDD, U+4FE1, U+4FEE, U+500B, U+500D, U+5011, U+5019, U+503C, U+504F, U+505A, U+505C, U+5065, U+5074-5077, U+5099, U+50AC, U+50B3, U+50CF, U+50DA, U+50F9, U+5100, U+512A, U+5143, U+5145, U+5148-5149, U+514B, U+514D, U+5152, U+5165, U+5167-5169, U+516C-516D, U+5171, U+5176-5177, U+518D, U+5192, U+51A4, U+51B7, U+51FA, U+5206-5207, U+520A, U+5217, U+5224-5225, U+5229-522A, U+5230, U+5236-5237, U+523A-523B, U+5247, U+524D, U+525B, U+5269-526A, U+526F, U+5275, U+5283, U+5287, U+529B, U+529F-52A0, U+52A9, U+52C1, U+52C7, U+52D5, U+52D9, U+52DD-52DE, U+52E2, U+52F3, U+52FE, U+5305, U+5316-5317, U+532F, U+5339, U+5340-5341, U+5343, U+5347-5348, U+534A, U+5354, U+535A, U+5361, U+5373, U+537B, U+539F, U+53AD, U+53BB, U+53C3, U+53C8, U+53CA-53CB, U+53CD, U+53D6-53D7, U+53E3, U+53E5-53E6, U+53EA-53EC, U+53EF-53F0, U+53F2-53F3, U+53F8, U+5403-5404, U+5408, U+540C-540D, U+5411, U+542B, U+5435, U+5438, U+5448, U+544A, U+5462, U+5468, U+5473, U+547C-547D, U+548C, U+5496, U+54C1, U+54E1, U+54E5, U+54EA, U+54ED, U+54F2, U+552F, U+5546, U+554A, U+554F, U+555F, U+5561, U+5584, U+558A, U+5594, U+559A, U+559C, U+55AE, U+55CE, U+5662, U+5668, U+5695, U+56B4, U+56DB, U+56DE, U+56E0, U+56F0, U+56FA, U+570D, U+5713, U+5716, U+5718, U+5728, U+5730, U+5740, U+5747, U+574A, U+5751, U+5782, U+578B, U+57DF, U+57F7, U+57F9-57FA, U+5806, U+5831, U+5834, U+584A, U+5854, U+585E, U+586B, U+5883, U+589E, U+58D3, U+58DE, U+58EB, U+5916, U+591A, U+591C, U+5920, U+5925, U+5927, U+5929-592B, U+592E, U+5931, U+593E, U+594F, U+5957, U+5967, U+596E, U+5973, U+5979, U+597D, U+5982, U+59B3, U+59CB, U+5A92, U+5B50, U+5B54, U+5B57-5B58, U+5B63-5B64, U+5B78, U+5B83, U+5B88-5B89, U+5B8C, U+5B98, U+5B9A, U+5BA2-5BA4, U+5BAE, U+5BB6, U+5BB9, U+5BBF, U+5BC4, U+5BC6, U+5BDF, U+5BE6-5BE7, U+5BE9, U+5BEB, U+5C01, U+5C08, U+5C0A-5C0B, U+5C0D-5C0F, U+5C11, U+5C1A, U+5C31, U+5C3E, U+5C40, U+5C4F, U+5C55, U+5C64, U+5C6C, U+5C71, U+5CB8, U+5CF0, U+5D4C, U+5DE1, U+5DE5-5DE7, U+5DEE, U+5DF1-5DF2, U+5E02-5E03, U+5E0C, U+5E2B, U+5E2D, U+5E33, U+5E36, U+5E38, U+5E45, U+5E55, U+5E63, U+5E6B, U+5E73-5E74, U+5E7B, U+5E7E, U+5E8A, U+5E8F, U+5E95, U+5EA6, U+5EAB, U+5EB6-5EB7, U+5EF6, U+5EFA, U+5F0F, U+5F15, U+5F35, U+5F37, U+5F48, U+5F59, U+5F62, U+5F69, U+5F71, U+5F80, U+5F85, U+5F88, U+5F8B-5F8C, U+5F91, U+5F97, U+5F9E, U+5FA9-5FAA, U+5FAE, U+5FB7, U+5FBD, U+5FC3, U+5FC5, U+5FD7-5FD8, U+5FEB, U+5FF5, U+5FFD, U+600E, U+6012, U+601D, U+6027-6028, U+6046, U+6069, U+606F, U+6089, U+60C5, U+60F3, U+6109, U+610F, U+611B, U+611F, U+614B, U+6162-6163, U+6167, U+616E, U+618A, U+6191, U+61A4, U+61B6, U+61C2, U+61C7, U+61C9, U+61F7, U+6210-6211, U+6216, U+622A, U+6230, U+6232-6233, U+6236, U+6240-6241, U+624B, U+624D, U+6253, U+6258, U+626E, U+6279, U+627E-6280, U+6284, U+628A, U+6291-6293, U+6295-6297, U+62AC, U+62B1, U+62B5, U+62BD, U+62C6, U+62C9, U+62CD, U+62D2, U+62D6, U+62DB-62DC, U+62EC, U+62FC, U+62FE-62FF, U+6301, U+6307, U+6309, U+6311, U+6349, U+6355, U+6372, U+6383, U+6389, U+638C, U+6392, U+639B, U+63A1, U+63A5, U+63A8, U+63CF-63D0, U+63D2, U+63DA-63DB, U+63E1, U+63EE, U+63F4, U+640D, U+641C, U+641E, U+642C-642D, U+6458, U+6488, U+6495, U+64A4, U+64AD, U+64B0, U+64C7, U+64CA-64CB, U+64CD-64CE, U+64D4, U+64DA, U+64E0, U+64EC, U+64F4, U+64FE, U+6524, U+652F, U+6536, U+6539, U+653E-653F, U+6545, U+6548, U+6557-6559, U+6563, U+6574, U+6578, U+6582, U+6587, U+6599, U+659C, U+65AF-65B0, U+65B7, U+65B9, U+65BC, U+65C5, U+65CB, U+65D7, U+65E5-65E6, U+65E9, U+660E, U+6613, U+661F, U+6628, U+662F, U+6642, U+665A, U+6668, U+666F-6670, U+667A, U+6696-6697, U+66B1, U+66B4, U+66C6, U+66F4, U+66F8, U+66FF-6700, U+6703, U+6708-6709, U+670B, U+670D, U+6717, U+671B, U+671F, U+672A-672C, U+6750, U+675F, U+6771, U+677F, U+6789, U+6790, U+679C, U+67B6, U+67D0, U+67D3, U+67E5, U+6821, U+6838-6839, U+683C, U+6846, U+6848, U+684C, U+687F, U+689D, U+68E7, U+695A, U+696D, U+6975, U+69CB, U+69CD, U+69D3, U+6A02, U+6A0A, U+6A13, U+6A19, U+6A1E, U+6A21, U+6A23, U+6A39, U+6A58, U+6A5F, U+6A6B, U+6A94, U+6AA2, U+6B04, U+6B0A, U+6B21, U+6B3E, U+6B61-6B65, U+6B6A, U+6B77-6B78, U+6B7B, U+6B8A, U+6BB5, U+6BCD, U+6BCF, U+6BD2, U+6BD4, U+6BDB, U+6BEB, U+6C23, U+6C34, U+6C38, U+6C42, U+6C7A, U+6C88-6C89, U+6C92, U+6CC1, U+6CD5, U+6CE1-6CE2, U+6CE8, U+6D0B, U+6D1E, U+6D29, U+6D3B, U+6D3E, U+6D41, U+6D6A, U+6D77, U+6D88-6D89, U+6DAF, U+6DE1, U+6DE8, U+6DF1, U+6DF7, U+6DFA, U+6E05, U+6E1B, U+6E2C, U+6E32, U+6E90, U+6E96, U+6E9D, U+6EAB, U+6ED1, U+6EFE, U+6F02, U+6F0F, U+6F14, U+6F2C, U+6F38, U+6F54, U+6FC3, U+6FFE, U+700F, U+7063, U+7070, U+70BA, U+70C8, U+7121, U+7126, U+7136, U+7167, U+719F, U+71C8, U+71DF, U+7206, U+7236, U+723D-723E, U+7246-7248, U+724C, U+725B, U+7267, U+7269, U+7279, U+72AF, U+72C0, U+7336, U+734E, U+7368, U+7387, U+7389, U+738B, U+73A9, U+73ED, U+73FE, U+7403, U+7406, U+74B0, U+751A, U+751F, U+7522, U+7528, U+7530-7531, U+754C, U+7559, U+7565, U+756B, U+7570, U+7576, U+758A, U+7591, U+75B2, U+75DB, U+7626, U+767B-767E, U+7684, U+76AE, U+76E3-76E4, U+76EE, U+76F2, U+76F4, U+76F8, U+76FE, U+7701, U+770B, U+771F, U+773C, U+773E, U+7761, U+7763, U+77AD, U+77DB, U+77E5, U+77ED, U+7814, U+7838, U+786C, U+788E, U+789F, U+78BA, U+78BC, U+78DA, U+78E8, U+790E, U+793A, U+793E, U+795D, U+7968, U+7981, U+798F, U+79AA, U+79AE, U+79C1, U+79D2, U+79D8, U+79E9, U+79FB, U+7A00, U+7A05, U+7A0B, U+7A0D, U+7A2E, U+7A31, U+7A3F, U+7A4D, U+7A57, U+7A69, U+7A74, U+7A76, U+7A7A, U+7A7F, U+7A81, U+7A84, U+7A97, U+7AAE, U+7ACB, U+7AD9, U+7AE0, U+7AEF, U+7AF6, U+7B28, U+7B2C, U+7B46, U+7B49, U+7B54, U+7B56, U+7B97, U+7BA1, U+7BAD, U+7BB1, U+7BC0, U+7BC4, U+7BC7, U+7BE9, U+7C21, U+7C3D, U+7C3F, U+7C4C-7C4D, U+7C64, U+7C73, U+7C92, U+7C97, U+7CBE, U+7CCA, U+7CD6, U+7CFB, U+7D00, U+7D04-7D05, U+7D0B, U+7D0D, U+7D14, U+7D19-7D1A, U+7D20, U+7D22, U+7D2B, U+7D2F-7D30, U+7D39, U+7D42, U+7D44, U+7D50, U+7D55, U+7D66, U+7D71, U+7D81, U+7D93, U+7DA0, U+7DAD, U+7DB1-7DB2, U+7DB4, U+7DCA, U+7DD2, U+7DDA, U+7DE3, U+7DE8, U+7DF4, U+7DFB, U+7E2E, U+7E31, U+7E3D, U+7E41, U+7E54, U+7E5E, U+7E6A, U+7E7C, U+7E8C, U+7E96, U+7F3A, U+7F50, U+7F6E, U+7F72, U+7F75, U+7F8E, U+7FA4, U+7FA9, U+7FD2, U+7FF0, U+7FFB, U+8001, U+8003, U+8005, U+800C, U+8010, U+8017, U+804A, U+8056, U+8058, U+806F-8070, U+8072, U+8077, U+807D, U+80B2, U+80CC, U+80FD, U+8106, U+8108, U+8139, U+813E, U+8166, U+8173, U+8178, U+81A0, U+81A8, U+81C9, U+81E8, U+81EA, U+81F3-81F4, U+81FA, U+8207-8208, U+820C, U+822C, U+8239, U+8272, U+82B1, U+82E5-82E6, U+8349, U+8403, U+842C, U+8431, U+843D, U+8457, U+8490, U+84B8, U+84CB, U+85A6, U+85AA, U+85C9, U+85CD, U+85CF, U+85E5, U+8607, U+8655, U+865B, U+865F, U+8679, U+86C7, U+87A2, U+883B, U+884C, U+8853, U+885D, U+8868, U+888B, U+88AB, U+88DC-88DD, U+88E1, U+88FD, U+8907, U+897F, U+8981, U+8986, U+898B, U+898F, U+8996, U+89AA, U+89BA, U+89BD, U+89C0, U+89D2, U+89E3, U+89F8, U+8A00, U+8A02, U+8A08, U+8A0A, U+8A0E, U+8A13, U+8A18, U+8A23, U+8A2A, U+8A2D, U+8A34, U+8A3A-8A3B, U+8A55, U+8A5E, U+8A62, U+8A66, U+8A69, U+8A71-8A73, U+8A87, U+8A8C-8A8D, U+8A95, U+8A9E, U+8AA0, U+8AA4, U+8AAA, U+8AB0, U+8AB2, U+8ABF, U+8ACB, U+8AD6, U+8AEE, U+8AFE, U+8B1B, U+8B1D, U+8B49, U+8B58, U+8B5C, U+8B66, U+8B70, U+8B77, U+8B80, U+8B8A, U+8B93, U+8B9A, U+8C50, U+8C61, U+8C6B, U+8C8C, U+8CA0-8CA1, U+8CAB-8CAC, U+8CBB-8CBC, U+8CC7, U+8CE3, U+8CE6, U+8CEA, U+8D70, U+8D77, U+8D85, U+8D8A, U+8D9F, U+8DA3, U+8DA8, U+8DB3, U+8DD1, U+8DDF, U+8DE1, U+8DE8, U+8DEF, U+8DF3, U+8E29, U+8E64, U+8EAB, U+8EB2, U+8ECC, U+8EF8, U+8F03, U+8F09, U+8F15, U+8F29-8F2A, U+8F2F, U+8F38, U+8F49, U+8FA6, U+8FA8, U+8FCE, U+8FD1, U+8FED, U+8FF0, U+8FF7, U+8FFD, U+9001, U+9003, U+9006, U+900F-9010, U+9014, U+9019-901A, U+901F-9020, U+9023, U+9031-9032, U+903C, U+9047, U+904A-904B, U+904D-904E, U+9053-9054, U+9060, U+9069, U+9075, U+9078, U+907A, U+907F, U+9084, U+908A, U+908F, U+90A3, U+90A6, U+90E8, U+90FD, U+914D, U+9192, U+919C, U+91CB, U+91CD, U+91CF, U+91D1, U+9215, U+929C, U+92B7, U+92F8, U+9304, U+9322, U+932F, U+9336, U+9375, U+93E1, U+9418, U+9435, U+9577, U+9580, U+9583, U+9589, U+958B, U+9593, U+95B1, U+95C6, U+95DC, U+9632, U+963F, U+9644, U+964C-964D, U+9650, U+9662, U+9664, U+966A, U+9670, U+9678, U+967D, U+968A, U+968E, U+9694, U+969B, U+96A8, U+96AA, U+96B1, U+96C6, U+96D9, U+96DC, U+96E3, U+96EA, U+96F2, U+96F6, U+96FB, U+9700, U+9732, U+9748, U+975C, U+975E, U+9760, U+9762, U+97F3, U+97FF, U+9801-9802, U+9805-9806, U+9808, U+9810, U+9818, U+982D, U+983B, U+984C-984D, U+984F, U+9858, U+985E, U+9867, U+986F, U+98A8, U+98C4, U+98DF, U+98F2, U+98FE, U+990A, U+9918, U+9935, U+993E, U+994B, U+9996, U+99AC, U+9A45, U+9A57, U+9A5F, U+9AA8, U+9AD4, U+9AD8, U+9B06, U+9B42, U+9B54, U+9EBC, U+9EC3, U+9ED8, U+9EDE, U+9F20, U+9F4A, U+9F52, U+9F61, U+9F8D, U+FF01, U+FF08-FF09, U+FF0B-FF0C, U+FF0F, U+FF1A-FF1B, U+FF1D, U+FF1F, U+FF5C, U+FF5E; }
@font-face { font-family: '金萱3'; src: url('fonts/jinxuanlatte-regular.woff2') format('woff2'); font-display: swap; unicode-range: U+0020-0023, U+0027-002A, U+002C-003A, U+0041-005B, U+005D-007E, U+00A9, U+00D7, U+2014, U+2026, U+203B, U+2190-2193, U+2212, U+2260, U+22EF, U+2460-2467, U+2500, U+2502, U+2514, U+251C, U+25C6, U+2640, U+3000-3002, U+3008-3011, U+30FB, U+4E00, U+4E03, U+4E08-4E0B, U+4E0D, U+4E16, U+4E1F, U+4E26, U+4E2D, U+4E32, U+4E3B, U+4E45, U+4E4B, U+4E5D, U+4E5F, U+4E7E, U+4E82, U+4E86, U+4E8B-4E8C, U+4E92, U+4E94, U+4E9B, U+4EA4, U+4EAB, U+4EAE, U+4EBA, U+4EC0, U+4ECA-4ECB, U+4ED6, U+4ED8, U+4EE3-4EE5, U+4EF0, U+4EF6, U+4EFB, U+4EFD, U+4F2F-4F30, U+4F34, U+4F38, U+4F46, U+4F48, U+4F4D-4F4F, U+4F55, U+4F5C, U+4F60, U+4F75, U+4F7F, U+4F86, U+4F8B, U+4F9D, U+4FBF, U+4FC2-4FC4, U+4FDD, U+4FE1, U+4FEE, U+500B, U+500D, U+5011, U+5019, U+503C, U+504F, U+505A, U+505C, U+5065, U+5074-5077, U+5099, U+50AC, U+50B3, U+50CF, U+50DA, U+50F9, U+5100, U+512A, U+5143, U+5145, U+5148-5149, U+514B, U+514D, U+5152, U+5165, U+5167-5169, U+516C-516D, U+5171, U+5176-5177, U+518D, U+5192, U+51A4, U+51B7, U+51FA, U+5206-5207, U+520A, U+5217, U+5224-5225, U+5229-522A, U+5230, U+5236-5237, U+523A-523B, U+5247, U+524D, U+525B, U+5269-526A, U+526F, U+5275, U+5283, U+5287, U+529B, U+529F-52A0, U+52A9, U+52C1, U+52C7, U+52D5, U+52D9, U+52DD-52DE, U+52E2, U+52F3, U+52FE, U+5305, U+5316-5317, U+532F, U+5339, U+5340-5341, U+5343, U+5347-5348, U+534A, U+5354, U+535A, U+5361, U+5373, U+537B, U+539F, U+53AD, U+53BB, U+53C3, U+53C8, U+53CA-53CB, U+53CD, U+53D6-53D7, U+53E3, U+53E5-53E6, U+53EA-53EC, U+53EF-53F0, U+53F2-53F3, U+53F8, U+5403-5404, U+5408, U+540C-540D, U+5411, U+542B, U+5435, U+5438, U+5448, U+544A, U+5462, U+5468, U+5473, U+547C-547D, U+548C, U+5496, U+54C1, U+54E1, U+54E5, U+54EA, U+54ED, U+54F2, U+552F, U+5546, U+554A, U+554F, U+555F, U+5561, U+5584, U+558A, U+5594, U+559A, U+559C, U+55AE, U+55CE, U+5662, U+5668, U+5695, U+56B4, U+56DB, U+56DE, U+56E0, U+56F0, U+56FA, U+570D, U+5713, U+5716, U+5718, U+5728, U+5730, U+5740, U+5747, U+574A, U+5751, U+5782, U+578B, U+57DF, U+57F7, U+57F9-57FA, U+5806, U+5831, U+5834, U+584A, U+5854, U+585E, U+586B, U+5883, U+589E, U+58D3, U+58DE, U+58EB, U+5916, U+591A, U+591C, U+5920, U+5925, U+5927, U+5929-592B, U+592E, U+5931, U+593E, U+594F, U+5957, U+5967, U+596E, U+5973, U+5979, U+597D, U+5982, U+59B3, U+59CB, U+5A92, U+5B50, U+5B54, U+5B57-5B58, U+5B63-5B64, U+5B78, U+5B83, U+5B88-5B89, U+5B8C, U+5B98, U+5B9A, U+5BA2-5BA4, U+5BAE, U+5BB6, U+5BB9, U+5BBF, U+5BC4, U+5BC6, U+5BDF, U+5BE6-5BE7, U+5BE9, U+5BEB, U+5C01, U+5C08, U+5C0A-5C0B, U+5C0D-5C0F, U+5C11, U+5C1A, U+5C31, U+5C3E, U+5C40, U+5C4F, U+5C55, U+5C64, U+5C6C, U+5C71, U+5CB8, U+5CF0, U+5D4C, U+5DE1, U+5DE5-5DE7, U+5DEE, U+5DF1-5DF2, U+5E02-5E03, U+5E0C, U+5E2B, U+5E2D, U+5E33, U+5E36, U+5E38, U+5E45, U+5E55, U+5E63, U+5E6B, U+5E73-5E74, U+5E7B, U+5E7E, U+5E8A, U+5E8F, U+5E95, U+5EA6, U+5EAB, U+5EB6-5EB7, U+5EF6, U+5EFA, U+5F0F, U+5F15, U+5F35, U+5F37, U+5F48, U+5F59, U+5F62, U+5F69, U+5F71, U+5F80, U+5F85, U+5F88, U+5F8B-5F8C, U+5F91, U+5F97, U+5F9E, U+5FA9-5FAA, U+5FAE, U+5FB7, U+5FBD, U+5FC3, U+5FC5, U+5FD7-5FD8, U+5FEB, U+5FF5, U+5FFD, U+600E, U+6012, U+601D, U+6027-6028, U+6046, U+6069, U+606F, U+6089, U+60C5, U+60F3, U+6109, U+610F, U+611B, U+611F, U+614B, U+6162-6163, U+6167, U+616E, U+618A, U+6191, U+61A4, U+61B6, U+61C2, U+61C7, U+61C9, U+61F7, U+6210-6211, U+6216, U+622A, U+6230, U+6232-6233, U+6236, U+6240-6241, U+624B, U+624D, U+6253, U+6258, U+626E, U+6279, U+627E-6280, U+6284, U+628A, U+6291-6293, U+6295-6297, U+62AC, U+62B1, U+62B5, U+62BD, U+62C6, U+62C9, U+62CD, U+62D2, U+62D6, U+62DB-62DC, U+62EC, U+62FC, U+62FE-62FF, U+6301, U+6307, U+6309, U+6311, U+6349, U+6355, U+6372, U+6383, U+6389, U+638C, U+6392, U+639B, U+63A1, U+63A5, U+63A8, U+63CF-63D0, U+63D2, U+63DA-63DB, U+63E1, U+63EE, U+63F4, U+640D, U+641C, U+641E, U+642C-642D, U+6458, U+6488, U+6495, U+64A4, U+64AD, U+64B0, U+64C7, U+64CA-64CB, U+64CD-64CE, U+64D4, U+64DA, U+64E0, U+64EC, U+64F4, U+64FE, U+6524, U+652F, U+6536, U+6539, U+653E-653F, U+6545, U+6548, U+6557-6559, U+6563, U+6574, U+6578, U+6582, U+6587, U+6599, U+659C, U+65AF-65B0, U+65B7, U+65B9, U+65BC, U+65C5, U+65CB, U+65D7, U+65E5-65E6, U+65E9, U+660E, U+6613, U+661F, U+6628, U+662F, U+6642, U+665A, U+6668, U+666F-6670, U+667A, U+6696-6697, U+66B1, U+66B4, U+66C6, U+66F4, U+66F8, U+66FF-6700, U+6703, U+6708-6709, U+670B, U+670D, U+6717, U+671B, U+671F, U+672A-672C, U+6750, U+675F, U+6771, U+677F, U+6789, U+6790, U+679C, U+67B6, U+67D0, U+67D3, U+67E5, U+6821, U+6838-6839, U+683C, U+6846, U+6848, U+684C, U+687F, U+689D, U+68E7, U+695A, U+696D, U+6975, U+69CB, U+69CD, U+69D3, U+6A02, U+6A0A, U+6A13, U+6A19, U+6A1E, U+6A21, U+6A23, U+6A39, U+6A58, U+6A5F, U+6A6B, U+6A94, U+6AA2, U+6B04, U+6B0A, U+6B21, U+6B3E, U+6B61-6B65, U+6B6A, U+6B77-6B78, U+6B7B, U+6B8A, U+6BB5, U+6BCD, U+6BCF, U+6BD2, U+6BD4, U+6BDB, U+6BEB, U+6C23, U+6C34, U+6C38, U+6C42, U+6C7A, U+6C88-6C89, U+6C92, U+6CC1, U+6CD5, U+6CE1-6CE2, U+6CE8, U+6D0B, U+6D1E, U+6D29, U+6D3B, U+6D3E, U+6D41, U+6D6A, U+6D77, U+6D88-6D89, U+6DAF, U+6DE1, U+6DE8, U+6DF1, U+6DF7, U+6DFA, U+6E05, U+6E1B, U+6E2C, U+6E32, U+6E90, U+6E96, U+6E9D, U+6EAB, U+6ED1, U+6EFE, U+6F02, U+6F0F, U+6F14, U+6F2C, U+6F38, U+6F54, U+6FC3, U+6FFE, U+700F, U+7063, U+7070, U+70BA, U+70C8, U+7121, U+7126, U+7136, U+7167, U+719F, U+71C8, U+71DF, U+7206, U+7236, U+723D-723E, U+7246-7248, U+724C, U+725B, U+7267, U+7269, U+7279, U+72AF, U+72C0, U+7336, U+734E, U+7368, U+7387, U+7389, U+738B, U+73A9, U+73ED, U+73FE, U+7403, U+7406, U+74B0, U+751A, U+751F, U+7522, U+7528, U+7530-7531, U+754C, U+7559, U+7565, U+756B, U+7570, U+7576, U+758A, U+7591, U+75B2, U+75DB, U+7626, U+767B-767E, U+7684, U+76AE, U+76E3-76E4, U+76EE, U+76F2, U+76F4, U+76F8, U+76FE, U+7701, U+770B, U+771F, U+773C, U+773E, U+7761, U+7763, U+77AD, U+77DB, U+77E5, U+77ED, U+7814, U+7838, U+786C, U+788E, U+789F, U+78BA, U+78BC, U+78DA, U+78E8, U+790E, U+793A, U+793E, U+795D, U+7968, U+7981, U+798F, U+79AA, U+79AE, U+79C1, U+79D2, U+79D8, U+79E9, U+79FB, U+7A00, U+7A05, U+7A0B, U+7A0D, U+7A2E, U+7A31, U+7A3F, U+7A4D, U+7A57, U+7A69, U+7A74, U+7A76, U+7A7A, U+7A7F, U+7A81, U+7A84, U+7A97, U+7AAE, U+7ACB, U+7AD9, U+7AE0, U+7AEF, U+7AF6, U+7B28, U+7B2C, U+7B46, U+7B49, U+7B54, U+7B56, U+7B97, U+7BA1, U+7BAD, U+7BB1, U+7BC0, U+7BC4, U+7BC7, U+7BE9, U+7C21, U+7C3D, U+7C3F, U+7C4C-7C4D, U+7C64, U+7C73, U+7C92, U+7C97, U+7CBE, U+7CCA, U+7CD6, U+7CFB, U+7D00, U+7D04-7D05, U+7D0B, U+7D0D, U+7D14, U+7D19-7D1A, U+7D20, U+7D22, U+7D2B, U+7D2F-7D30, U+7D39, U+7D42, U+7D44, U+7D50, U+7D55, U+7D66, U+7D71, U+7D81, U+7D93, U+7DA0, U+7DAD, U+7DB1-7DB2, U+7DB4, U+7DCA, U+7DD2, U+7DDA, U+7DE3, U+7DE8, U+7DF4, U+7DFB, U+7E2E, U+7E31, U+7E3D, U+7E41, U+7E54, U+7E5E, U+7E6A, U+7E7C, U+7E8C, U+7E96, U+7F3A, U+7F50, U+7F6E, U+7F72, U+7F75, U+7F8E, U+7FA4, U+7FA9, U+7FD2, U+7FF0, U+7FFB, U+8001, U+8003, U+8005, U+800C, U+8010, U+8017, U+804A, U+8056, U+8058, U+806F-8070, U+8072, U+8077, U+807D, U+80B2, U+80CC, U+80FD, U+8106, U+8108, U+8139, U+813E, U+8166, U+8173, U+8178, U+81A0, U+81A8, U+81C9, U+81E8, U+81EA, U+81F3-81F4, U+81FA, U+8207-8208, U+820C, U+822C, U+8239, U+8272, U+82B1, U+82E5-82E6, U+8349, U+8403, U+842C, U+8431, U+843D, U+8457, U+8490, U+84B8, U+84CB, U+85A6, U+85AA, U+85C9, U+85CD, U+85CF, U+85E5, U+8607, U+8655, U+865B, U+865F, U+8679, U+86C7, U+87A2, U+883B, U+884C, U+8853, U+885D, U+8868, U+888B, U+88AB, U+88DC-88DD, U+88E1, U+88FD, U+8907, U+897F, U+8981, U+8986, U+898B, U+898F, U+8996, U+89AA, U+89BA, U+89BD, U+89C0, U+89D2, U+89E3, U+89F8, U+8A00, U+8A02, U+8A08, U+8A0A, U+8A0E, U+8A13, U+8A18, U+8A23, U+8A2A, U+8A2D, U+8A34, U+8A3A-8A3B, U+8A55, U+8A5E, U+8A62, U+8A66, U+8A69, U+8A71-8A73, U+8A87, U+8A8C-8A8D, U+8A95, U+8A9E, U+8AA0, U+8AA4, U+8AAA, U+8AB0, U+8AB2, U+8ABF, U+8ACB, U+8AD6, U+8AEE, U+8AFE, U+8B1B, U+8B1D, U+8B49, U+8B58, U+8B5C, U+8B66, U+8B70, U+8B77, U+8B80, U+8B8A, U+8B93, U+8B9A, U+8C50, U+8C61, U+8C6B, U+8C8C, U+8CA0-8CA1, U+8CAB-8CAC, U+8CBB-8CBC, U+8CC7, U+8CE3, U+8CE6, U+8CEA, U+8D70, U+8D77, U+8D85, U+8D8A, U+8D9F, U+8DA3, U+8DA8, U+8DB3, U+8DD1, U+8DDF, U+8DE1, U+8DE8, U+8DEF, U+8DF3, U+8E29, U+8E64, U+8EAB, U+8EB2, U+8ECC, U+8EF8, U+8F03, U+8F09, U+8F15, U+8F29-8F2A, U+8F2F, U+8F38, U+8F49, U+8FA6, U+8FA8, U+8FCE, U+8FD1, U+8FED, U+8FF0, U+8FF7, U+8FFD, U+9001, U+9003, U+9006, U+900F-9010, U+9014, U+9019-901A, U+901F-9020, U+9023, U+9031-9032, U+903C, U+9047, U+904A-904B, U+904D-904E, U+9053-9054, U+9060, U+9069, U+9075, U+9078, U+907A, U+907F, U+9084, U+908A, U+908F, U+90A3, U+90A6, U+90E8, U+90FD, U+914D, U+9192, U+919C, U+91CB, U+91CD, U+91CF, U+91D1, U+9215, U+929C, U+92B7, U+92F8, U+9304, U+9322, U+932F, U+9336, U+9375, U+93E1, U+9418, U+9435, U+9577, U+9580, U+9583, U+9589, U+958B, U+9593, U+95B1, U+95C6, U+95DC, U+9632, U+963F, U+9644, U+964C-964D, U+9650, U+9662, U+9664, U+966A, U+9670, U+9678, U+967D, U+968A, U+968E, U+9694, U+969B, U+96A8, U+96AA, U+96B1, U+96C6, U+96D9, U+96DC, U+96E3, U+96EA, U+96F2, U+96F6, U+96FB, U+9700, U+9732, U+9748, U+975C, U+975E, U+9760, U+9762, U+97F3, U+97FF, U+9801-9802, U+9805-9806, U+9808, U+9810, U+9818, U+982D, U+983B, U+984C-984D, U+984F, U+9858, U+985E, U+9867, U+986F, U+98A8, U+98C4, U+98DF, U+98F2, U+98FE, U+990A, U+9918, U+9935, U+993E, U+994B, U+9996, U+99AC, U+9A45, U+9A57, U+9A5F, U+9AA8, U+9AD4, U+9AD8, U+9B06, U+9B42, U+9B54, U+9EBC, U+9EC3, U+9ED8, U+9EDE, U+9F20, U+9F4A, U+9F52, U+9F61, U+9F8D, U+FF01, U+FF08-FF09, U+FF0B-FF0C, U+FF0F, U+FF1A-FF1B, U+FF1D, U+FF1F, U+FF5C, U+FF5E; }

/* ============ TOKENS ============ */
:root {
  --brand-red: #d14b63;
  --brand-red-dark: #b93a50;
  --brand-purple: #4C458A;
  --brand-yellow: #FFF3CD;
  --brand-yellow-deep: #FFE89B;
  --brand-yellow-edge: #F5A623;
  --brand-green: #52B788;
  --brand-peach: #F4B79C;
  --paper: #FAF6EE;
  --paper-deep: #F2EDE0;
  --note-yellow: #FFF6C9;
  --note-peach: #FAE4D4;
  --note-mint: #D6EBD6;
  --kraft: #D4B68A;
  --ink: #4a3c34;
  --ink-deep: #2c2730;
  --muted: #8a7f8c;
  --line-blue: rgba(120,160,180,0.24);
  --line-red: rgba(209,75,99,0.3);
  --hole: #d5ccc0;
  --outer-bg: #E8DFC9;

  /* 紙張陰影系統（通用） */
  --shadow-paper:
    1px 2px 3px rgba(0,0,0,0.08),
    3px 5px 12px rgba(0,0,0,0.10),
    6px 12px 28px rgba(0,0,0,0.08);
  --shadow-paper-lg:
    2px 3px 5px rgba(0,0,0,0.10),
    5px 9px 20px rgba(0,0,0,0.14),
    10px 18px 40px rgba(0,0,0,0.10);
  --shadow-paper-xl:
    2px 3px 6px rgba(0,0,0,0.12),
    8px 14px 28px rgba(0,0,0,0.18),
    16px 24px 48px rgba(0,0,0,0.12);

  /* ========= TOOL COLOR PALETTE ========= */
  --t-claude:#CC785C;       --t-claude-bg:#F5DDD0;
  --t-obsidian:#7C3AED;     --t-obsidian-bg:#E3D5F7;
  --t-heptabase:#5D8B4C;    --t-heptabase-bg:#D4E4CC;
  --t-notion:#37352F;       --t-notion-bg:#E1DED6;
  --t-wordpress:#21759B;    --t-wordpress-bg:#CFE4F1;
  --t-systeme:#4BA3C7;      --t-systeme-bg:#D3E9F1;
  --t-gmail:#EA4335;        --t-gmail-bg:#F6D4D0;
  --t-gcal:#4285F4;         --t-gcal-bg:#D3DFF8;
  --t-ga:#E37400;           --t-ga-bg:#F5D9B6;
  --t-notebooklm:#4F6BED;   --t-notebooklm-bg:#D4DAF7;
  --t-discord:#5865F2;      --t-discord-bg:#D5D8F8;
  --t-threads:#2c2730;      --t-threads-bg:#D9D9D9;
  --t-ig:#E1306C;           --t-ig-bg:#F6D3E1;
  --t-line:#06C755;         --t-line-bg:#C8EDCF;
  --t-wechat:#07C160;       --t-wechat-bg:#C8EDD1;
  --t-zeabur:#6E2AEB;       --t-zeabur-bg:#DAC9F5;
  --t-mac:#555;             --t-mac-bg:#DADADA;
  --t-siri:#DE6B48;         --t-siri-bg:#F5D5C6;
  --t-airdrop:#3B7BDC;      --t-airdrop-bg:#CFDCF4;
  --t-cloudflare:#F38020;   --t-cloudflare-bg:#F9DCBC;
  --t-anthropic:#CC785C;    --t-anthropic-bg:#F5DDD0;
}

/* ============ BASE ============ */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body {
  font-family: '金萱3', 'PingFang TC', 'Noto Sans TC', sans-serif;
  background: var(--outer-bg);
  color: var(--ink);
  line-height: 1.9;
  min-height: 100vh;
  padding-bottom: 60px;
}
a { color: var(--brand-purple); }
a:hover { color: var(--brand-red); }
code {
  font-family: 'SF Mono', Menlo, 'Courier New', monospace;
  background: rgba(209,75,99,0.1);
  color: var(--brand-red);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 0.92em;
}

/* ============ TOP NAV ============ */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(250,246,238,0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 2px 10px rgba(0,0,0,0.06);
}
.nav-inner {
  max-width: 1180px; margin: 0 auto;
  display: flex; align-items: center; gap: 14px;
  padding: 12px 22px;
  overflow-x: auto; white-space: nowrap;
  scrollbar-width: none;
}
.nav-inner::-webkit-scrollbar { display: none; }
.nav-brand {
  display: flex; align-items: center; gap: 8px;
  font-family: '粒線體', sans-serif; font-size: 17px;
  color: var(--ink-deep); text-decoration: none; flex-shrink: 0;
}
.nav-brand img { height: 32px; width: auto; }
.nav-links { display: flex; gap: 2px; margin-left: 6px; }
.nav-links a {
  padding: 7px 13px; border-radius: 99px;
  font-family: '金萱9', sans-serif; font-size: 13.5px;
  color: var(--muted); text-decoration: none;
  transition: all .15s ease;
}
.nav-links a:hover,
.nav-links a.active {
  background: var(--brand-yellow); color: var(--ink-deep);
}
.nav-cta {
  margin-left: auto; flex-shrink: 0;
  background: var(--brand-red); color: #fff;
  padding: 8px 18px; border-radius: 99px;
  font-family: '金萱9', sans-serif; font-size: 13.5px;
  text-decoration: none;
  box-shadow: 2px 3px 8px rgba(209,75,99,0.3);
}
.nav-cta:hover { background: var(--brand-red-dark); color: #fff; }

/* ============ NOTEBOOK CONTAINER ============ */
.notebook {
  max-width: 1120px;
  margin: 28px auto;
  background-color: var(--paper);
  background-image:
    repeating-linear-gradient(transparent, transparent 31px,
      var(--line-blue) 31px, var(--line-blue) 32px),
    linear-gradient(90deg, transparent 86px,
      var(--line-red) 86px, var(--line-red) 88px, transparent 88px);
  padding: 64px 40px 72px 110px;
  border-radius: 10px;
  box-shadow: 0 30px 70px rgba(0,0,0,0.18);
  position: relative;
}
.notebook::before {
  content: '';
  position: absolute;
  left: 28px; top: 50px; bottom: 50px;
  width: 18px;
  background-image:
    radial-gradient(circle at 50% 0%,   var(--hole) 0 9px, transparent 9.5px),
    radial-gradient(circle at 50% 20%,  var(--hole) 0 9px, transparent 9.5px),
    radial-gradient(circle at 50% 40%,  var(--hole) 0 9px, transparent 9.5px),
    radial-gradient(circle at 50% 60%,  var(--hole) 0 9px, transparent 9.5px),
    radial-gradient(circle at 50% 80%,  var(--hole) 0 9px, transparent 9.5px),
    radial-gradient(circle at 50% 100%, var(--hole) 0 9px, transparent 9.5px);
}

/* ============ PAGE TITLE ============ */
.page-title { text-align: center; margin-bottom: 40px; }
.page-kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: '金萱9', sans-serif;
  font-size: 11px; letter-spacing: 5px;
  color: var(--brand-red);
  padding: 6px 2px;
  margin-bottom: 18px;
  text-transform: uppercase;
  font-weight: 700;
}
.page-kicker::before,
.page-kicker::after {
  content: '';
  width: 22px; height: 1px;
  background: var(--brand-red);
  opacity: 0.6;
}
.page-title h1 {
  font-family: '粒線體', sans-serif;
  font-size: clamp(30px, 4.6vw, 52px);
  line-height: 1.3; font-weight: 900;
  color: var(--brand-red);
  letter-spacing: 1px;
}
.page-title h1 .hl {
  color: var(--brand-red);
  background: linear-gradient(transparent 48%, rgba(255,218,65,0.75) 48%, rgba(255,218,65,0.75) 88%, transparent 88%);
  padding: 0 3px;
  display: inline;
}
.page-title .sub {
  font-family: '金萱3', sans-serif; font-style: italic;
  font-size: clamp(15px, 1.7vw, 19px);
  color: var(--muted);
  max-width: 720px; margin: 14px auto 0;
}

/* ============ HERO SPLIT（圖+文字兩欄） ============ */
.hero-split {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 48px;
  align-items: center;
  margin: 20px 0 40px;
}
.hero-split .hero-photo {
  position: relative;
  transform: rotate(-2deg);
  transition: transform .3s ease;
}
.hero-split .hero-photo:hover { transform: rotate(0) scale(1.03); }
.hero-split .hero-photo img {
  width: 100%;
  display: block;
  background: #fff;
  padding: 14px 14px 46px;
  box-shadow: var(--shadow-paper-xl);
  border-radius: 2px;
}
.hero-split .hero-photo::before {
  content: '';
  position: absolute;
  top: -14px; left: 50%;
  width: 120px; height: 26px;
  transform: translateX(-50%) rotate(-4deg);
  background: rgba(209,75,99,0.42);
  box-shadow: 0 2px 4px rgba(0,0,0,0.12);
  z-index: 2;
}
.hero-split .hero-photo::after {
  content: attr(data-caption);
  position: absolute;
  left: 14px; right: 14px; bottom: 14px;
  text-align: center;
  font-family: '金萱3', sans-serif;
  font-style: italic;
  font-size: 13px;
  color: var(--muted);
}
.hero-split .hero-text {
  text-align: left;
}
.hero-split .hero-text .page-kicker { margin-bottom: 16px; }
.hero-split .hero-text h1 {
  font-family: '粒線體', 'PingFang TC', sans-serif;
  font-weight: 900;
  color: var(--brand-purple);
  letter-spacing: 1px;
  line-height: 1.3;
  text-align: left;
  font-size: clamp(30px, 4.4vw, 54px);
}
.hero-split .hero-text h1 .hl {
  color: var(--brand-red);
  background: linear-gradient(transparent 48%, rgba(255,218,65,0.75) 48%, rgba(255,218,65,0.75) 88%, transparent 88%);
  padding: 0 3px;
  display: inline;
}
.hero-split .hero-text .sub { margin: 14px 0 0; max-width: none; }

/* ============ PHOTO WALL（拍立得照片牆） ============ */
.photo-wall {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  margin: 36px 0;
  padding: 20px 8px;
}
.photo-card {
  background: #fff;
  padding: 14px 14px 40px;
  box-shadow: var(--shadow-paper-xl);
  border-radius: 2px;
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
}
.photo-card:nth-child(4n+1) { transform: rotate(-1.8deg); }
.photo-card:nth-child(4n+2) { transform: rotate(1.2deg); }
.photo-card:nth-child(4n+3) { transform: rotate(-0.8deg); }
.photo-card:nth-child(4n+4) { transform: rotate(1.5deg); }
.photo-card:hover {
  transform: rotate(0) scale(1.05) translateY(-4px);
  z-index: 3;
}
.photo-card::before {
  content: '';
  position: absolute;
  top: -10px; left: 50%;
  width: 76px; height: 20px;
  transform: translateX(-50%) rotate(-4deg);
  background: rgba(245,166,35,0.5);
  box-shadow: 0 2px 3px rgba(0,0,0,0.12);
}
.photo-card:nth-child(3n+2)::before { background: rgba(209,75,99,0.42); transform: translateX(-50%) rotate(3deg); }
.photo-card:nth-child(3n+3)::before { background: rgba(76,69,138,0.42); transform: translateX(-50%) rotate(-2deg); }
.photo-card img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
  border-radius: 1px;
}
.photo-card .cap {
  position: absolute;
  left: 14px; right: 14px; bottom: 12px;
  text-align: center;
  font-family: '金萱3', sans-serif;
  font-style: italic;
  font-size: 12.5px;
  color: var(--muted);
  line-height: 1.3;
}

/* ============ CONTENT IMAGE（段落中插圖） ============ */
.content-img {
  background: #fff;
  padding: 10px 10px 34px;
  box-shadow: var(--shadow-paper-lg);
  border-radius: 2px;
  margin: 24px auto;
  max-width: 520px;
  position: relative;
  transform: rotate(-0.6deg);
}
.content-img img {
  width: 100%;
  display: block;
  border-radius: 1px;
}
.content-img::before {
  content: '';
  position: absolute;
  top: -10px; left: 50%;
  width: 78px; height: 20px;
  transform: translateX(-50%) rotate(-3deg);
  background: rgba(209,75,99,0.4);
  box-shadow: 0 2px 3px rgba(0,0,0,0.12);
}
.content-img .cap {
  position: absolute;
  left: 10px; right: 10px; bottom: 10px;
  text-align: center;
  font-family: '金萱3', sans-serif;
  font-style: italic;
  font-size: 12.5px;
  color: var(--muted);
}

/* ============ ABOUT HERO BIG PHOTO ============ */
.about-hero {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 50px;
  align-items: center;
  margin: 30px 0 50px;
}
.about-hero .photo-card {
  margin: 0;
  transform: rotate(-2.5deg);
}
.about-hero .photo-card img { aspect-ratio: 2/3; }

/* ============ PROOF IMAGE（大課/電子報視覺） ============ */
.proof-img {
  background: #fff;
  padding: 10px;
  box-shadow: var(--shadow-paper-lg);
  border-radius: 3px;
  display: block;
  width: 100%;
  position: relative;
  transform: rotate(-0.4deg);
}
.proof-img img {
  width: 100%;
  display: block;
  border-radius: 1px;
}

/* ============ GUIDE BOX（使用引導，給長輩看） ============ */
.guide-box {
  background: #FBF8F1;
  border-radius: 8px;
  padding: 32px 36px 28px;
  margin: 32px 0;
  box-shadow: 0 3px 14px rgba(0,0,0,0.08), 0 10px 30px rgba(0,0,0,0.06);
  position: relative;
}
.guide-box::before {
  content: '';
  position: absolute;
  top: -12px; left: 50%;
  width: 110px; height: 24px;
  transform: translateX(-50%) rotate(-2deg);
  background: rgba(76,69,138,0.4);
  box-shadow: 0 2px 4px rgba(0,0,0,0.12);
}
.guide-head {
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 18px;
  margin-bottom: 22px;
  border-bottom: 1px dashed rgba(0,0,0,0.12);
}
.guide-head .guide-ic {
  width: 54px; height: 54px;
  background: var(--brand-purple);
  color: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 26px;
  box-shadow: 2px 4px 10px rgba(76,69,138,0.3);
}
.guide-head h3 {
  font-family: '粒線體', sans-serif;
  font-size: clamp(20px, 2.4vw, 26px);
  color: var(--brand-purple);
  font-weight: 900;
  letter-spacing: 0.5px;
}
.guide-steps {
  display: flex; flex-direction: column; gap: 20px;
}
.g-step {
  display: flex; align-items: flex-start; gap: 18px;
  padding: 14px 16px;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.g-step .g-num {
  flex-shrink: 0;
  width: 40px; height: 40px;
  background: var(--brand-red);
  color: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: '粒線體', sans-serif;
  font-size: 22px; font-weight: 900;
  box-shadow: 2px 3px 8px rgba(209,75,99,0.3);
}
.g-step:nth-child(even) .g-num { background: var(--brand-purple); box-shadow: 2px 3px 8px rgba(76,69,138,0.3); }
.g-step > div { flex: 1; }
.g-step b {
  font-family: '金萱9', sans-serif;
  font-size: 17px;
  color: var(--ink-deep);
  display: block; margin-bottom: 6px;
  letter-spacing: 0.5px;
}
.g-step span {
  font-size: 14.5px;
  color: var(--ink);
  line-height: 1.85;
}
.guide-foot {
  text-align: center;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px dashed rgba(0,0,0,0.12);
  font-family: '金萱9', sans-serif;
  font-size: 14.5px;
  color: var(--brand-red);
}

/* 手寫裝飾線 */
.hr-handwrite {
  height: 14px; margin: 40px 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 12'%3E%3Cpath d='M2,6 Q20,2 40,7 T80,5 T120,6 T160,6 T198,6' stroke='%23d14b63' stroke-width='2' fill='none' stroke-linecap='round' opacity='0.55'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-position: center;
}

/* ============ SECTION ============ */
.section { margin-top: 70px; scroll-margin-top: 90px; }
.section-head {
  display: flex; align-items: baseline; gap: 14px;
  margin-bottom: 10px;
}
.section-head .num {
  font-family: '粒線體', sans-serif;
  font-size: 44px; font-weight: 900;
  color: var(--brand-red);
  line-height: 1;
}
.section h2 {
  font-family: '粒線體', sans-serif;
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 900;
  color: var(--ink-deep);
}
.section h2 .hl {
  color: var(--brand-red);
  background: linear-gradient(transparent 48%, rgba(255,218,65,0.75) 48%, rgba(255,218,65,0.75) 88%, transparent 88%);
  padding: 0 3px;
  display: inline;
}
.section .lead {
  font-size: 16px;
  color: var(--muted);
  margin: 4px 0 28px 58px;
  max-width: 780px;
  line-height: 1.85;
}

/* ============ BULB CARD — 淡米白紙 + 纖細紅線裝飾 ============ */
.bulb-card {
  background: #FBF8F1;
  padding: 26px 32px 24px 40px;
  border-radius: 4px;
  margin: 28px 0;
  box-shadow: var(--shadow-paper);
  position: relative;
  overflow: hidden;
}
.bulb-card::before {
  content: '';
  position: absolute;
  left: 16px; top: 22px; bottom: 22px;
  width: 3px;
  background: var(--brand-red);
  opacity: 0.7;
  border-radius: 2px;
}
.bulb-card p { font-size: 15.5px; line-height: 2; color: var(--ink); }
.bulb-card strong {
  color: var(--brand-red);
  font-weight: 700;
}

/* ============ CALLOUT — 中性米灰底（無花色） ============ */
.callout {
  background: #F4EEE0;
  padding: 18px 24px 18px 52px;
  border-radius: 4px;
  font-size: 14.5px;
  color: var(--ink);
  line-height: 1.9;
  margin: 24px 0;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05);
  position: relative;
}
.callout::before {
  content: '※';
  position: absolute;
  left: 24px; top: 16px;
  font-size: 20px;
  color: var(--brand-red);
  font-weight: 700;
}
.callout b { color: var(--brand-red); font-weight: 700; }
.callout.quiet {
  background: #EFE9DB;
  color: var(--ink);
}
.callout.quiet::before { content: '◆'; color: var(--brand-purple); font-size: 14px; top: 18px; }
.callout.quiet b { color: var(--brand-purple); }

/* ============ POLAROID 拍立得（強化陰影） ============ */
.polaroid {
  background: #fff;
  padding: 14px 14px 22px;
  box-shadow: var(--shadow-paper-xl);
  position: relative;
  transition: transform .22s ease, box-shadow .22s ease;
  border-radius: 2px;
}
.polaroid:hover {
  transform: rotate(0) scale(1.05) translateY(-4px) !important;
  box-shadow:
    2px 4px 8px rgba(0,0,0,0.18),
    12px 18px 40px rgba(0,0,0,0.28),
    24px 32px 60px rgba(0,0,0,0.20);
  z-index: 3;
}
.polaroid:nth-child(4n+1) { transform: rotate(-1.4deg); }
.polaroid:nth-child(4n+2) { transform: rotate(0.9deg); }
.polaroid:nth-child(4n+3) { transform: rotate(-0.6deg); }
.polaroid:nth-child(4n+4) { transform: rotate(1.2deg); }
.polaroid::before {
  content: '';
  position: absolute;
  top: -12px; left: 50%;
  width: 92px; height: 24px;
  transform: translateX(-50%) rotate(-4deg);
  background: rgba(209,75,99,0.4);
  box-shadow: 0 2px 3px rgba(0,0,0,0.12);
}
.polaroid:nth-child(3n+2)::before { background: rgba(76,69,138,0.42); transform: translateX(-50%) rotate(3deg); }
.polaroid:nth-child(3n+3)::before { background: rgba(245,166,35,0.5); transform: translateX(-50%) rotate(-2deg); }
.polaroid .pic {
  aspect-ratio: 1/1;
  background: var(--tool-bg, var(--note-yellow));
  color: var(--tool-color, var(--brand-red));
  display: flex; align-items: center; justify-content: center;
  font-size: 48px;
  margin-bottom: 12px;
  border-radius: 2px;
  position: relative;
}
.polaroid .pic img { max-width: 78%; max-height: 78%; object-fit: contain; }
.polaroid h4 {
  font-family: '金萱9', sans-serif;
  font-size: 16px; font-weight: 700;
  color: var(--ink-deep);
  text-align: center; margin-bottom: 4px;
}
.polaroid .role,
.polaroid .role-tag {
  text-align: center;
  font-size: 11.5px; color: var(--tool-color, var(--brand-red));
  font-family: '金萱9', sans-serif;
  font-weight: 700; letter-spacing: 0.5px;
  margin-bottom: 8px;
}
.polaroid .cap {
  text-align: center;
  font-family: '金萱3', sans-serif;
  font-style: italic;
  font-size: 12.5px; color: var(--muted);
  padding-top: 8px;
  line-height: 1.6;
}

/* Grids */
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; padding: 14px 4px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; padding: 14px 4px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; padding: 14px 4px; }

/* ============ TOOL CHIP (小標籤) ============ */
.tool-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--tool-bg, var(--paper-deep));
  color: var(--tool-color, var(--ink-deep));
  padding: 5px 12px;
  border-radius: 99px;
  font-family: '金萱9', sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  white-space: nowrap;
  box-shadow: 1px 2px 3px rgba(0,0,0,0.08);
}
.tool-chip .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--tool-color, var(--brand-red));
}

/* ============ TOOL CARD — 白底 + 細工具色指示（精緻版） ============ */
.tool-card {
  background: #fff;
  color: var(--ink);
  border-radius: 6px;
  padding: 24px 26px 22px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06), 0 6px 18px rgba(0,0,0,0.04);
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
  overflow: hidden;
}
.tool-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.10), 0 12px 32px rgba(0,0,0,0.08);
}
.tool-card .head {
  display: flex; align-items: center; gap: 14px; margin-bottom: 14px;
}
.tool-card .head .ic {
  width: 44px; height: 44px;
  background: var(--tool-bg, var(--paper-deep));
  color: var(--tool-color, var(--brand-red));
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.tool-card .head h4 {
  font-family: '粒線體', sans-serif;
  font-size: 19px; color: var(--tool-color, var(--brand-red));
  font-weight: 900;
  letter-spacing: 0.5px;
}
.tool-card .head .cat {
  margin-left: auto;
  font-size: 10.5px; color: var(--muted);
  font-family: '金萱9', sans-serif;
  padding: 3px 0;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.tool-card p {
  font-size: 14px; line-height: 1.85;
  color: var(--ink); margin-bottom: 8px;
}
.tool-card .use { color: var(--ink-deep); }
.tool-card .owner {
  font-size: 12.5px; color: var(--tool-color, var(--brand-red));
  font-family: '金萱9', sans-serif;
  margin-top: 10px; font-weight: 700;
  padding-top: 10px;
  border-top: 1px dashed rgba(0,0,0,0.08);
}
.tool-card .owner::before { content: '👥 '; }

/* ============ TOOL COLOR CLASSES ============ */
.tool-claude     { --tool-color: var(--t-claude);     --tool-bg: var(--t-claude-bg); }
.tool-anthropic  { --tool-color: var(--t-anthropic);  --tool-bg: var(--t-anthropic-bg); }
.tool-obsidian   { --tool-color: var(--t-obsidian);   --tool-bg: var(--t-obsidian-bg); }
.tool-heptabase  { --tool-color: var(--t-heptabase);  --tool-bg: var(--t-heptabase-bg); }
.tool-notion     { --tool-color: var(--t-notion);     --tool-bg: var(--t-notion-bg); }
.tool-wordpress  { --tool-color: var(--t-wordpress);  --tool-bg: var(--t-wordpress-bg); }
.tool-systeme    { --tool-color: var(--t-systeme);    --tool-bg: var(--t-systeme-bg); }
.tool-gmail      { --tool-color: var(--t-gmail);      --tool-bg: var(--t-gmail-bg); }
.tool-gcal       { --tool-color: var(--t-gcal);       --tool-bg: var(--t-gcal-bg); }
.tool-ga         { --tool-color: var(--t-ga);         --tool-bg: var(--t-ga-bg); }
.tool-notebooklm { --tool-color: var(--t-notebooklm); --tool-bg: var(--t-notebooklm-bg); }
.tool-discord    { --tool-color: var(--t-discord);    --tool-bg: var(--t-discord-bg); }
.tool-threads    { --tool-color: var(--t-threads);    --tool-bg: var(--t-threads-bg); }
.tool-ig         { --tool-color: var(--t-ig);         --tool-bg: var(--t-ig-bg); }
.tool-line       { --tool-color: var(--t-line);       --tool-bg: var(--t-line-bg); }
.tool-wechat     { --tool-color: var(--t-wechat);     --tool-bg: var(--t-wechat-bg); }
.tool-zeabur     { --tool-color: var(--t-zeabur);     --tool-bg: var(--t-zeabur-bg); }
.tool-mac        { --tool-color: var(--t-mac);        --tool-bg: var(--t-mac-bg); }
.tool-siri       { --tool-color: var(--t-siri);       --tool-bg: var(--t-siri-bg); }
.tool-airdrop    { --tool-color: var(--t-airdrop);    --tool-bg: var(--t-airdrop-bg); }
.tool-cloudflare { --tool-color: var(--t-cloudflare); --tool-bg: var(--t-cloudflare-bg); }

/* ============ STATS ROW — 四張純白紙卡（精緻雜誌感） ============ */
.stats-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin: 32px 0;
  padding: 10px 2px;
}
.stats-row .s {
  background: transparent;
  padding: 16px 8px;
  text-align: center;
  position: relative;
}
.stats-row .s::after {
  content: '';
  position: absolute;
  left: 50%; bottom: 12px;
  width: 24px; height: 1px;
  transform: translateX(-50%);
  background: var(--brand-red);
  opacity: 0.35;
}
.stats-row .big {
  font-family: '粒線體', sans-serif;
  font-size: 64px; font-weight: 900;
  line-height: 1; display: block;
  color: var(--brand-red);
  letter-spacing: -1px;
}
.stats-row .s:nth-child(2) .big { color: var(--brand-purple); }
.stats-row .s:nth-child(3) .big { color: #a36f00; }
.stats-row .s:nth-child(4) .big { color: #2d8659; }
.stats-row .s:nth-child(2)::after { background: var(--brand-purple); }
.stats-row .s:nth-child(3)::after { background: #a36f00; }
.stats-row .s:nth-child(4)::after { background: #2d8659; }
.stats-row .lab {
  font-size: 12px; color: var(--muted);
  display: block; margin-top: 14px;
  font-family: '金萱9', sans-serif;
  letter-spacing: 1px;
}

/* ============ FLOW (pipeline) — 整張工具色 ============ */
.flow-row {
  display: grid;
  grid-template-columns: 1fr 48px 1fr 48px 1fr;
  align-items: center;
  gap: 10px;
  margin: 26px 0;
  padding: 12px 0;
}
.flow-node {
  background: var(--tool-bg, #fff);
  color: var(--ink-deep);
  border-radius: 3px;
  padding: 16px 10px;
  text-align: center;
  box-shadow: var(--shadow-paper);
  transform: rotate(-0.4deg);
  position: relative;
}
.flow-node:nth-child(3) { transform: rotate(0.3deg); }
.flow-node:nth-child(5) { transform: rotate(-0.2deg); }
.flow-node .ic {
  font-size: 28px; margin-bottom: 4px; display: block;
  color: var(--tool-color, var(--brand-red));
}
.flow-node .nm {
  font-family: '金萱9', sans-serif; font-size: 13.5px;
  color: var(--tool-color, var(--ink-deep)); font-weight: 700;
}
.flow-node .sm { font-size: 11px; color: var(--ink); margin-top: 2px; }
.flow-arr {
  font-family: '粒線體', sans-serif;
  font-size: 26px; color: var(--brand-red);
  text-align: center; font-weight: 900;
}

/* ============ STEP CARD — 純白紙（去紙膠帶） ============ */
.step-card {
  background: #fff;
  border-radius: 6px;
  padding: 28px 32px 24px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06), 0 8px 22px rgba(0,0,0,0.05);
  position: relative;
  margin-bottom: 28px;
}
.step-card .step-num {
  position: absolute; top: 0; right: 0;
  width: auto; height: 32px;
  border-radius: 0 6px 0 18px;
  padding: 0 16px 0 20px;
  background: var(--brand-red); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: '粒線體', sans-serif; font-size: 16px; font-weight: 900;
  box-shadow: -2px 3px 8px rgba(209,75,99,0.25);
  letter-spacing: 1px;
  z-index: 2;
}
.step-card:nth-child(even) .step-num { background: var(--brand-purple); box-shadow: -2px 3px 8px rgba(76,69,138,0.25); }
.step-card h3 {
  font-family: '金萱9', sans-serif;
  font-size: 19px; color: var(--brand-purple); font-weight: 700;
  margin: 4px 0 12px;
}
.step-card:nth-child(even) h3 { color: var(--brand-red); }
.step-card .what { font-size: 14.5px; line-height: 1.85; color: var(--ink); }
.step-card .what b { color: var(--brand-red); }
.step-card .tools {
  margin-top: 14px; display: flex; flex-wrap: wrap; gap: 6px;
}

/* ============ RITUAL CARD — 純白紙（去紙膠帶） ============ */
.ritual-card {
  background: #fff;
  border-radius: 6px;
  padding: 32px 28px 28px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06), 0 10px 26px rgba(0,0,0,0.06);
  position: relative;
}
.ritual-card .icon {
  font-size: 44px; margin-bottom: 12px; display: block;
}
.ritual-card h3 {
  font-family: '粒線體', sans-serif; font-size: 24px;
  color: var(--ink-deep); font-weight: 900; margin-bottom: 8px;
}
.ritual-card .trig {
  font-size: 12px; color: var(--brand-red);
  background: var(--brand-yellow);
  padding: 3px 10px; border-radius: 99px;
  display: inline-block; margin-bottom: 16px;
  font-weight: 700;
}
.ritual-card ol {
  padding-left: 22px; font-size: 14px; color: var(--ink); line-height: 1.9;
}
.ritual-card ol li { margin-bottom: 4px; }
.ritual-card ol li b { color: var(--brand-purple); }
.ritual-card .foot {
  margin-top: 16px; padding-top: 12px;
  font-size: 12.5px; color: var(--muted); font-style: italic;
}

/* ============ MEMO DEMO — 淡米白底 + 彩色 badge ============ */
.memo-demo {
  background: #FBF8F1;
  border-radius: 6px;
  padding: 26px 30px 24px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.05), 0 6px 18px rgba(0,0,0,0.04);
  margin-top: 24px;
  position: relative;
}
.memo-demo .memo-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 14px;
  font-family: 'SF Mono', Menlo, monospace; font-size: 12.5px; color: var(--muted);
}
.memo-demo .badge {
  background: var(--brand-green); color: #fff;
  padding: 3px 12px; border-radius: 3px; font-size: 10.5px;
  letter-spacing: 2px; font-family: '金萱9', sans-serif;
}
.memo-demo h4 {
  font-family: '金萱9', sans-serif; font-size: 19px;
  color: var(--ink-deep); margin-bottom: 12px; font-weight: 700;
}
.memo-demo .memo-body {
  background: #fff; padding: 18px 20px;
  border-radius: 4px; font-size: 14.5px; line-height: 1.9;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.04);
}
.memo-demo .memo-body b { color: var(--brand-red); font-weight: 700; }

/* Memory stats — 4 白紙卡 */
.memo-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  margin-top: 24px; padding: 8px 2px;
}
.memo-stats .m {
  background: #fff;
  border-radius: 6px;
  padding: 24px 12px 20px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06), 0 8px 20px rgba(0,0,0,0.04);
  position: relative;
}
.memo-stats .m::after {
  content: '';
  position: absolute;
  left: 50%; bottom: 10px;
  width: 20px; height: 1px;
  transform: translateX(-50%);
  background: var(--brand-red);
  opacity: 0.35;
}
.memo-stats .m .n {
  font-family: '粒線體', sans-serif; font-size: 34px;
  color: var(--brand-red); display: block; line-height: 1; font-weight: 900;
  letter-spacing: -1px;
}
.memo-stats .m:nth-child(2) .n { color: var(--brand-purple); }
.memo-stats .m:nth-child(3) .n { color: #a36f00; }
.memo-stats .m:nth-child(4) .n { color: #2d8659; }
.memo-stats .m:nth-child(2)::after { background: var(--brand-purple); }
.memo-stats .m:nth-child(3)::after { background: #a36f00; }
.memo-stats .m:nth-child(4)::after { background: #2d8659; }
.memo-stats .m .l {
  font-size: 11px; color: var(--muted);
  margin-top: 12px; display: block;
  font-family: '金萱9', sans-serif; letter-spacing: 1px;
}

/* ============ SKILL CATEGORY — 純白紙（去紙膠帶） ============ */
.skill-cat {
  background: #fff;
  border-radius: 6px;
  padding: 28px 32px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06), 0 8px 22px rgba(0,0,0,0.05);
  margin-bottom: 24px;
  position: relative;
}
.skill-cat h3 {
  font-family: '粒線體', sans-serif; font-size: 22px;
  color: var(--ink-deep); margin-bottom: 6px; font-weight: 900;
}
.skill-cat .desc { font-size: 14.5px; color: var(--muted); margin-bottom: 14px; }
.skill-list { display: flex; flex-wrap: wrap; gap: 8px; }

/* ============ TABLE — 參考 wall-of-love speaking-table ============ */
.notebook table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 32px auto;
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 3px 6px 20px rgba(0,0,0,0.12);
  max-width: 1100px;
  transform: rotate(-0.3deg);
}
.notebook table th {
  background: #f7f0e3;
  color: var(--ink-deep);
  padding: 18px 22px;
  text-align: center;
  font-family: '金萱9', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.12em;
  border-bottom: 2px solid rgba(200,150,80,0.25);
  white-space: nowrap;
}
.notebook table th:first-child { border-top-left-radius: 20px; }
.notebook table th:last-child { border-top-right-radius: 20px; }

.notebook table td {
  padding: 16px 22px;
  border-bottom: 1px dashed rgba(80,50,30,0.18);
  font-size: 14.5px;
  line-height: 1.8;
  vertical-align: top;
}
.notebook table tr:last-child td { border-bottom: none; }
.notebook table tr:hover td { background: rgba(247,240,227,0.55); }
.notebook table tr:nth-child(even) td { background: transparent; }

/* ============ FOOTER ============ */
.site-footer {
  text-align: center;
  max-width: 1120px; margin: 10px auto 0;
  padding: 30px 40px 40px;
  font-family: '金萱3', sans-serif;
  font-size: 13.5px; color: var(--muted);
}
.site-footer img { width: 130px; display: block; margin: 0 auto 10px; opacity: 0.9; }
.site-footer .platforms {
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center; margin: 16px 0 12px;
}
.site-footer .platforms a {
  font-family: '金萱9', sans-serif; font-size: 13px;
  color: var(--brand-purple); text-decoration: none;
  padding: 7px 16px; border-radius: 99px;
  background: #fff;
  box-shadow: 1px 2px 4px rgba(0,0,0,0.08);
  font-weight: 700;
}
.site-footer .platforms a:hover { background: var(--brand-yellow); color: var(--ink-deep); }

/* ============ CTA — 乾淨精緻版 ============ */
.cta-section {
  background: #fff;
  border-radius: 8px;
  padding: 48px 40px;
  margin-top: 48px;
  text-align: center;
  box-shadow: 0 4px 14px rgba(0,0,0,0.08), 0 12px 36px rgba(0,0,0,0.06);
  position: relative;
}
.cta-section h2 {
  font-family: '粒線體', sans-serif;
  font-size: 30px; color: var(--brand-red);
  font-weight: 900; margin-bottom: 10px;
}
.cta-section p.intro { font-size: 15px; color: var(--muted); margin-bottom: 28px; }
.cta-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; padding: 8px 2px; }
.cta-btn {
  background: #fff;
  border-radius: 6px;
  padding: 28px 20px 24px;
  text-decoration: none; color: var(--ink);
  box-shadow: 0 2px 10px rgba(0,0,0,0.06), 0 6px 18px rgba(0,0,0,0.04);
  display: block; transition: transform .2s ease, box-shadow .2s ease;
  position: relative;
  overflow: hidden;
}
.cta-btn::after {
  content: '';
  position: absolute;
  left: 28px; right: 28px; bottom: 14px;
  height: 1px;
  background: var(--brand-red);
  opacity: 0.3;
}
.cta-btn:nth-child(2)::after { background: var(--brand-purple); }
.cta-btn:nth-child(3)::after { background: #a36f00; }
.cta-btn:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.08), 0 14px 34px rgba(0,0,0,0.10);
  color: var(--ink-deep);
}
.cta-btn .ic {
  font-size: 32px; display: block; margin-bottom: 10px;
  width: 56px; height: 56px;
  background: var(--paper-deep);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 14px;
}
.cta-btn h4 {
  font-family: '金萱9', sans-serif; font-size: 17px;
  color: var(--brand-red); margin-bottom: 8px; font-weight: 700;
  text-align: center;
}
.cta-btn:nth-child(2) h4 { color: var(--brand-purple); }
.cta-btn:nth-child(3) h4 { color: #a36f00; }
.cta-btn p {
  font-size: 13px; color: var(--muted); line-height: 1.7;
  text-align: center;
}

/* ============ MANIFESTO（淺米手撕紙 — 小腸 2026-04-24：不要深牛皮紙）============ */
.manifesto-wrap {
  max-width: 720px;
  margin: 56px auto;
  position: relative;
  filter: drop-shadow(0 6px 18px rgba(80,60,40,0.18));
}
.manifesto {
  background-color: #F2EADA;  /* 淺米色（取代深牛皮紙） */
  background-image:
    radial-gradient(ellipse at 20% 30%, rgba(255,250,235,0.5), transparent 50%),
    radial-gradient(ellipse at 80% 70%, rgba(180,155,120,0.15), transparent 55%);
  padding: 56px 48px 52px;
  transform: rotate(-0.4deg);
  text-align: center;
  position: relative;
  /* 大幅手撕邊（上下各 8-10%，像真的從筆記本撕下來） */
  clip-path: polygon(
    0% 5%, 4% 1%, 9% 5%, 14% 2%, 19% 4%, 25% 1%, 32% 5%, 38% 2%, 46% 4%, 54% 1%, 62% 4%, 69% 2%, 76% 5%, 82% 1%, 88% 4%, 94% 2%, 100% 3%,
    100% 97%, 94% 99%, 88% 96%, 82% 99%, 76% 95%, 69% 98%, 62% 96%, 54% 99%, 46% 96%, 38% 98%, 32% 95%, 25% 99%, 19% 96%, 14% 98%, 9% 95%, 4% 99%, 0% 95%
  );
}
/* 紙膠帶（不被 clip-path 吃掉，所以放在 wrap 上） */
.manifesto-wrap::before {
  content: '';
  position: absolute;
  top: -6px; left: 50%;
  width: 120px; height: 24px;
  transform: translateX(-50%) rotate(-3deg);
  background: rgba(255,255,255,0.45);
  box-shadow: 0 2px 6px rgba(0,0,0,0.18);
  z-index: 2;
}
/* 紙張紋理 noise layer */
.manifesto::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  opacity: 0.12;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: 0;
}
.manifesto-logo { width: 58px; margin: 0 auto 8px; display: block; }
.manifesto .quote { font-family: '粒線體', sans-serif; font-size: 48px; color: var(--brand-red); line-height: 0.5; margin-bottom: 8px; opacity: 0.6; }
.manifesto p {
  font-family: '粒線體', sans-serif;
  font-size: clamp(18px, 2.1vw, 24px);
  color: var(--ink-deep); font-weight: 900;
  letter-spacing: 1.2px; line-height: 2.1;
  margin: 14px 0;
  position: relative; z-index: 1;
}
/* 螢光筆效果：色只在字下半部，像真實螢光筆劃過（適配淺米底） */
.manifesto p .hl {
  padding: 0 4px;
  display: inline;
  font-weight: 900;
  color: var(--ink-deep) !important;
  background: none;
  box-shadow: none;
}
.manifesto p .hl.hl-red {
  background: linear-gradient(180deg, transparent 48%, rgba(209,75,99,0.55) 48%, rgba(209,75,99,0.55) 94%, transparent 94%) !important;
}
.manifesto p .hl.hl-purple {
  background: linear-gradient(180deg, transparent 48%, rgba(140,125,200,0.5) 48%, rgba(140,125,200,0.5) 94%, transparent 94%) !important;
}
.manifesto p .hl.hl-orange {
  background: linear-gradient(180deg, transparent 48%, rgba(245,200,130,0.75) 48%, rgba(245,200,130,0.75) 94%, transparent 94%) !important;
}
.manifesto .signature {
  font-family: '金萱3', sans-serif; font-style: italic;
  font-size: 16px; color: var(--muted);
  margin-top: 28px; letter-spacing: 1px;
}

/* ============ ORG CHART — 實心色塊版 ============ */
.org-hierarchy { margin: 40px 0 30px; padding: 16px 4px; }

/* Level 1 · CEO — 紅底卡 */
.org-ceo-wrap { text-align: center; position: relative; padding-top: 10px; }
.org-ceo {
  display: inline-block;
  background: var(--brand-red);
  color: #fff;
  border-radius: 4px;
  padding: 18px 40px;
  box-shadow:
    2px 4px 10px rgba(209,75,99,0.35),
    6px 12px 30px rgba(0,0,0,0.18);
  transform: rotate(-0.6deg);
  position: relative;
}
.org-ceo::before {
  content: '';
  position: absolute;
  top: -10px; left: 50%;
  width: 92px; height: 22px;
  transform: translateX(-50%) rotate(-3deg);
  background: rgba(255,255,255,0.45);
  box-shadow: 0 2px 3px rgba(0,0,0,0.12);
}
.org-ceo .lv { font-size: 10.5px; letter-spacing: 3px; color: rgba(255,255,255,0.85); font-family: '金萱9', sans-serif; margin-bottom: 3px; }
.org-ceo .nm { font-family: '粒線體', sans-serif; font-size: 28px; color: #fff; font-weight: 900; }
.org-ceo .rl { font-size: 12.5px; color: rgba(255,255,255,0.9); margin-top: 3px; }

/* Level 2 · 大腸 + 顧問 */
.org-mid {
  display: flex; justify-content: center; gap: 130px;
  margin: 44px 0 16px; position: relative;
}
.org-mid::before {
  content: ''; position: absolute;
  top: -30px; left: 50%; width: 2px; height: 30px;
  background: var(--brand-red); opacity: 0.35;
}
.org-mid::after {
  content: ''; position: absolute;
  top: 0; left: calc(50% - 65px); width: 130px;
  height: 2px; background: var(--brand-red); opacity: 0.35;
}
.org-chief, .org-advisors {
  position: relative;
  border-radius: 4px;
  padding: 14px 24px;
  min-width: 210px;
  text-align: center;
  box-shadow: var(--shadow-paper-lg);
}
.org-chief {
  background: var(--t-claude);
  color: #fff;
  transform: rotate(-0.5deg);
}
.org-advisors {
  background: var(--brand-purple);
  color: #fff;
  transform: rotate(0.5deg);
}
.org-chief::before, .org-advisors::before {
  content: ''; position: absolute;
  top: -30px; left: 50%; width: 2px; height: 30px;
  background: var(--brand-red); opacity: 0.35;
}
.org-chief .nm, .org-advisors .nm {
  font-family: '金萱9', sans-serif; font-size: 17px; color: #fff; font-weight: 700;
}
.org-chief .rl, .org-advisors .rl {
  font-size: 11.5px; color: rgba(255,255,255,0.9); margin-top: 3px;
}

/* Level 3 · 8 處室 */
.org-depts-wrap { position: relative; padding-top: 52px; }
.org-depts-wrap::before {
  content: ''; position: absolute;
  top: 0; left: 50%; width: 2px; height: 28px;
  background: var(--brand-red); opacity: 0.35;
}
.org-depts-wrap::after {
  content: ''; position: absolute;
  top: 28px; left: calc(100% / 16); right: calc(100% / 16);
  height: 2px; background: var(--brand-red); opacity: 0.35;
}
.org-depts {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 10px;
}
.org-dept-col { position: relative; padding-top: 26px; }
.org-dept-col::before {
  content: ''; position: absolute;
  top: 0; left: 50%; width: 2px; height: 26px;
  background: var(--brand-red); opacity: 0.35;
}

/* Dept header — 整張實心色塊 */
.org-dept-head {
  background: var(--dept-color, var(--brand-red));
  color: #fff;
  border-radius: 4px;
  padding: 12px 6px;
  text-align: center;
  box-shadow: 2px 3px 10px rgba(0,0,0,0.18);
  margin-bottom: 14px;
  transform: rotate(-0.6deg);
  position: relative;
}
.org-dept-col:nth-child(even) .org-dept-head { transform: rotate(0.5deg); }
.org-dept-head::before {
  content: '';
  position: absolute;
  top: -7px; left: 50%;
  width: 44px; height: 14px;
  transform: translateX(-50%) rotate(-3deg);
  background: rgba(255,255,255,0.45);
}
.org-dept-head .no {
  font-family: '粒線體', sans-serif; font-size: 16px; font-weight: 900;
  color: rgba(255,255,255,0.8); display: block; line-height: 1;
}
.org-dept-head .nm {
  font-family: '金萱9', sans-serif; font-size: 12.5px;
  color: #fff; font-weight: 700; margin-top: 3px; display: block;
}

/* Emp card — 整張淡色底（dept 對應色） */
.org-emp {
  background: var(--dept-bg, #fff);
  border-radius: 3px;
  padding: 11px 12px 10px;
  margin-bottom: 9px;
  box-shadow: var(--shadow-paper);
  transform: rotate(-0.3deg);
}
.org-emp:nth-child(even) { transform: rotate(0.3deg); }
.org-emp .en {
  font-family: '金萱9', sans-serif;
  font-size: 13.5px; font-weight: 700;
  color: var(--dept-color, var(--ink-deep));
  display: flex; align-items: center; gap: 4px;
}
.org-emp .en .ic { font-size: 14px; }
.org-emp .et {
  font-size: 10px; color: var(--ink);
  line-height: 1.4; margin: 1px 0 5px;
  opacity: 0.75;
}
.org-emp .sk { list-style: none; padding: 0; margin: 0; }
.org-emp .sk li {
  font-size: 10.5px;
  color: var(--ink);
  line-height: 1.55;
  padding: 1px 0 1px 10px;
  position: relative;
}
.org-emp .sk li::before {
  content: '·';
  position: absolute; left: 3px; top: 1px;
  color: var(--dept-color);
  font-weight: 900;
}

/* 8 處室顏色（主色 + 底色配對） */
.dept-0 { --dept-color: #8a6db8; --dept-bg: #ECE5F5; }
.dept-7 { --dept-color: #d14b63; --dept-bg: #FAD8DE; }
.dept-1 { --dept-color: #4C458A; --dept-bg: #DAD7EA; }
.dept-2 { --dept-color: #7C3AED; --dept-bg: #E3D5F7; }
.dept-3 { --dept-color: #E37400; --dept-bg: #F9DFBE; }
.dept-4 { --dept-color: #CC785C; --dept-bg: #F5DDD0; }
.dept-5 { --dept-color: #2d8659; --dept-bg: #C8E4D0; }
.dept-6 { --dept-color: #E1306C; --dept-bg: #F9D9E6; }

/* 員工卡可點擊視覺提示 */
.org-emp[data-emp] {
  cursor: pointer !important;
  position: relative;
}
.org-emp[data-emp]::after {
  content: '👆';
  position: absolute;
  bottom: 6px; right: 6px;
  font-size: 11px;
  opacity: 0;
  transition: opacity .2s;
}
.org-emp[data-emp]:hover {
  outline: 2px solid var(--dept-color, var(--brand-red));
  outline-offset: 2px;
  transform: translateY(-3px) scale(1.03) !important;
  box-shadow: 0 8px 22px rgba(0,0,0,0.2) !important;
  z-index: 5;
}
.org-emp[data-emp]:hover::after { opacity: 1; }
.org-ceo, .org-chief, .org-advisors { cursor: pointer; }

/* ============ 小腸對話泡泡（段落分隔 + 個性化敘述） ============ */
.chang-bubble {
  display: flex; gap: 14px;
  max-width: 680px; margin: 56px auto;
  align-items: flex-start;
  opacity: 0; transform: translateY(16px);
  animation: bubbleFade .6s ease forwards;
}
@keyframes bubbleFade { to { opacity: 1; transform: translateY(0); } }
.chang-bubble .avatar {
  width: 54px; height: 54px; border-radius: 50%;
  background: var(--brand-red);
  color: #fff;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
  box-shadow: 2px 4px 12px rgba(209,75,99,0.30);
  overflow: hidden;
}
.chang-bubble .avatar img { width: 100%; height: 100%; object-fit: cover; }
.chang-bubble .bubble {
  background: #fff;
  padding: 18px 24px;
  border-radius: 22px;
  border-top-left-radius: 4px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08), 0 6px 20px rgba(0,0,0,0.06);
  font-size: 15.5px;
  line-height: 1.9;
  color: var(--ink);
  position: relative;
  flex: 1;
}
.chang-bubble .bubble::before {
  content: '';
  position: absolute;
  left: -9px; top: 14px;
  border: 10px solid transparent;
  border-right-color: #fff;
  border-left: 0;
}
.chang-bubble .bubble .nm {
  display: block;
  font-family: '金萱9', sans-serif;
  font-size: 13px;
  color: var(--brand-red);
  letter-spacing: 2px;
  margin-bottom: 6px;
}
.chang-bubble .bubble strong { color: var(--brand-red); }
/* 變體：基腸說（紫） */
.chang-bubble.jichang .avatar { background: var(--brand-purple); box-shadow: 2px 4px 12px rgba(76,69,138,0.3); }
.chang-bubble.jichang .bubble .nm { color: var(--brand-purple); }
.chang-bubble.jichang .bubble strong { color: var(--brand-purple); }
/* 變體：大腸說（橘） */
.chang-bubble.dachang .avatar { background: var(--t-claude); box-shadow: 2px 4px 12px rgba(204,120,92,0.3); }
.chang-bubble.dachang .bubble .nm { color: var(--t-claude); }
.chang-bubble.dachang .bubble strong { color: var(--t-claude); }

/* ============ SCROLL REVEAL（滾動進場動畫） ============ */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1);
  will-change: opacity, transform;
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* ============ EMPLOYEE POPUP MODAL ============ */
.emp-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(44,39,48,0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
  padding: 20px;
}
.emp-modal-backdrop.active { opacity: 1; pointer-events: auto; }
.emp-modal {
  background: #fff;
  border-radius: 14px;
  padding: 36px 40px 30px;
  max-width: 520px;
  width: 100%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  position: relative;
  transform: scale(0.92) translateY(10px);
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
  max-height: 85vh;
  overflow-y: auto;
}
.emp-modal-backdrop.active .emp-modal { transform: scale(1) translateY(0); }
.emp-modal .close {
  position: absolute; top: 14px; right: 16px;
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--paper-deep);
  border: none; cursor: pointer;
  font-size: 18px; color: var(--muted);
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.emp-modal .close:hover { background: var(--brand-red); color: #fff; }
.emp-modal .emp-avatar {
  width: 80px; height: 80px; border-radius: 50%;
  background: var(--dept-color, var(--brand-red));
  color: #fff;
  margin: 0 auto 18px;
  display: flex; align-items: center; justify-content: center;
  font-size: 42px;
  box-shadow: 3px 6px 20px rgba(0,0,0,0.18);
}
.emp-modal .emp-name {
  font-family: '粒線體', sans-serif;
  font-size: 28px;
  color: var(--dept-color, var(--ink-deep));
  font-weight: 900;
  text-align: center;
  margin-bottom: 4px;
}
.emp-modal .emp-title {
  text-align: center;
  font-family: '金萱9', sans-serif;
  font-size: 13px;
  color: var(--brand-red);
  letter-spacing: 2px;
  margin-bottom: 18px;
}
.emp-modal .emp-bio {
  background: var(--paper-deep);
  border-radius: 8px;
  padding: 18px 22px;
  font-size: 14.5px;
  line-height: 1.9;
  color: var(--ink);
  margin-bottom: 18px;
}
.emp-modal .emp-bio p { margin-bottom: 12px; }
.emp-modal .emp-bio p:last-child { margin-bottom: 0; }
.emp-modal .emp-bio p.lead-line {
  font-family: '金萱9', sans-serif;
  color: var(--dept-color, var(--brand-red));
  font-size: 15px;
  font-weight: 700;
  line-height: 1.7;
  padding-bottom: 10px;
  border-bottom: 1px dashed rgba(0,0,0,0.14);
}
.emp-modal .emp-bio strong { color: var(--brand-red); font-weight: 700; }
.emp-modal .emp-section-title {
  font-family: '金萱9', sans-serif;
  font-size: 12.5px;
  color: var(--muted);
  letter-spacing: 3px;
  margin: 16px 0 10px;
}
.emp-modal .emp-skills-list {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.emp-modal .emp-skills-list .skill-tag {
  background: var(--paper-deep);
  color: var(--dept-color, var(--brand-red));
  padding: 5px 12px;
  border-radius: 99px;
  font-family: '金萱9', sans-serif;
  font-size: 12.5px;
  font-weight: 700;
}
.emp-modal .emp-tools {
  display: flex; flex-wrap: wrap; gap: 6px;
}

/* org-emp 加 hover 暗示可點 */
.org-emp {
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease;
}
.org-emp:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 6px 18px rgba(0,0,0,0.14);
}
.org-emp::after {
  content: '';
  position: absolute;
  right: 6px; top: 6px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--dept-color);
  opacity: 0;
  transition: opacity .2s;
}
.org-emp { position: relative; }
.org-emp:hover::after { opacity: 0.5; }

/* ============ TAB NAV（工作流切換） ============ */
.tab-nav {
  display: flex; gap: 4px;
  background: #fff;
  padding: 6px;
  border-radius: 14px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08), 0 6px 20px rgba(0,0,0,0.05);
  overflow-x: auto;
  scrollbar-width: none;
  margin: 28px 0 36px;
}
.tab-nav::-webkit-scrollbar { display: none; }
.tab-btn {
  padding: 12px 20px;
  border-radius: 10px;
  background: transparent;
  color: var(--muted);
  font-family: '金萱9', sans-serif;
  font-size: 14px;
  cursor: pointer;
  border: none;
  white-space: nowrap;
  transition: all .25s cubic-bezier(.2,.8,.2,1);
  display: flex; align-items: center; gap: 8px;
  flex-shrink: 0;
}
.tab-btn:hover { color: var(--ink-deep); background: var(--paper-deep); }
.tab-btn.active {
  background: var(--brand-purple);
  color: #fff;
  box-shadow: 2px 4px 10px rgba(76,69,138,0.3);
}
.tab-btn .num {
  font-family: '粒線體', sans-serif;
  font-weight: 900;
  opacity: 0.6;
}
.tab-btn.active .num { opacity: 1; }
.tab-panel { display: none; }
.tab-panel.active {
  display: block;
  animation: panelIn .4s cubic-bezier(.2,.8,.2,1);
}
@keyframes panelIn {
  from { opacity: 0; transform: translateX(24px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes gentlePulse {
  0%, 100% { box-shadow: 2px 4px 10px rgba(76,69,138,0.3); }
  50% { box-shadow: 2px 4px 20px rgba(76,69,138,0.55), 0 0 0 5px rgba(76,69,138,0.08); }
}
.tab-btn.active { animation: gentlePulse 2.8s ease-in-out infinite; }

/* ============ 彩虹漸層按鈕（完全 1:1 複製 heptabase-7-days-workshop）============
   Keyframes 來回動：100% → 0% → 100%，明顯看得到流動
   小腸 2026-04-24：漸層一定要動，靜止的很醜 */
@keyframes ctaGradient {
  /* 2026-04-27 統一品牌升級：對角線流動（配 135deg + 250% 250%） */
  0%   { background-position:   0% 0%; }
  50%  { background-position: 100% 100%; }
  100% { background-position:   0% 0%; }
}
@keyframes ctaScalePulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.03); }
}

/* 所有主要按鈕自動套彩虹：cta-btn / nav-cta / tap-hint / cta-rainbow
   例外：大卡片型 cta-btn（內部有 h4 或 tap-hint）不套，保留原卡片樣式 */
.cta-btn:not(:has(h4)):not(:has(.tap-hint)),
.nav-cta,
.tap-hint,
.cta-rainbow,
.site-footer .platforms a {
  /* 2026-04-27 統一品牌升級：135deg 斜向流動 + 250% bg-size */
  background: linear-gradient(135deg, #D14B63, #FF7C99, #F4B79C, #EBE79D, #FF7C99, #D14B63) !important;
  background-size: 250% 250% !important;
  color: #fff !important;
  animation: ctaGradient 6s linear infinite, ctaScalePulse 2.5s ease-in-out infinite !important;
  border-radius: 999px !important;
  box-shadow: 0 4px 14px rgba(209,75,99,0.25) !important;
  transition: filter .3s ease-in-out !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.15) !important;
  text-decoration: none !important;
}
.cta-btn:not(:has(h4)):not(:has(.tap-hint)):hover,
.nav-cta:hover,
.tap-hint:hover,
.cta-rainbow:hover,
.site-footer .platforms a:hover {
  filter: brightness(1.15) !important;
}

/* 大卡片型 cta-btn（含 h4 / tap-hint 的）→ 拍立得造型 */
.cta-btn:has(h4), .cta-btn:has(.tap-hint) {
  background: #fff !important;
  color: var(--ink-deep) !important;
  animation: none !important;
  border-radius: 2px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1), 0 8px 22px rgba(50,30,10,0.16), 2px 10px 28px rgba(50,30,10,0.12) !important;
  text-shadow: none !important;
  padding: 20px 18px 28px !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
  transform: rotate(-0.8deg);
  position: relative;
}
.cta-btn:has(h4):nth-child(3n+2),
.cta-btn:has(.tap-hint):nth-child(3n+2) { transform: rotate(0.9deg); }
.cta-btn:has(h4):nth-child(3n+3),
.cta-btn:has(.tap-hint):nth-child(3n+3) { transform: rotate(-0.4deg); }

/* 頂部紙膠帶裝飾（washi tape）*/
.cta-btn:has(h4)::before,
.cta-btn:has(.tap-hint)::before {
  content: '';
  position: absolute;
  top: -8px; left: 50%;
  width: 72px; height: 20px;
  transform: translateX(-50%) rotate(-3deg);
  background: rgba(209,75,99,0.28);
  z-index: 1;
}
.cta-btn:has(h4):nth-child(3n+2)::before,
.cta-btn:has(.tap-hint):nth-child(3n+2)::before {
  background: rgba(76,69,138,0.22);
  transform: translateX(-50%) rotate(2deg);
}
.cta-btn:has(h4):nth-child(3n+3)::before,
.cta-btn:has(.tap-hint):nth-child(3n+3)::before {
  background: rgba(249,168,37,0.3);
  transform: translateX(-50%) rotate(-1deg);
}

.cta-btn:has(h4):hover, .cta-btn:has(.tap-hint):hover {
  transform: rotate(0deg) translateY(-4px) scale(1.02) !important;
  box-shadow: 0 3px 8px rgba(0,0,0,0.12), 0 14px 30px rgba(50,30,10,0.2), 3px 14px 36px rgba(50,30,10,0.16) !important;
  filter: none !important;
  z-index: 2;
}
.cta-btn:has(h4) h4,
.cta-btn:has(.tap-hint) h4 {
  color: var(--brand-purple) !important;
  text-shadow: none !important;
  font-family: '金萱9', '金萱那提-thick', sans-serif !important;
}
.cta-btn:has(h4) p,
.cta-btn:has(.tap-hint) p {
  color: var(--ink) !important;
  text-shadow: none !important;
}

/* CTA Section 去外框 — 小腸：紙質底上不要再套一層框 */
.cta-section {
  background: transparent !important;
  box-shadow: none !important;
  padding: 40px 0 !important;
  overflow: visible !important;
}
.cta-grid {
  padding: 30px 4px 30px !important;  /* 上方多給空間讓紙膠帶露出 */
  gap: 28px !important;
  overflow: visible !important;
}

/* 確保 cta-btn 本體跟 ::before 膠帶不被父層切掉 */
.cta-btn:has(h4), .cta-btn:has(.tap-hint) {
  overflow: visible !important;
}
.cta-btn:has(h4)::before,
.cta-btn:has(.tap-hint)::before {
  top: -10px !important;
  z-index: 3 !important;
}

/* ============ 員工彈窗觸發元素（真正可點的 chip）============
   小腸 2026-04-24 反饋：只在「真的可點」的地方做動畫
   .fnode / .night-note / .mt-step 視覺上是資訊卡片，動畫會讓頁面很亂 → 關掉 */
@keyframes empChipPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 2px 6px rgba(0,0,0,0.08); }
  50% { transform: scale(1.04); box-shadow: 0 4px 14px rgba(209,75,99,0.25), 0 0 0 3px rgba(209,75,99,0.08); }
}
.org-emp, .org-ceo, .org-chief, .org-advisors {
  cursor: pointer;
  animation: empChipPulse 3.2s ease-in-out infinite;
  transition: transform .2s ease, box-shadow .2s ease;
}
.org-ceo { animation-delay: 0s; }
.org-chief { animation-delay: .3s; }
.org-advisors { animation-delay: .6s; }
.org-emp:nth-child(1) { animation-delay: 0s; }
.org-emp:nth-child(2) { animation-delay: .3s; }
.org-emp:nth-child(3) { animation-delay: .6s; }
.org-emp:nth-child(4) { animation-delay: .9s; }
.org-emp:nth-child(5) { animation-delay: 1.2s; }
.org-emp:nth-child(6) { animation-delay: 1.5s; }
.org-emp:nth-child(7) { animation-delay: 1.8s; }
.org-emp:nth-child(8) { animation-delay: 2.1s; }
.org-emp:nth-child(9) { animation-delay: 2.4s; }
.org-emp:nth-child(10) { animation-delay: 2.7s; }
.org-emp:hover, .org-ceo:hover, .org-chief:hover, .org-advisors:hover {
  transform: scale(1.06);
  animation-play-state: paused;
}

/* ============ 晚安 12 步驟箭頭：SVG 虛線太醜，隱藏 ============ */
.night-spine-svg { display: none !important; }

/* 每張便條紙底部加向下/向右小箭頭暗示流向（不擋文字） */
.night-note::after {
  content: '→';
  position: absolute;
  right: 10px; bottom: 6px;
  font-family: '粒線體', sans-serif;
  font-size: 22px;
  color: rgba(209,75,99,0.55);
  font-weight: 900;
}
/* 每行最後一張（第 4、8 個）：向下箭頭（進入下一行） */
.night-grid .night-note:nth-child(4n)::after { content: '↓'; }
/* 最後一張（第 12）：不加箭頭 */
.night-grid .night-note:last-child::after { content: ''; }

/* 尊重使用者「減少動態效果」偏好 */
@media (prefers-reduced-motion: reduce) {
  .tab-btn.active, .cta-btn, .tap-hint, .nav-cta,
  .site-footer .platforms a,
  .org-emp, .org-ceo, .org-chief, .org-advisors,
  .cta-rainbow {
    animation: none !important;
  }
}

/* ============ FLOW STAGE（大流程節點圖） ============ */
.flow-stage {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 24px 40px;
  margin: 30px 0;
  position: relative;
}
.flow-stage.cols-3 { grid-template-columns: repeat(3, 1fr); }
.flow-stage.cols-4 { grid-template-columns: repeat(4, 1fr); }
.flow-stage.cols-5 { grid-template-columns: repeat(5, 1fr); }

.stage-node {
  background: #fff;
  border-radius: 12px;
  padding: 20px 16px 18px;
  text-align: center;
  box-shadow: 0 3px 12px rgba(0,0,0,0.08), 0 10px 24px rgba(0,0,0,0.05);
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
}
.stage-node:hover {
  transform: translateY(-4px);
  box-shadow: 0 5px 16px rgba(0,0,0,0.1), 0 16px 34px rgba(0,0,0,0.1);
}
.stage-node .step-num {
  position: absolute;
  top: -14px; left: -12px;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--brand-red);
  color: #fff;
  font-family: '粒線體', sans-serif;
  font-size: 15px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 2px 3px 8px rgba(209,75,99,0.3);
}
.stage-node .node-ic {
  width: 60px; height: 60px;
  margin: 0 auto 12px;
  border-radius: 14px;
  background: var(--node-bg, var(--paper-deep));
  color: var(--node-color, var(--brand-red));
  display: flex; align-items: center; justify-content: center;
  font-size: 30px;
  box-shadow: 2px 3px 8px rgba(0,0,0,0.08);
}
.stage-node h4 {
  font-family: '金萱9', sans-serif;
  font-size: 15px;
  color: var(--node-color, var(--ink-deep));
  font-weight: 700;
  margin-bottom: 4px;
}
.stage-node .desc {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.6;
  min-height: 38px;
}
.stage-arrow {
  display: flex; align-items: center; justify-content: center;
  font-family: '粒線體', sans-serif;
  font-size: 28px;
  color: var(--brand-red);
  opacity: 0.6;
  font-weight: 900;
}

/* 流程主結果（終點大卡） */
.flow-result {
  background: linear-gradient(135deg, var(--brand-red), #b93a50);
  color: #fff;
  padding: 26px 32px;
  border-radius: 14px;
  text-align: center;
  box-shadow: 0 8px 28px rgba(209,75,99,0.28);
  margin: 28px auto;
  max-width: 620px;
}
.flow-result .label {
  font-family: '金萱9', sans-serif;
  font-size: 11.5px;
  letter-spacing: 4px;
  opacity: 0.85;
  margin-bottom: 6px;
}
.flow-result .title {
  font-family: '粒線體', sans-serif;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: 0.5px;
}

/* 工作流 tab hero（上方顯示名稱+觸發詞） */
.wf-hero {
  background: #fff;
  border-radius: 14px;
  padding: 28px 32px;
  margin-bottom: 28px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06), 0 8px 20px rgba(0,0,0,0.04);
  display: flex; align-items: center; gap: 22px;
}
.wf-hero .wf-ic {
  width: 64px; height: 64px; flex-shrink: 0;
  background: var(--wf-color, var(--brand-red));
  color: #fff;
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px;
  box-shadow: 3px 5px 14px rgba(0,0,0,0.15);
}
.wf-hero h3 {
  font-family: '粒線體', sans-serif;
  font-size: 26px;
  color: var(--wf-color, var(--ink-deep));
  font-weight: 900;
  margin-bottom: 4px;
  letter-spacing: 0.5px;
}
.wf-hero .trig {
  font-size: 13px;
  color: var(--muted);
  font-family: '金萱9', sans-serif;
}
.wf-hero .trig code {
  background: var(--paper-deep);
  color: var(--wf-color, var(--brand-red));
  padding: 2px 8px;
  border-radius: 4px;
}

/* ============ 更大留白 ============ */
.section { margin-top: 96px; }
.notebook > .section:first-child { margin-top: 40px; }

/* ============ SVG 手繪流程圖 ============ */
.flow-canvas {
  position: relative;
  background: #fffdf8;
  background-image:
    linear-gradient(#f0ead8 1px, transparent 1px),
    linear-gradient(90deg, #f0ead8 1px, transparent 1px);
  background-size: 28px 28px;
  background-position: -1px -1px;
  border: 1.5px solid #e8dfc4;
  border-radius: 14px;
  padding: 20px 18px 28px;
  margin: 24px 0 18px;
  box-shadow:
    0 3px 14px rgba(0,0,0,0.08),
    inset 0 0 0 6px rgba(255,255,255,0.6);
  overflow: visible;
}
.flow-canvas::before {
  content: "";
  position: absolute;
  top: -10px; left: 28px;
  width: 120px; height: 22px;
  background: rgba(255, 232, 140, 0.65);
  border-radius: 3px;
  transform: rotate(-1.5deg);
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
  pointer-events: none;
}
.flow-svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
}
.flow-svg .fpath {
  fill: none;
  stroke-width: 2.2;
  opacity: 0.72;
  stroke-linecap: round;
}
.flow-svg .fpath.dashed {
  stroke-dasharray: 6 5;
  opacity: 0.62;
}
.flow-svg .flane-label {
  font-family: '金萱9', '金萱', 'PingFang TC', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  fill: #8a7a55;
  opacity: 0.9;
}
.fnode {
  background: var(--nbg, #fff);
  color: var(--nc, #333);
  border: 1.8px solid var(--nc, #333);
  border-radius: 12px;
  padding: 8px 10px;
  text-align: center;
  box-shadow: 0 2px 6px rgba(0,0,0,0.10), 0 0 0 2px rgba(255,255,255,0.7) inset;
  height: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-family: '金萱9', '金萱', 'PingFang TC', sans-serif;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.fnode:hover {
  transform: translateY(-2px) rotate(-0.4deg);
  box-shadow: 0 6px 16px rgba(0,0,0,0.16), 0 0 0 2px rgba(255,255,255,0.7) inset;
}
.fnode-ic {
  font-size: 22px;
  line-height: 1;
  margin-bottom: 3px;
}
.fnode-label {
  font-size: 13px;
  color: var(--nc);
  font-weight: 800;
  line-height: 1.3;
}
.fnode-label small {
  display: block;
  font-size: 10.5px;
  color: var(--nc);
  opacity: 0.72;
  font-weight: 500;
  margin-top: 2px;
  letter-spacing: 0.3px;
}
.fnode.terminal {
  background: var(--nc);
  color: #fff;
  border-color: var(--nc);
  border-radius: 14px;
  box-shadow: 0 5px 16px rgba(0,0,0,0.22);
}
.fnode.terminal .fnode-label,
.fnode.terminal .fnode-label small { color: #fff; opacity: 1; }
.fnode.terminal .fnode-label small { opacity: 0.85; }
.fnode.diamond {
  border-radius: 50%;
  padding: 6px;
}
.fnode.trigger {
  background: #fff7d6;
  border-style: dashed;
  border-width: 2px;
}
.flow-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-top: 8px;
  font-family: '金萱9', 'PingFang TC', sans-serif;
  font-size: 12px;
  color: #6b6358;
  padding: 10px 14px;
  background: rgba(255,255,255,0.6);
  border-radius: 8px;
}
.flow-legend .lg-dot {
  display: inline-block;
  width: 14px; height: 14px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: 6px;
  border: 2px solid rgba(0,0,0,0.15);
}
.flow-legend .lg-line {
  display: inline-block;
  width: 22px; height: 0;
  border-top: 2.5px solid currentColor;
  vertical-align: middle;
  margin-right: 6px;
  opacity: 0.75;
}
.flow-legend .lg-line.dashed {
  border-top-style: dashed;
}

/* ============ 明顯點擊按鈕提示 ============ */
.tap-hint {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--brand-red);
  color: #fff;
  padding: 10px 22px;
  border-radius: 99px;
  font-family: '金萱9', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  box-shadow: 2px 4px 12px rgba(209,75,99,0.35);
  transition: transform .2s ease, box-shadow .2s ease;
  margin-top: 14px;
}
.cta-btn:hover .tap-hint,
a:hover .tap-hint {
  transform: translateX(4px);
  box-shadow: 3px 6px 16px rgba(209,75,99,0.5);
}
.tap-hint.purple { background: var(--brand-purple); box-shadow: 2px 4px 12px rgba(76,69,138,0.35); }
.tap-hint.purple:hover,
a:hover .tap-hint.purple { box-shadow: 3px 6px 16px rgba(76,69,138,0.5); }
.tap-hint.green { background: var(--brand-green); box-shadow: 2px 4px 12px rgba(82,183,136,0.35); }
.tap-hint .finger { font-size: 18px; }

/* cta-btn 點擊感強化 */
.cta-btn {
  cursor: pointer;
}
.cta-btn:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 22px rgba(0,0,0,0.12), 0 16px 36px rgba(0,0,0,0.12);
}

/* ============ 晚安 12 步便條紙 Grid ============ */
.night-flow-wrap {
  position: relative;
}
.night-spine-svg {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 2;
  overflow: visible;
}
.night-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin: 28px 0;
  position: relative;
  z-index: 1;
}
.night-note {
  padding: 20px 18px 18px;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08), 0 8px 22px rgba(0,0,0,0.08);
  min-height: 158px;
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
  background: var(--note-yellow);
}
.night-note:nth-child(4n+1) { background: #FFF6C9; transform: rotate(-1deg); }
.night-note:nth-child(4n+2) { background: #FAE4D4; transform: rotate(0.7deg); }
.night-note:nth-child(4n+3) { background: #D6EBD6; transform: rotate(-0.5deg); }
.night-note:nth-child(4n+4) { background: #E5DBF5; transform: rotate(0.5deg); }
.night-note:hover {
  transform: rotate(0) translateY(-4px) scale(1.03);
  box-shadow: 0 4px 14px rgba(0,0,0,0.14), 0 14px 32px rgba(0,0,0,0.14);
  z-index: 2;
}
.night-note::before {
  content: '';
  position: absolute;
  top: -8px; left: 50%;
  width: 46px; height: 14px;
  transform: translateX(-50%) rotate(-3deg);
  background: rgba(209,75,99,0.32);
}
.night-note:nth-child(4n+2)::before { background: rgba(204,120,92,0.32); transform: translateX(-50%) rotate(3deg); }
.night-note:nth-child(4n+3)::before { background: rgba(82,183,136,0.4); transform: translateX(-50%) rotate(-2deg); }
.night-note:nth-child(4n+4)::before { background: rgba(124,58,237,0.32); transform: translateX(-50%) rotate(2deg); }
.night-note .step-n {
  font-family: '粒線體', sans-serif;
  font-size: 54px;
  font-weight: 900;
  color: var(--brand-red);
  line-height: 1;
  opacity: 0.18;
  position: absolute;
  top: 14px; right: 16px;
}
.night-note .step-ic {
  font-size: 28px;
  margin-bottom: 8px;
  display: block;
}
.night-note .step-ttl {
  font-family: '金萱9', sans-serif;
  font-size: 15px;
  color: var(--ink-deep);
  font-weight: 700;
  margin-bottom: 6px;
}
.night-note .step-desc {
  font-size: 12.5px;
  line-height: 1.65;
  color: var(--ink);
}

/* ============ 開工 5 階段時間軸（橫向） ============ */
.morning-timeline {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin: 30px 0;
  position: relative;
}
.morning-timeline::before {
  content: '';
  position: absolute;
  top: 38px; left: 10%; right: 10%;
  height: 2px;
  background: linear-gradient(90deg, #d14b63 0%, #4C458A 100%);
  opacity: 0.35;
  z-index: 0;
}
.mt-step {
  background: #fff;
  border-radius: 10px;
  padding: 20px 14px 18px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  text-align: center;
  position: relative;
  z-index: 1;
  transition: transform .2s;
}
.mt-step:hover { transform: translateY(-5px); box-shadow: 0 8px 22px rgba(0,0,0,0.18); animation-play-state: paused; }
.mt-step .mt-dot {
  width: 54px; height: 54px;
  border-radius: 50%;
  background: var(--brand-red);
  color: #fff;
  margin: 0 auto 12px;
  display: flex; align-items: center; justify-content: center;
  font-family: '粒線體', sans-serif;
  font-size: 22px; font-weight: 900;
  box-shadow: 2px 4px 10px rgba(209,75,99,0.3);
}
.mt-step:nth-child(2) .mt-dot { background: #CC785C; box-shadow: 2px 4px 10px rgba(204,120,92,0.3); }
.mt-step:nth-child(3) .mt-dot { background: var(--brand-yellow-edge); box-shadow: 2px 4px 10px rgba(245,166,35,0.3); }
.mt-step:nth-child(4) .mt-dot { background: var(--brand-purple); box-shadow: 2px 4px 10px rgba(76,69,138,0.3); }
.mt-step:nth-child(5) .mt-dot { background: var(--brand-green); box-shadow: 2px 4px 10px rgba(82,183,136,0.3); }
.mt-step h4 {
  font-family: '金萱9', sans-serif;
  font-size: 14px; color: var(--ink-deep);
  font-weight: 700; margin-bottom: 4px;
}
.mt-step p { font-size: 12px; line-height: 1.65; color: var(--muted); }

/* ============ 金字塔視覺（週復盤三層） ============ */
.pyramid {
  max-width: 760px;
  margin: 30px auto;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.pyramid-lv {
  border-radius: 14px;
  padding: 22px 28px;
  box-shadow: 0 3px 12px rgba(0,0,0,0.08);
  display: flex; align-items: center; gap: 22px;
  transition: transform .2s;
}
.pyramid-lv:hover { transform: translateY(-3px); box-shadow: 0 6px 20px rgba(0,0,0,0.14); }
.pyramid-lv.l1 { width: 70%; background: #FFF6C9; }
.pyramid-lv.l2 { width: 85%; background: #FAE4D4; }
.pyramid-lv.l3 { width: 100%; background: #D6EBD6; }
.pyramid-lv .lv-num {
  font-family: '粒線體', sans-serif;
  font-size: 44px; font-weight: 900;
  color: var(--brand-red);
  flex-shrink: 0;
  line-height: 1;
  width: 60px; text-align: center;
}
.pyramid-lv.l2 .lv-num { color: #a04b30; }
.pyramid-lv.l3 .lv-num { color: #2d8659; }
.pyramid-lv .lv-body { flex: 1; }
.pyramid-lv h4 {
  font-family: '金萱9', sans-serif;
  font-size: 17px; color: var(--ink-deep);
  font-weight: 700; margin-bottom: 6px;
}
.pyramid-lv .lv-items {
  font-size: 13.5px; color: var(--ink);
  line-height: 1.8;
  display: flex; flex-wrap: wrap; gap: 6px 14px;
}
.pyramid-lv .lv-items span { white-space: nowrap; }

/* ============ 訓練 AI 三步流程 ============ */
.train-flow {
  display: grid;
  grid-template-columns: 1fr 44px 1fr 44px 1fr;
  gap: 8px;
  align-items: stretch;
  margin: 30px 0;
}
.train-step {
  background: #fff;
  border-radius: 14px;
  padding: 28px 22px 24px;
  text-align: center;
  box-shadow: 0 3px 12px rgba(0,0,0,0.08), 0 10px 24px rgba(0,0,0,0.06);
  position: relative;
  transition: transform .2s ease, box-shadow .2s ease;
}
.train-step:hover { transform: translateY(-4px); box-shadow: 0 5px 16px rgba(0,0,0,0.12), 0 16px 34px rgba(0,0,0,0.1); }
.train-step .ic-big {
  width: 68px; height: 68px; border-radius: 50%;
  background: var(--brand-red);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 30px;
  margin: 0 auto 16px;
  box-shadow: 2px 4px 12px rgba(209,75,99,0.3);
}
.train-step:nth-child(3) .ic-big { background: var(--brand-yellow-edge); box-shadow: 2px 4px 12px rgba(245,166,35,0.3); }
.train-step:nth-child(5) .ic-big { background: var(--brand-green); box-shadow: 2px 4px 12px rgba(82,183,136,0.3); }
.train-step h4 {
  font-family: '粒線體', sans-serif;
  font-size: 19px; color: var(--ink-deep); font-weight: 900;
  margin-bottom: 10px;
  letter-spacing: 0.5px;
}
.train-step p { font-size: 13.5px; color: var(--ink); line-height: 1.8; }
.train-arr {
  display: flex; align-items: center; justify-content: center;
  font-family: '粒線體', sans-serif;
  font-size: 32px; color: var(--brand-red);
  font-weight: 900;
  opacity: 0.6;
}

/* ============ Skill 5 大類 hero 卡（比原 tool-card 更有視覺衝擊） ============ */
.skill-cat-hero {
  background: #fff;
  border-radius: 14px;
  padding: 30px 32px 24px;
  box-shadow: 0 3px 12px rgba(0,0,0,0.07), 0 10px 26px rgba(0,0,0,0.05);
  margin-bottom: 22px;
  position: relative;
  transition: transform .25s;
}
.skill-cat-hero:hover { transform: translateY(-3px); box-shadow: 0 5px 16px rgba(0,0,0,0.1), 0 14px 32px rgba(0,0,0,0.08); }
.skill-cat-hero .cat-head {
  display: flex; align-items: center; gap: 18px; margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px dashed rgba(0,0,0,0.12);
}
.skill-cat-hero .cat-emoji {
  width: 62px; height: 62px; border-radius: 14px;
  background: var(--cat-bg, #fff3cd);
  color: var(--cat-color, #d14b63);
  display: flex; align-items: center; justify-content: center;
  font-size: 32px;
  flex-shrink: 0;
  box-shadow: 2px 4px 10px rgba(0,0,0,0.08);
}
.skill-cat-hero .cat-meta { flex: 1; }
.skill-cat-hero .cat-name {
  font-family: '粒線體', sans-serif;
  font-size: 22px; font-weight: 900;
  color: var(--cat-color, #d14b63);
  margin-bottom: 2px;
}
.skill-cat-hero .cat-sub {
  font-size: 13px; color: var(--muted);
  font-family: '金萱9', sans-serif;
}
.skill-cat-hero .cat-count {
  font-family: '粒線體', sans-serif;
  font-size: 40px; font-weight: 900;
  color: var(--cat-color, #d14b63);
  opacity: 0.25;
  line-height: 1;
  align-self: flex-start;
}
.skill-cat-hero .cat-desc { font-size: 14.5px; color: var(--ink); line-height: 1.85; margin-bottom: 14px; }
.skill-cat-hero .skill-pills { display: flex; flex-wrap: wrap; gap: 7px; }
.skill-cat-hero .skill-pill {
  background: var(--cat-bg, #fff3cd);
  color: var(--cat-color, #d14b63);
  padding: 6px 14px;
  border-radius: 99px;
  font-family: 'SF Mono', Menlo, monospace;
  font-size: 12.5px;
  font-weight: 600;
  transition: transform .15s;
}
.skill-cat-hero .skill-pill:hover { transform: scale(1.05); }

/* ============ 對比雙卡（WAM vs 季度盤點） ============ */
.vs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin: 28px 0; }
.vs-card {
  background: #fff;
  border-radius: 12px;
  padding: 26px 28px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06), 0 8px 22px rgba(0,0,0,0.06);
  position: relative;
}
.vs-card .vs-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 16px;
}
.vs-card .vs-ic {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--vs-bg, #fff3cd);
  color: var(--vs-c, #d14b63);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
}
.vs-card h4 {
  font-family: '粒線體', sans-serif;
  font-size: 20px; color: var(--vs-c, #d14b63);
  font-weight: 900;
}
.vs-card .vs-row {
  display: flex; gap: 12px;
  padding: 10px 0;
  border-bottom: 1px dashed rgba(0,0,0,0.1);
  font-size: 13.5px;
}
.vs-card .vs-row:last-child { border-bottom: none; }
.vs-card .vs-row .k {
  font-family: '金萱9', sans-serif; font-weight: 700;
  color: var(--muted);
  min-width: 72px;
  flex-shrink: 0;
}
.vs-card .vs-row .v { color: var(--ink); flex: 1; }

/* ============ RESPONSIVE ============ */
@media (max-width: 1000px) {
  .night-grid { grid-template-columns: repeat(2, 1fr); }
  .morning-timeline { grid-template-columns: repeat(5, 1fr); gap: 8px; }
  .morning-timeline .mt-step p { font-size: 11px; }
  .vs-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1000px) {
  .flow-stage.cols-3,
  .flow-stage.cols-4,
  .flow-stage.cols-5 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .night-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .morning-timeline { grid-template-columns: 1fr; }
  .morning-timeline::before { display: none; }
  .pyramid-lv.l1, .pyramid-lv.l2 { width: 100%; }
  .train-flow { grid-template-columns: 1fr; }
  .train-arr { transform: rotate(90deg); padding: 8px 0; font-size: 24px; }
  .skill-cat-hero { padding: 22px 20px 18px; }
  .skill-cat-hero .cat-head { gap: 14px; }
  .skill-cat-hero .cat-emoji { width: 52px; height: 52px; font-size: 26px; }
  .skill-cat-hero .cat-count { font-size: 32px; }
  .flow-canvas { padding: 14px 8px 20px; }
  .flow-canvas::before { left: 16px; width: 88px; height: 18px; }
  .fnode-label { font-size: 11.5px; }
  .fnode-label small { font-size: 9.5px; }
  .fnode-ic { font-size: 18px; }
  .chang-bubble { margin: 40px auto; }
  .chang-bubble .bubble { padding: 14px 18px; font-size: 14.5px; }
  .wf-hero { flex-direction: column; text-align: center; padding: 22px; }
  .tab-nav { margin: 20px 0 24px; }
  .tab-btn { padding: 10px 14px; font-size: 13px; }
  .emp-modal { padding: 30px 24px 24px; }
  .section { margin-top: 64px; }
  .notebook { padding: 40px 22px 50px 60px; border-radius: 0; }
  .notebook::before { left: 14px; width: 14px; }
  .notebook table { font-size: 12.5px; }
  .notebook table th, .notebook table td { padding: 8px 10px; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .memo-stats { grid-template-columns: repeat(2, 1fr); }
  .flow-row { grid-template-columns: 1fr; }
  .flow-arr { transform: rotate(90deg); }
  .cta-grid { grid-template-columns: 1fr; }
  .section .lead { margin-left: 0; }
  .hero-split { grid-template-columns: 1fr; gap: 30px; }
  .hero-split .hero-photo { max-width: 280px; margin: 0 auto; }
  .hero-split .hero-text h1 { text-align: center; }
  .hero-split .hero-text .sub { text-align: center; }
  .about-hero { grid-template-columns: 1fr; gap: 28px; }
  .about-hero .photo-card { max-width: 300px; margin: 0 auto; }
  .photo-wall { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .org-depts { grid-template-columns: repeat(2, 1fr); }
  .org-depts-wrap::after { display: none; }
  .org-mid { flex-direction: column; gap: 20px; align-items: center; }
  .org-mid::after { display: none; }
  .nav-inner { padding: 10px 14px; }
  .nav-brand { font-size: 15px; }
  .nav-brand img { height: 28px; }
  .nav-links a { padding: 6px 10px; font-size: 12.5px; }
  .nav-cta { padding: 6px 14px; font-size: 12.5px; }
}

/* ===================================================================
   2026-04-24 小腸深夜反饋：整體美化
   - 組織圖配色統一（米底 + 頂色條，不再整張實心花色）
   - 員工 icon size 放大
   - 引用框瘦身（紙質底上減少框）
   - 標題螢光筆風格優先
   =================================================================== */

/* 1. 組織圖｜處室標題：實心色底（小腸確認保留），去掉旋轉和膠帶 */
.org-dept-head {
  background: var(--dept-color, var(--brand-red)) !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12) !important;
  border-radius: 4px !important;
  transform: none !important;
  padding: 12px 6px 10px !important;
}
.org-dept-head::before { display: none !important; }
.org-dept-head .no {
  color: rgba(255,255,255,0.7) !important;
  font-size: 13px !important;
}
.org-dept-head .nm {
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

/* 2. 組織圖｜員工卡：更乾淨，icon 大一點，白底換淡米 */
.org-emp {
  background: #FDFBF4 !important;
  border-top: 2px solid var(--dept-color, var(--brand-red)) !important;
  border-radius: 3px !important;
  transform: none !important;
  padding: 10px 10px 8px 12px !important;
}
.org-emp:nth-child(even) { transform: none !important; }
.org-emp .en {
  font-size: 13.5px !important;
  gap: 6px !important;
}
.org-emp .en .ic { font-size: 18px !important; }
.org-emp .et {
  font-size: 10.5px !important;
  opacity: 0.7 !important;
}

/* 3. 組織圖｜dept 配色統一到品牌 5 色（取代雜牌紫紫紫橘洋紅） */
.dept-0 { --dept-color: #4C458A; --dept-bg: #FDFBF4; }  /* 生活 紫 */
.dept-7 { --dept-color: #D14B63; --dept-bg: #FDFBF4; }  /* 總部 紅 */
.dept-1 { --dept-color: #CC785C; --dept-bg: #FDFBF4; }  /* 行政 磚橘 */
.dept-2 { --dept-color: #D14B63; --dept-bg: #FDFBF4; }  /* 業務 紅 */
.dept-3 { --dept-color: #E1A300; --dept-bg: #FDFBF4; }  /* 財務 金黃 */
.dept-4 { --dept-color: #4C458A; --dept-bg: #FDFBF4; }  /* 技術 紫 */
.dept-5 { --dept-color: #52B788; --dept-bg: #FDFBF4; }  /* 審核 綠 */
.dept-6 { --dept-color: #D14B63; --dept-bg: #FDFBF4; }  /* 公關 紅 */

/* CEO / Chief / Advisors：統一品牌風格 */
.org-chief, .org-advisors {
  background: #FDFBF4 !important;
  border-top: 4px solid var(--brand-red) !important;
  color: var(--ink-deep) !important;
  box-shadow: 0 3px 10px rgba(0,0,0,0.1) !important;
}
.org-advisors { border-top-color: var(--brand-purple) !important; }
.org-chief .nm, .org-advisors .nm { color: var(--ink-deep) !important; }
.org-chief .rl, .org-advisors .rl { color: var(--muted) !important; }
.org-chief::before, .org-advisors::before { display: none !important; }

/* 4. 引用框瘦身｜bulb-card（小腸永久硬規則：不可使用 border-left 左色條）*/
.bulb-card {
  background: transparent !important;
  padding: 10px 0 10px 38px !important;
  box-shadow: none !important;
  border-left: none !important;
  border-radius: 0 !important;
  margin: 20px 0 !important;
  position: relative;
}
.bulb-card::before {
  content: '💡' !important;
  display: block !important;
  position: absolute !important;
  left: 0; top: 10px;
  font-size: 20px !important;
  background: none !important;
  width: auto !important;
  height: auto !important;
  opacity: 1 !important;
}

/* 5. Callout 瘦身（小腸永久硬規則：不可使用 border-left） */
.callout {
  background: transparent !important;
  box-shadow: none !important;
  border-left: none !important;
  padding: 8px 0 8px 42px !important;
  border-radius: 0 !important;
  margin: 18px 0 !important;
}
.callout::before {
  left: 14px !important;
  top: 6px !important;
  font-size: 18px !important;
}
.callout.quiet {
  background: transparent !important;
}
.callout.quiet::before { left: 14px !important; top: 8px !important; }

/* 6. 螢光筆強化（小腸愛的風格：直接底色螢光打在字上）
   註：只對 h2 / h3 / p 裡的 .hl 套螢光筆，manifesto 和 page-title 的 .hl 保留各自色樣 */
.section h2 .hl,
.section h3 .hl,
p .hl:not(.hl-red):not(.hl-purple):not(.hl-orange) {
  background: linear-gradient(180deg, transparent 60%, #EBE79D 60%, #EBE79D 95%, transparent 95%) !important;
  padding: 0 3px !important;
}

/* 7. 手機版組織圖改 2 欄（原本 8 欄擠爆） */
@media (max-width: 780px) {
  .org-depts { grid-template-columns: repeat(2, 1fr) !important; }
  .org-dept-head { padding: 8px 4px !important; }
  .org-dept-head .nm { font-size: 12px !important; }
}

/* ===================================================================
   2026-04-24 參考 wall-of-love 設計優化：
   接下來去哪看 / 5 個專題頁 / 工具地圖 / 工作流 / 儀式系統
   =================================================================== */

/* 1. section num 漸層字（紅→紫，雜誌感） */
.section-head .num {
  background: linear-gradient(135deg, var(--brand-red) 0%, var(--brand-purple) 100%);
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  color: transparent !important;
  font-size: 52px !important;
  letter-spacing: -2px;
}

/* 2. tool-card：加左上紙膠帶（wall-of-love review-card 風格） */
.tool-card {
  overflow: visible !important;
  transition: transform .3s ease, box-shadow .3s ease !important;
}
.tool-card::before {
  content: '';
  position: absolute;
  top: -9px; left: 22px;
  width: 58px; height: 18px;
  background: rgba(209,75,99,0.55);
  border-radius: 1px;
  transform: rotate(-3deg);
  background-image: repeating-linear-gradient(
    90deg, transparent, transparent 4px,
    rgba(255,255,255,0.2) 4px, rgba(255,255,255,0.2) 5px
  );
  box-shadow: 0 1px 3px rgba(0,0,0,0.12);
  z-index: 2;
}
/* 錯開不同卡片的膠帶色 + 角度 */
.tool-card:nth-child(4n+2)::before { background-color: rgba(76,69,138,0.5); transform: rotate(2deg); left: auto; right: 22px; }
.tool-card:nth-child(4n+3)::before { background-color: rgba(235,231,157,0.85); transform: rotate(-1deg); }
.tool-card:nth-child(4n+4)::before { background-color: rgba(82,183,136,0.5); transform: rotate(3deg); left: auto; right: 28px; }

.tool-card:hover {
  transform: rotate(0deg) translateY(-6px) scale(1.015) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12), 0 16px 40px rgba(0,0,0,0.1) !important;
  z-index: 3;
}

/* 3. 專題頁 4 張大卡（.grid-2 裡的 tool-card）標題放大 + 漸層字 */
.grid-2 > .tool-card .head h4 {
  font-size: 22px !important;
  letter-spacing: 1px !important;
}
.grid-2 > .tool-card .head .ic {
  width: 52px !important; height: 52px !important;
  font-size: 26px !important;
}
.grid-2 > .tool-card .head .cat {
  background: linear-gradient(90deg, var(--tool-color, var(--brand-red)), var(--brand-purple));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 900 !important;
  font-size: 11.5px !important;
}
.grid-2 > .tool-card .use {
  font-size: 14.5px !important;
  line-height: 1.8 !important;
  color: var(--ink) !important;
  margin: 4px 0 10px;
}
.grid-2 > .tool-card .owner {
  font-size: 12px !important;
  color: var(--muted) !important;
  line-height: 1.6 !important;
  padding-top: 10px;
  border-top: 1px dashed rgba(0,0,0,0.12);
}

/* 4. lead 文字重新設計 — 更有雜誌標語感 */
.section > .lead {
  font-family: '金萱9', sans-serif;
  font-size: 15.5px;
  color: var(--ink);
  max-width: 640px;
  margin: 0 0 28px 58px;
  line-height: 1.9;
  letter-spacing: 0.5px;
  position: relative;
}
.section > .lead::before {
  content: '';
  position: absolute;
  left: -28px; top: 12px;
  width: 18px; height: 2px;
  background: var(--brand-red);
}

/* 5. sitemap h3 分類標題加裝飾（⸺ TITLE ⸺） */
#sitemap h3 {
  text-align: center;
  position: relative;
}
#sitemap h3::before, #sitemap h3::after {
  content: '⸺';
  opacity: 0.4;
  margin: 0 10px;
  font-weight: 400;
}

/* 6. hover 時膠帶稍微抬高呼應 */
.tool-card:hover::before {
  transform: rotate(0deg) translateY(-2px);
  transition: transform .3s ease;
}

/* ===================================================================
   2026-04-24 Sitemap 三區分造型 + 全站留白強化
   =================================================================== */

/* 全站：section / h2 / h3 呼吸空間強化 */
.section { margin-top: 110px !important; }
.section-head { margin-bottom: 18px !important; }
.section > .lead { margin-bottom: 44px !important; }

/* Sitemap 區塊之間的大型留白 */
#sitemap .sm-group-ttl {
  font-family: '金萱9', sans-serif;
  font-size: 14px;
  letter-spacing: 3px;
  margin: 72px 0 28px !important;
  text-align: center;
}
/* 第一個分組不需要那麼大上 margin（緊接 section-head） */
#sitemap .sm-group-ttl:first-of-type { margin-top: 12px !important; }

/* Grid 本身也給一點 padding-top 讓膠帶/便利貼露出 */
#sitemap .grid-3, #sitemap .grid-4 {
  padding-top: 16px;
  margin-bottom: 20px;
}

/* === 區 1：便利貼造型（黃色底 + 歪斜 + 無紙膠帶） === */
.sm-sticky .tool-card::before { display: none !important; }
.sm-sticky .tool-card {
  background: #FFF6C9 !important;
  box-shadow: 2px 3px 8px rgba(150,110,30,0.18), 0 8px 18px rgba(150,110,30,0.1) !important;
  border-radius: 3px !important;
  transform: rotate(-1deg);
}
.sm-sticky .tool-card:nth-child(2) { background: #FAE4D4 !important; transform: rotate(0.8deg); }
.sm-sticky .tool-card:nth-child(3) { background: #D6EBD6 !important; transform: rotate(-0.5deg); }
.sm-sticky .tool-card:nth-child(4) { background: #E5DBF5 !important; transform: rotate(0.6deg); }
.sm-sticky .tool-card:nth-child(5) { background: #FFE9A8 !important; transform: rotate(-0.7deg); }
.sm-sticky .tool-card:nth-child(6) { background: #FAD8DE !important; transform: rotate(0.4deg); }
.sm-sticky .tool-card:hover {
  transform: rotate(0deg) translateY(-5px) scale(1.03) !important;
}

/* === 區 2：拍立得造型（白卡 + 上紙膠帶 + 下方大留白 padding） === */
.sm-polaroid .tool-card {
  background: #fff !important;
  padding: 22px 22px 36px !important;  /* 下方大留白像拍立得底緣 */
  border-radius: 2px !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1), 0 10px 26px rgba(50,30,10,0.14) !important;
  transform: rotate(-0.8deg);
}
.sm-polaroid .tool-card:nth-child(2) { transform: rotate(0.9deg); }
.sm-polaroid .tool-card:nth-child(3) { transform: rotate(-0.4deg); }
.sm-polaroid .tool-card::before {
  top: -10px !important; left: 50% !important; right: auto !important;
  transform: translateX(-50%) rotate(-3deg) !important;
  width: 72px !important; height: 22px !important;
}
.sm-polaroid .tool-card:nth-child(2)::before {
  background-color: rgba(76,69,138,0.5) !important;
  transform: translateX(-50%) rotate(2deg) !important;
}
.sm-polaroid .tool-card:nth-child(3)::before {
  background-color: rgba(235,231,157,0.85) !important;
  transform: translateX(-50%) rotate(-1deg) !important;
}
.sm-polaroid .tool-card:hover {
  transform: rotate(0deg) translateY(-5px) scale(1.02) !important;
}

/* === 區 3：保留紙膠帶原樣，只微調（已在原 tool-card::before） === */
.sm-tape .tool-card {
  background: #FDFBF4 !important;  /* 米底，不是純白，跟便利貼有差 */
}

/* 手機版：所有歪斜取消，避免擠爆 */
@media (max-width: 780px) {
  .sm-sticky .tool-card,
  .sm-polaroid .tool-card { transform: none !important; }
}

/* ===================================================================
   2026-04-24 Brand Guardian 顧問建議採用：section 內部裝置呼吸空間
   （小腸 09:26 抱怨「太擠，每頁要多留白」）
   =================================================================== */
.notebook .hero-split { margin-bottom: 60px; }
.notebook .stats-row { margin: 0 0 52px !important; }
.notebook .bulb-card + .guide-box,
.notebook .guide-box + .photo-wall,
.notebook .photo-wall + .chang-bubble,
.notebook .stats-row + .bulb-card,
.notebook .chang-bubble + .hr-handwrite,
.notebook .hr-handwrite + .section,
.notebook .about-hero + .section,
.notebook .manifesto-wrap + .section,
.notebook .manifesto-wrap,
.notebook .about-hero { margin-top: 56px; margin-bottom: 56px; }

/* section 內部：grid / table / proof-img 跟前後元素呼吸 */
.notebook .section > .grid-2,
.notebook .section > .grid-3,
.notebook .section > .grid-4,
.notebook .section > table,
.notebook .section > .proof-img { margin-top: 32px; margin-bottom: 32px; }

/* page-title 跟下面 hero 給足空間 */
.page-title + .about-hero,
.page-title + .section { margin-top: 50px; }

/* ===================================================================
   2026-04-24 顧問建議 1-4 執行
   =================================================================== */

/* ----- 問題 1：sitemap 三組統一拍立得造型，用紙膠帶色區分 ----- */
.sm-sticky .tool-card,
.sm-polaroid .tool-card,
.sm-tape .tool-card {
  background: #fff !important;
  padding: 22px 22px 32px !important;
  border-radius: 2px !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08), 0 10px 22px rgba(50,30,10,0.1) !important;
}
/* 三組旋轉角度統一放輕，保留手作感但不亂 */
.sm-sticky .tool-card,
.sm-polaroid .tool-card,
.sm-tape .tool-card { transform: rotate(-0.6deg); }
.sm-sticky .tool-card:nth-child(2n),
.sm-polaroid .tool-card:nth-child(2n),
.sm-tape .tool-card:nth-child(2n) { transform: rotate(0.6deg); }

/* 三組各用不同紙膠帶顏色區分 */
.sm-sticky .tool-card::before {
  display: block !important;
  background-color: rgba(209,75,99,0.5) !important;  /* 紅 */
  top: -10px !important; left: 50% !important; right: auto !important;
  transform: translateX(-50%) rotate(-3deg) !important;
  width: 72px !important; height: 22px !important;
}
.sm-polaroid .tool-card::before {
  background-color: rgba(76,69,138,0.5) !important;  /* 紫 */
  top: -10px !important; left: 50% !important; right: auto !important;
  transform: translateX(-50%) rotate(2deg) !important;
  width: 72px !important; height: 22px !important;
}
.sm-tape .tool-card::before {
  background-color: rgba(235,231,157,0.85) !important;  /* 金黃 */
  top: -10px !important; left: 50% !important; right: auto !important;
  transform: translateX(-50%) rotate(-1deg) !important;
  width: 72px !important; height: 22px !important;
}
.sm-sticky .tool-card:hover,
.sm-polaroid .tool-card:hover,
.sm-tape .tool-card:hover {
  transform: rotate(0deg) translateY(-5px) scale(1.02) !important;
}

/* ----- section h2：紫色字（底線取消，靠 .hl 螢光筆強調）----- */
.section h2,
.section h2 .hl {
  color: var(--brand-purple) !important;
}

/* ===================================================================
   2026-04-24 callout / bulb-card 加手撕紙邊（小腸：我覺得也蠻不錯的）
   =================================================================== */
.callout {
  background: #FBF8F1 !important;
  padding: 24px 28px 22px 56px !important;
  margin: 28px 0 !important;
  position: relative;
  clip-path: polygon(
    0% 3%, 4% 1%, 9% 3%, 14% 0%, 19% 2%, 25% 1%, 31% 3%, 37% 0%, 43% 2%, 50% 0%, 56% 3%, 62% 1%, 68% 3%, 74% 0%, 80% 2%, 86% 1%, 91% 3%, 96% 0%, 100% 2%,
    100% 98%, 96% 100%, 91% 97%, 86% 99%, 80% 96%, 74% 99%, 68% 97%, 62% 100%, 56% 98%, 50% 100%, 43% 97%, 37% 99%, 31% 96%, 25% 99%, 19% 97%, 14% 100%, 9% 98%, 4% 100%, 0% 97%
  );
  box-shadow: 0 2px 10px rgba(80,50,30,0.12) !important;
  border-left: none !important;
}
.callout::before {
  content: '※' !important;
  background: none !important;
  position: absolute !important;
  left: 20px !important; top: 22px !important;
  font-size: 22px !important;
  color: var(--brand-red) !important;
}
.callout.quiet::before { content: '◆' !important; color: var(--brand-purple) !important; }

/* ----- about 5 招式卡：純淨卡（無任何 border、無紙膠帶，靠文字色區分）----- */
.section .grid-2 > .tool-card[style*="--tool-color"] {
  background: #FBF8F1 !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06), 0 8px 22px rgba(0,0,0,0.05) !important;
  padding: 28px 28px 24px !important;
  transform: none !important;
}
/* 關鍵：也把原本的紙膠帶 ::before 完全拿掉 */
.section .grid-2 > .tool-card[style*="--tool-color"]::before {
  display: none !important;
  content: none !important;
}
/* 標號圓形（像勳章） */
.section .grid-2 > .tool-card[style*="--tool-color"] .head .ic {
  background: var(--tool-color) !important;
  color: #fff !important;
  font-size: 18px !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15) !important;
  flex-shrink: 0;
}
.section .grid-2 > .tool-card[style*="--tool-color"] .head h4 {
  color: var(--tool-color) !important;
  font-size: 22px !important;
}
.section .grid-2 > .tool-card[style*="--tool-color"]:hover {
  transform: translateY(-4px) !important;
}

/* ----- 問題 3（撤回）：small 隱藏造成空白節點，還原為預設顯示 ----- */
.fnode-label small {
  display: block;
  opacity: 0.82;
  margin-top: 4px;
}
/* 節點背景不動（原本深底白字、淺底深字的配對就是對的，混色會讓白字變看不見）*/

/* ----- 問題 4：rituals.html 晚安 12 便條紙減到 2 色 ----- */
.night-note:nth-child(4n+1),
.night-note:nth-child(4n+3) { background: #FFF6C9 !important; }
.night-note:nth-child(4n+2),
.night-note:nth-child(4n+4) { background: #D6EBD6 !important; }
.night-note:nth-child(4n+1)::before,
.night-note:nth-child(4n+3)::before { background: rgba(209,75,99,0.32) !important; }
.night-note:nth-child(4n+2)::before,
.night-note:nth-child(4n+4)::before { background: rgba(76,69,138,0.32) !important; }
/* （蛇形 SVG 之前已經 display:none，保留原設定） */

/* ============ DEPT-HEAD-LINK｜第七處 → 總覽 ============ */
.org-dept-head.dept-head-link {
  display: block;
  text-decoration: none !important;
  color: #fff !important;
  cursor: pointer;
  position: relative;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.org-dept-head.dept-head-link:hover {
  transform: translateY(-2px) rotate(-0.6deg);
  box-shadow: 3px 6px 16px rgba(0,0,0,0.28);
}
.org-dept-head.dept-head-link .dept-head-cta {
  display: block;
  margin-top: 4px;
  font-family: '金萱9', sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1px;
  opacity: 0.85;
}

/* ============ TOOL-CARD .cat｜移除漸層字（小腸不喜歡） ============ */
.grid-2 > .tool-card .head .cat,
.section .grid-2 > .tool-card[style*="--tool-color"] .head .cat {
  background: none !important;
  -webkit-text-fill-color: var(--tool-color, var(--brand-red)) !important;
  color: var(--tool-color, var(--brand-red)) !important;
  font-weight: 700 !important;
}

/* ============ 知識包小腸招牌黃色螢光筆連結（2026-04-27 統一品牌升級） ============
   作用範圍：main / article / .content / section 內的 inline 連結
   排除：nav 連結、按鈕類、卡片類、Elementor 類、tool-card head 類
*/
main a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand),
article a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand),
.content a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand),
section a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand) {
  color: #1F3A68; /* navy */
  font-weight: 700;
  text-decoration: none;
  background-image: linear-gradient(rgb(255, 238, 85), rgb(255, 238, 85));
  background-size: 100% 4px;
  background-position: 0 100%;
  background-repeat: no-repeat;
  padding: 0 2px;
  transition: background-size .2s ease, color .2s ease;
}
main a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand):hover,
article a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand):hover,
.content a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand):hover,
section a:not(.btn):not(.button):not(.cta-btn):not(.nav-link):not(.menu-link):not(.nav-cta):not(.tap-hint):not(.cta-rainbow):not([class*="elementor"]):not([class*="card"]):not(.nav-brand):hover {
  background-size: 100% 100%;
  color: #1F3A68;
}

/* ============ 側邊目錄 override｜螢光筆只給內文，不給目錄（2026-04-28 修正）============
   排除：aside / [class*="sidebar"] / [class*="toc"] / [id*="toc"] / .tut-sidebar
   不包含 nav！nav 已被原 selector 用 :not(.nav-link/.nav-cta/.nav-brand) 排除，
   再加 nav a 進來會把頂部 banner item 的 padding 全砍光，導致擠在一起（4/28 09:26 bug）
   套上：部落格 ez-toc 風格——淺灰、無底線、hover 變紫
*/
aside a, aside a:hover,
.tut-sidebar a, .tut-sidebar a:hover,
[class*="sidebar"] a, [class*="sidebar"] a:hover,
[class*="toc"] a, [class*="toc"] a:hover,
#toc a, #toc a:hover {
  background-image: none !important;
  background-size: auto !important;
  font-weight: 500;
  text-decoration: none;
}
/* 不寫 padding: 0 — 4/28 10:00 拔掉，因為它把 .tut-sidebar 自定義 padding 全砍光，
   導致目錄項目左右沒留白、文字貼齊紅底邊。砍螢光筆只需 background-image: none 就夠 */
/* 部落格 ez-toc 風格 */
aside a,
.tut-sidebar a,
[class*="sidebar"] a:not(.cta-btn):not(.btn):not(.button),
[class*="toc"] a,
#toc a {
  color: #5a4a40 !important;
  transition: color .2s linear !important;
}
aside a:hover,
.tut-sidebar a:hover,
[class*="sidebar"] a:not(.cta-btn):not(.btn):not(.button):hover,
[class*="toc"] a:hover,
#toc a:hover {
  color: #4C458A !important; /* purple */
}
/* 目錄當前項（active）：紅底白字｜修復 4/28 09:20 — 原 !important 把白字蓋掉看不見 */
.tut-sidebar a.active,
.tut-sidebar a.active:hover,
[class*="sidebar"] a.active,
[class*="sidebar"] a.active:hover,
[class*="toc"] a.active,
[class*="toc"] a.active:hover,
#toc a.active,
#toc a.active:hover,
aside a.active,
aside a.active:hover {
  color: #fff !important;
  font-weight: 700 !important;
}
