Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
 
 
 
 
 

1410 строки
75 KiB

  1. /* ===== Reset & Variables ===== */
  2. *,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
  3. ul,ol{list-style:none;}
  4. :root{
  5. --orange:#E8751A;
  6. --orange-dark:#C96012;
  7. --orange-light:#F5A623;
  8. --red:#CC2929;
  9. --red-light:#E84040;
  10. --blue:#3B82C4;
  11. --blue-dark:#1A3550;
  12. --white:#fff;
  13. --gray-bg:#F5F6F8;
  14. --gray-100:#ECEEF1;
  15. --gray-300:#C4C8CE;
  16. --gray-400:#A0A5AD;
  17. --gray-500:#7A8290;
  18. --gray-600:#565C67;
  19. --gray-700:#3D4451;
  20. --gray-900:#1A1D24;
  21. --font-cn:"Microsoft YaHei","PingFang SC",sans-serif;
  22. --font-en:"Roboto",sans-serif;
  23. }
  24. html,body{height:100%;font-family:var(--font-cn);color:var(--gray-900);line-height:1.7;background:#fff;}
  25. /* Iconfont 场景化样式 */
  26. .iconfont.icon-view{font-size:14px;color:var(--gray-500);}
  27. .iconfont.icon-phone{font-size:18px;color:var(--orange);}
  28. .iconfont.icon-email{font-size:18px;color:#165DFF;}
  29. .iconfont.icon-dizhi{font-size:14px;color:#E8751A;}
  30. .iconfont.icon-clipboard{font-size:14px;color:var(--orange);}
  31. .iconfont.icon-email-empty{font-size:48px;color:var(--gray-300);}
  32. .iconfont.icon-lock{font-size:13px;color:var(--gray-400);}
  33. .ct-info-icon .iconfont{font-size:20px;}
  34. .ct-info-icon.orange .iconfont{color:var(--orange);}
  35. .ct-info-icon.blue .iconfont{color:#165DFF;}
  36. .ct-info-icon.green .iconfont{color:#00B42A;}
  37. .ct-map-header .iconfont{font-size:18px;color:var(--orange);}
  38. .job-tag.location .iconfont{font-size:12px;}
  39. .job-contact .iconfont{font-size:14px;}
  40. .job-nav-title .iconfont{font-size:15px;}
  41. .proj-detail-meta .iconfont,.article-detail-meta .iconfont{font-size:14px;color:var(--gray-500);vertical-align:-1px;}
  42. a{text-decoration:none;color:inherit;transition:.2s;}
  43. img{max-width:100%;display:block;image-rendering:crisp-edges;image-rendering:-webkit-optimize-contrast;image-rendering:-moz-crisp-edges;}
  44. /* ===== Fixed Header ===== */
  45. .fixed-header{
  46. position:fixed;top:0;left:0;right:0;z-index:1000;
  47. display:flex;align-items:center;
  48. padding:0 60px;height:72px;
  49. background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  50. box-shadow:0 2px 12px rgba(0,0,0,.04);
  51. transition:all .4s;
  52. }
  53. .logo{display:flex;align-items:center;position:relative;z-index:2;}
  54. .logo-img{height:44px;width:auto;transition:.3s;}
  55. .header-right{display:flex;align-items:center;gap:12px;margin-left:auto;position:relative;z-index:2;}
  56. .header-nav{display:flex;align-items:center;gap:4px;position:absolute;left:50%;transform:translateX(-50%);white-space:nowrap;}
  57. .nav-link{
  58. position:relative;padding:8px 14px;font-size:15px;font-weight:500;
  59. color:var(--gray-700);letter-spacing:1px;transition:.25s;border-radius:4px;white-space:nowrap;
  60. }
  61. .nav-link:hover,.nav-link.active{color:var(--orange);}
  62. /* Dropdown */
  63. .nav-dropdown{position:relative;}
  64. .nav-dropdown .dropdown-menu{
  65. position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(4px);
  66. min-width:160px;background:rgba(255,255,255,.98);backdrop-filter:blur(12px);border-radius:8px;
  67. box-shadow:0 8px 32px rgba(0,0,0,.12);padding:8px 0;border:1px solid rgba(0,0,0,.06);
  68. opacity:0;visibility:hidden;transition:.25s;pointer-events:none;
  69. }
  70. .nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto;}
  71. .dropdown-menu a{display:block;padding:10px 24px;font-size:14px;color:var(--gray-700);white-space:nowrap;transition:.15s;text-align:center;}
  72. .dropdown-menu a:hover{color:var(--orange);background:rgba(232,117,26,.04);}
  73. /* Header Search */
  74. .header-search{position:relative;display:flex;align-items:center;}
  75. .header-search-btn{background:none;border:none;cursor:pointer;color:var(--gray-500);padding:6px;border-radius:50%;transition:.2s;display:flex;align-items:center;justify-content:center;}
  76. .header-search-btn:hover{color:var(--orange);}
  77. .header-search-box{position:absolute;right:0;top:50%;transform:translateY(-50%);width:0;overflow:hidden;transition:width .3s;display:flex;align-items:center;background:#fff;border-radius:24px;border:1px solid transparent;height:38px;}
  78. .header-search-box.open{width:260px;border-color:var(--orange);box-shadow:0 2px 12px rgba(0,0,0,.08);}
  79. .header-search-box input{flex:1;border:none;outline:none;font-size:14px;padding:0 12px;height:100%;background:transparent;font-family:var(--font-cn);color:var(--gray-900);min-width:0;}
  80. .header-search-box input::placeholder{color:var(--gray-300);}
  81. .header-search-go{background:var(--orange);border:none;cursor:pointer;color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-right:4px;flex-shrink:0;transition:.2s;}
  82. .header-search-go:hover{background:var(--orange-dark);}
  83. .header-search-mobile{display:none;color:var(--gray-500);padding:6px;transition:.2s;}
  84. .header-search-mobile:hover{color:var(--orange);}
  85. /* Mobile Menu Button */
  86. .mobile-menu-btn{
  87. display:none;width:32px;height:32px;background:none;border:none;cursor:pointer;
  88. flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:4px;
  89. }
  90. .mobile-menu-btn span{display:block;width:20px;height:2px;background:var(--gray-700);transition:.3s;}
  91. /* Mobile Menu Overlay */
  92. .mobile-menu-overlay{
  93. position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1001;
  94. opacity:0;visibility:hidden;transition:.3s;
  95. }
  96. .mobile-menu-overlay.open{opacity:1;visibility:visible;}
  97. /* Mobile Menu Drawer */
  98. .mobile-menu{
  99. position:fixed;top:0;right:-280px;width:280px;height:100%;
  100. background:#fff;z-index:1002;transition:.3s;
  101. display:flex;flex-direction:column;
  102. }
  103. .mobile-menu.open{right:0;}
  104. .mobile-menu-header{
  105. display:flex;align-items:center;justify-content:space-between;
  106. padding:16px 20px;border-bottom:1px solid var(--gray-100);
  107. }
  108. .mobile-logo{height:32px;}
  109. .mobile-menu-close{
  110. width:32px;height:32px;background:none;border:none;
  111. font-size:24px;color:var(--gray-500);cursor:pointer;
  112. }
  113. .mobile-nav{flex:1;overflow-y:auto;padding:12px 0;}
  114. .mobile-nav-item{border-bottom:1px solid var(--gray-100);}
  115. .mobile-nav-link{
  116. display:flex;align-items:center;justify-content:space-between;
  117. padding:14px 20px;font-size:15px;color:var(--gray-700);
  118. }
  119. .mobile-nav-arrow{font-size:18px;transition:.3s;}
  120. .mobile-nav-item.open .mobile-nav-arrow{transform:rotate(90deg);}
  121. .mobile-nav-sub{display:none;background:var(--gray-bg);padding:8px 0;}
  122. .mobile-nav-item.open .mobile-nav-sub{display:block;}
  123. .mobile-nav-sub a{display:block;padding:10px 20px 10px 36px;font-size:14px;color:var(--gray-500);}
  124. .mobile-nav-sub a:hover{color:var(--orange);}
  125. /* ===== Swiper Fullpage ===== */
  126. .swiper-fullpage{width:100%;height:100vh;overflow:hidden;}
  127. .swiper-fullpage .swiper-slide{height:100vh!important;overflow:hidden;position:relative;}
  128. /* ===== Slide Labels (right side dots) ===== */
  129. .slide-labels{
  130. position:fixed;right:36px;top:50%;transform:translateY(-50%);z-index:999;
  131. display:flex;flex-direction:column;gap:24px;
  132. }
  133. .slide-label{
  134. display:flex;align-items:center;gap:10px;cursor:pointer;
  135. flex-direction:row-reverse;
  136. }
  137. .slide-label .dot{
  138. width:10px;height:10px;border-radius:50%;
  139. background:rgba(255,255,255,.3);border:2px solid rgba(255,255,255,.5);
  140. transition:.3s;flex-shrink:0;
  141. }
  142. .slide-label.active .dot{
  143. background:var(--orange);border-color:var(--orange);
  144. width:10px;height:24px;border-radius:5px;
  145. }
  146. .slide-label .txt{
  147. font-size:12px;color:rgba(255,255,255,.5);letter-spacing:1px;
  148. opacity:0;transform:translateX(8px);transition:.25s;white-space:nowrap;
  149. }
  150. .slide-label:hover .txt{opacity:1;transform:translateX(0);}
  151. .slide-label.active .txt{opacity:1;transform:translateX(0);color:var(--orange);}
  152. .slide-labels.light .slide-label .dot{background:rgba(0,0,0,.1);border-color:rgba(0,0,0,.2);}
  153. .slide-labels.light .slide-label.active .dot{background:var(--orange);border-color:var(--orange);}
  154. .slide-labels.light .slide-label .txt{color:rgba(0,0,0,.3);}
  155. .slide-labels.light .slide-label.active .txt{color:var(--orange);}
  156. /* ===== Slide 1: Banner ===== */
  157. .slide-banner{background:#0a0a0a;height:100vh;position:relative;}
  158. .banner-swiper{width:100%;height:100%;}
  159. .banner-swiper .swiper-slide{height:100vh!important;overflow:hidden;}
  160. .banner-slide-bg{
  161. position:absolute;inset:0;
  162. background:center/cover no-repeat;
  163. filter:brightness(.85);transition:transform 6s ease-out;
  164. }
  165. .banner-swiper .swiper-slide-active .banner-slide-bg{transform:scale(1.05);}
  166. .banner-slide-content{
  167. position:absolute;top:50%;left:120px;transform:translateY(-50%);
  168. z-index:2;display:flex;flex-direction:column;
  169. align-items:flex-start;max-width:700px;
  170. }
  171. .banner-slide-content.pos-left{left:120px;right:auto;align-items:flex-start;text-align:left;}
  172. .banner-slide-content.pos-center{left:50%;transform:translate(-50%,-50%);align-items:center;text-align:center;}
  173. .banner-slide-content.pos-right{left:auto;right:120px;align-items:flex-end;text-align:right;}
  174. .banner-slide-content.glass-on{
  175. background:rgba(0,0,0,.25);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  176. border-radius:16px;border:1px solid rgba(255,255,255,.1);
  177. padding:48px 60px;
  178. }
  179. .banner-slide-content.pos-center.glass-on{transform:translate(-50%,-50%);}
  180. .banner-slide-content h1{
  181. font-size:48px;font-weight:700;color:#fff;line-height:1.3;
  182. margin-bottom:20px;letter-spacing:2px;
  183. opacity:0;transform:translateY(40px);transition:all .8s .3s;
  184. }
  185. .banner-swiper .swiper-slide-active .banner-slide-content h1{opacity:1;transform:translateY(0);}
  186. .banner-slide-content .desc{
  187. font-size:16px;color:rgba(255,255,255,.75);line-height:1.9;max-width:600px;
  188. margin-bottom:40px;
  189. opacity:0;transform:translateY(30px);transition:all .8s .5s;
  190. }
  191. .banner-swiper .swiper-slide-active .banner-slide-content .desc{opacity:1;transform:translateY(0);}
  192. .banner-slide-content .btns{
  193. display:flex;gap:16px;
  194. opacity:0;transform:translateY(20px);transition:all .8s .7s;
  195. }
  196. .banner-swiper .swiper-slide-active .banner-slide-content .btns{opacity:1;transform:translateY(0);}
  197. .banner-swiper .swiper-pagination{bottom:90px!important;}
  198. .banner-swiper .swiper-pagination-bullet{
  199. width:32px;height:4px;border-radius:2px;
  200. background:rgba(255,255,255,.35);opacity:1;border:none;transition:.3s;
  201. }
  202. .banner-swiper .swiper-pagination-bullet-active{width:48px;background:var(--orange);}
  203. .btn-primary{
  204. padding:14px 40px;border-radius:30px;font-size:15px;font-weight:600;
  205. background:var(--orange);color:#fff;letter-spacing:1px;transition:.3s;
  206. display:inline-block;
  207. }
  208. .btn-primary:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,117,26,.3);}
  209. .btn-ghost{
  210. padding:14px 40px;border-radius:30px;font-size:15px;font-weight:600;
  211. background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5);
  212. letter-spacing:1px;transition:.3s;display:inline-block;
  213. }
  214. .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1);}
  215. .scroll-hint{
  216. position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:2;
  217. display:flex;flex-direction:column;align-items:center;gap:8px;
  218. color:rgba(255,255,255,.5);font-size:12px;letter-spacing:2px;
  219. }
  220. .scroll-hint .mouse{
  221. width:24px;height:38px;border:2px solid rgba(255,255,255,.4);border-radius:12px;
  222. position:relative;
  223. }
  224. .scroll-hint .mouse::after{
  225. content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);
  226. width:3px;height:8px;background:rgba(255,255,255,.6);border-radius:2px;
  227. animation:scrollDown 1.8s infinite;
  228. }
  229. @keyframes scrollDown{0%{opacity:1;top:6px;}100%{opacity:0;top:22px;}}
  230. /* ===== Slide 2: Donation Data ===== */
  231. .slide-donation{
  232. background:linear-gradient(135deg,#fff8f0 0%,#fff 50%,#f0f7ff 100%);
  233. display:flex;align-items:center;justify-content:center;
  234. height:100vh;padding-top:72px;
  235. }
  236. .donation-wrap{
  237. width:100%;max-width:1300px;padding:0 40px;
  238. max-height:calc(100vh - 72px);overflow:hidden;
  239. opacity:0;transform:translateY(50px);transition:all .9s .2s;
  240. display:flex;flex-direction:column;
  241. }
  242. .swiper-slide-active .donation-wrap{opacity:1;transform:translateY(0);}
  243. .section-head{text-align:center;margin-bottom:2vh;}
  244. .section-head h2{font-size:clamp(24px,3vw,36px);font-weight:700;color:var(--gray-900);margin-bottom:4px;}
  245. .section-head h2::after{content:"";display:block;width:40px;height:3px;background:linear-gradient(90deg,var(--red),var(--orange));margin:8px auto 0;border-radius:2px;}
  246. .section-head .en{font-family:var(--font-en);font-size:13px;color:var(--gray-300);letter-spacing:3px;text-transform:uppercase;}
  247. .data-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:2vh;}
  248. .data-card{
  249. background:rgba(255,255,255,.65);backdrop-filter:blur(16px);
  250. border-radius:14px;padding:18px 16px;text-align:center;
  251. box-shadow:0 8px 32px rgba(0,0,0,.06),inset 0 1px 0 rgba(255,255,255,.8);
  252. border:1px solid rgba(255,255,255,.6);transition:.3s;
  253. }
  254. .data-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(232,117,26,.12);border-color:var(--orange-light);}
  255. .data-card .label{font-size:14px;color:var(--gray-500);margin-bottom:4px;}
  256. .data-card .amount{font-family:var(--font-en);font-size:clamp(20px,2.2vw,28px);font-weight:700;color:var(--orange);}
  257. .data-card .amount .unit{font-size:14px;color:var(--gray-500);font-weight:400;margin-left:4px;}
  258. .data-card .note{font-size:12px;color:var(--gray-300);margin-top:2px;}
  259. .donation-tables{display:grid;grid-template-columns:1fr 1fr;gap:16px;flex:1;min-height:0;}
  260. .dtable{
  261. background:rgba(255,255,255,.6);backdrop-filter:blur(16px);
  262. border-radius:14px;padding:14px;
  263. box-shadow:0 8px 32px rgba(0,0,0,.06);border:1px solid rgba(255,255,255,.6);
  264. }
  265. .dtable h3{font-size:14px;font-weight:600;color:var(--gray-900);margin-bottom:6px;padding-bottom:5px;border-bottom:2px solid var(--orange-light);}
  266. .dtable table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed;}
  267. .dtable th{text-align:center;padding:5px 8px;color:var(--gray-500);font-weight:500;border-bottom:1px solid var(--gray-100);}
  268. .dtable td{text-align:center;padding:5px 8px;color:var(--gray-700);border-bottom:1px solid var(--gray-100);}
  269. .dtable .td-r{font-family:var(--font-en);font-weight:500;color:var(--orange);}
  270. .dtable-head{margin-bottom:0;}
  271. .dtable-scroll-wrap{max-height:140px;overflow:hidden;position:relative;}
  272. .dtable-scroll-wrap.donation-scroll .dtable-scroll-inner{animation:donationScroll 15s linear infinite;}
  273. .dtable-scroll-wrap.donation-scroll:hover .dtable-scroll-inner{animation-play-state:paused;}
  274. @keyframes donationScroll{0%{transform:translateY(0);}100%{transform:translateY(-50%);}}
  275. .dtable-drug{grid-column:1/-1;}
  276. .dtable-drug h3{border-bottom-color:var(--orange);}
  277. .dtable-drug .drug-name{color:var(--orange);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block;}
  278. .drug-scroll-wrap{max-height:140px;overflow:hidden;position:relative;}
  279. .drug-scroll-inner{animation:drugScroll 18s linear infinite;}
  280. .drug-scroll-wrap:hover .drug-scroll-inner{animation-play-state:paused;}
  281. @keyframes drugScroll{0%{transform:translateY(0);}100%{transform:translateY(-50%);}}
  282. /* ===== Slide 3: Projects ===== */
  283. .slide-projects{
  284. position:relative;height:100vh;overflow:hidden;cursor:grab;
  285. }
  286. .slide-projects.dragging{cursor:grabbing;}
  287. .slide-projects .proj-bg{
  288. position:absolute;inset:0;
  289. background:center/cover no-repeat;
  290. filter:brightness(.65);
  291. transition:opacity .8s,transform 6s ease-out;
  292. opacity:0;
  293. }
  294. .slide-projects .proj-bg.active{opacity:1;}
  295. .swiper-slide-active .slide-projects .proj-bg.active{transform:scale(1.04);}
  296. .proj-info-card{
  297. position:absolute;top:50%;right:8%;transform:translateY(-50%);
  298. width:380px;
  299. background:rgba(232,117,26,.88);backdrop-filter:blur(8px);
  300. border-radius:4px;padding:48px 40px;color:#fff;
  301. opacity:0;transform:translateY(-50%) translateX(40px);
  302. transition:all .7s .3s;z-index:5;
  303. }
  304. .swiper-slide-active .proj-info-card{opacity:1;transform:translateY(-50%) translateX(0);}
  305. .proj-info-card .card-label{
  306. font-size:13px;letter-spacing:3px;opacity:.8;margin-bottom:12px;
  307. display:flex;align-items:center;gap:8px;
  308. }
  309. .proj-info-card .card-label::before{
  310. content:"";display:block;width:24px;height:2px;background:var(--red-light);opacity:.8;
  311. }
  312. .proj-info-card h3{font-size:28px;font-weight:700;line-height:1.4;margin-bottom:16px;}
  313. .proj-info-card .card-divider{width:40px;height:2px;background:#fff;opacity:.5;margin-bottom:16px;}
  314. .proj-info-card p{font-size:15px;line-height:1.9;opacity:.9;margin-bottom:24px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
  315. .proj-info-card .card-btn{
  316. display:inline-flex;align-items:center;gap:6px;
  317. padding:10px 28px;border:1.5px solid rgba(255,255,255,.6);border-radius:24px;
  318. font-size:14px;color:#fff;transition:.3s;
  319. }
  320. .proj-info-card .card-btn:hover{background:rgba(255,255,255,.15);border-color:#fff;}
  321. .proj-tabs{
  322. position:absolute;bottom:60px;left:50%;transform:translateX(-50%);
  323. z-index:5;display:flex;gap:0;max-width:60vw;
  324. }
  325. .proj-tab{
  326. padding:14px 28px;cursor:pointer;
  327. font-size:14px;color:rgba(255,255,255,.6);
  328. border-bottom:3px solid transparent;
  329. transition:.3s;white-space:nowrap;letter-spacing:1px;
  330. overflow:hidden;text-overflow:ellipsis;max-width:200px;
  331. }
  332. .proj-tab:hover{color:rgba(255,255,255,.85);}
  333. .proj-tab.active{color:#fff;border-bottom-color:var(--red);font-weight:600;}
  334. /* Mobile project nav (hidden on PC) */
  335. .proj-mobile-nav{display:none;}
  336. .proj-nav-btn{
  337. width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(255,255,255,.6);
  338. background:rgba(0,0,0,.2);color:#fff;font-size:20px;line-height:1;
  339. cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;
  340. }
  341. .proj-nav-btn:hover{background:rgba(255,255,255,.2);border-color:#fff;}
  342. .proj-counter{font-size:13px;color:rgba(255,255,255,.8);letter-spacing:1px;}
  343. .proj-more-link{
  344. position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  345. z-index:5;font-size:13px;color:rgba(255,255,255,.5);
  346. letter-spacing:2px;transition:.2s;
  347. }
  348. .proj-more-link:hover{color:var(--orange);}
  349. /* ===== Slide 4: News ===== */
  350. .slide-news{
  351. background:#fff;
  352. display:flex;align-items:center;justify-content:center;
  353. height:100vh;padding-top:72px;
  354. }
  355. .news-wrap{
  356. width:100%;max-width:1200px;padding:0 60px;
  357. max-height:calc(100vh - 72px);overflow:hidden;
  358. opacity:0;transform:translateY(50px);transition:all .9s .2s;
  359. }
  360. .swiper-slide-active .news-wrap{opacity:1;transform:translateY(0);}
  361. .news-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:stretch;}
  362. .news-featured{border-radius:14px;overflow:hidden;position:relative;cursor:pointer;display:flex;}
  363. .news-featured img{width:100%;height:100%;object-fit:cover;transition:.5s;}
  364. .news-featured:hover img{transform:scale(1.03);}
  365. .news-featured .overlay{
  366. position:absolute;bottom:0;left:0;right:0;
  367. padding:24px;background:linear-gradient(transparent,rgba(0,0,0,.7));
  368. color:#fff;
  369. }
  370. .news-featured .overlay h3{font-size:16px;font-weight:600;margin-bottom:4px;}
  371. .news-featured .overlay .date{font-size:13px;opacity:.7;}
  372. .news-list{display:flex;flex-direction:column;gap:0;}
  373. .news-item{
  374. display:flex;align-items:flex-start;gap:16px;
  375. padding:14px 0;border-bottom:1px solid var(--gray-100);
  376. cursor:pointer;transition:.2s;
  377. }
  378. .news-item:hover{padding-left:8px;}
  379. .news-item .date-box{flex-shrink:0;width:54px;text-align:center;}
  380. .news-item .date-box .day{font-family:var(--font-en);font-size:28px;font-weight:700;color:var(--orange);line-height:1;}
  381. .news-item .date-box .ym{font-size:12px;color:var(--gray-300);white-space:nowrap;margin-top:2px;}
  382. .news-item .text h4{font-size:14px;font-weight:500;color:var(--gray-900);margin-bottom:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
  383. .news-item .text p{font-size:13px;color:var(--gray-500);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
  384. .more-link{font-size:13px;color:var(--orange);letter-spacing:1px;}
  385. .more-link:hover{text-decoration:underline;}
  386. /* ===== Slide 5: Partners + Footer ===== */
  387. .slide-footer{
  388. background:#F8F9FA;
  389. display:flex;flex-direction:column;justify-content:flex-start;align-items:center;
  390. height:100vh;padding-top:72px;overflow:hidden;
  391. }
  392. .partners-section{
  393. width:100%;max-width:1200px;padding:40px 60px;flex:1;
  394. display:flex;flex-direction:column;
  395. opacity:0;transform:translateY(50px);transition:all .9s .2s;
  396. }
  397. .swiper-slide-active .partners-section{opacity:1;transform:translateY(0);}
  398. /* Partners carousel - 2 rows, 5 per row */
  399. .partners-carousel-wrap{
  400. position:relative;width:100%;flex:1;display:flex;align-items:center;
  401. }
  402. .partners-carousel-viewport{
  403. flex:1;overflow:hidden;margin:0 50px;
  404. }
  405. .partners-carousel{
  406. display:grid;grid-template-rows:repeat(2,1fr);grid-auto-flow:column;grid-auto-columns:calc((100% - 80px) / 5);
  407. gap:20px;transition:transform .5s ease;
  408. }
  409. .partner-item{
  410. background:#fff;border-radius:12px;padding:20px;
  411. display:flex;align-items:center;justify-content:center;
  412. box-shadow:0 2px 12px rgba(0,0,0,.03);border:1px solid var(--gray-100);
  413. transition:.3s;min-height:160px;position:relative;overflow:hidden;
  414. }
  415. .partner-item:hover{box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-2px);}
  416. .partner-item img{max-height:100px;width:auto;filter:grayscale(.3);transition:.3s;}
  417. .partner-item:hover img{filter:grayscale(0);}
  418. .partner-name{
  419. position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.65);color:#fff;font-size:13px;
  420. text-align:center;padding:8px 6px;opacity:0;transition:opacity .25s;pointer-events:none;
  421. }
  422. .partner-item:hover .partner-name{opacity:1;}
  423. /* Carousel navigation - only show when needed */
  424. .partners-nav{
  425. position:absolute;top:50%;transform:translateY(-50%);
  426. width:40px;height:40px;border-radius:50%;
  427. background:rgba(255,255,255,.9);border:1px solid var(--gray-100);
  428. display:none;align-items:center;justify-content:center;
  429. cursor:pointer;transition:.3s;z-index:10;
  430. box-shadow:0 2px 12px rgba(0,0,0,.08);
  431. }
  432. .partners-carousel-wrap.has-more .partners-nav{display:flex;}
  433. .partners-nav:hover{background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.12);}
  434. .partners-nav.prev{left:0;}
  435. .partners-nav.next{right:0;}
  436. .partners-nav svg{width:20px;height:20px;stroke:var(--gray-700);}
  437. /* Footer */
  438. .footer-component{
  439. width:100%;
  440. background:linear-gradient(to bottom,#fb8c1e,#f27019);
  441. position:relative;display:flex;flex-direction:column;flex-shrink:0;
  442. }
  443. .footer-main{flex:1;display:flex;align-items:center;padding:40px 0 20px;}
  444. .footer-content{
  445. max-width:1200px;width:100%;margin:0 auto;padding:0;
  446. display:flex;justify-content:space-between;align-items:flex-start;gap:40px;
  447. }
  448. .footer-left{flex:1;display:flex;flex-direction:column;gap:12px;padding-right:60px;}
  449. .footer-logo{width:180px;height:auto;}
  450. .footer-title{font-size:22px;font-weight:600;color:#fff;letter-spacing:1px;}
  451. .footer-info p{font-size:14px;color:#fff;line-height:2;text-indent:2em;}
  452. .footer-mid{flex:1;display:flex;align-items:flex-start;gap:40px;}
  453. .footer-qr-section{flex:0 0 auto;}
  454. .footer-section{display:flex;flex-direction:column;gap:8px;}
  455. .footer-section-title{
  456. font-size:16px;font-weight:700;color:#fff;margin-bottom:8px;
  457. display:flex;align-items:center;gap:8px;
  458. }
  459. .footer-section-title svg{flex-shrink:0;}
  460. .footer-links-list{display:grid;grid-template-columns:repeat(2,auto);gap:6px 0;list-style:none;padding:0;margin:0;}
  461. .footer-links-list li{font-size:14px;line-height:1.5;white-space:nowrap;padding-right:12px;border-right:1px solid rgba(255,255,255,.4);}
  462. .footer-links-list li:nth-child(2n){border-right:none;padding-right:0;padding-left:12px;}
  463. .footer-links-list a{color:#fff;transition:color .2s;white-space:nowrap;}
  464. .footer-links-list a:hover{color:#fedab7;}
  465. .footer-contact{font-size:13px;color:#fff;line-height:1.8;}
  466. .footer-contact a{color:#fff;transition:color .2s;}
  467. .footer-contact a:hover{color:#fedab7;}
  468. .footer-qr{text-align:center;}
  469. .footer-qr img{width:100px;height:auto;border-radius:4px;background:#fff;object-fit:contain;}
  470. .footer-bottom{border-top:1px solid rgba(255,255,255,.2);padding:16px 0;}
  471. .footer-bottom-content{
  472. max-width:1200px;width:100%;margin:0 auto;padding:0;
  473. display:flex;justify-content:space-between;align-items:center;
  474. }
  475. .footer-copyright{font-size:13px;color:#fedab7;}
  476. .footer-company{font-size:13px;color:#fedab7;}
  477. /* ===== Responsive ===== */
  478. /* ===== Column Page ===== */
  479. .col-banner{
  480. position:relative;height:280px;
  481. background:center/cover no-repeat var(--orange);
  482. display:flex;align-items:center;justify-content:center;
  483. margin-top:72px;
  484. }
  485. .col-banner-overlay{
  486. position:absolute;inset:0;
  487. background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.4) 100%);
  488. }
  489. .col-banner-content{
  490. position:relative;z-index:1;text-align:center;color:#fff;
  491. }
  492. .col-banner-content h1{
  493. font-size:42px;font-weight:700;letter-spacing:2px;margin-bottom:12px;
  494. }
  495. .col-banner-en{
  496. font-family:var(--font-en);font-size:16px;letter-spacing:3px;
  497. text-transform:uppercase;opacity:.9;margin-bottom:16px;
  498. }
  499. .col-banner-desc{
  500. font-size:18px;opacity:.95;letter-spacing:2px;
  501. }
  502. /* Sub Tabs */
  503. .col-tabs-wrap{
  504. background:var(--gray-bg);border-bottom:none;
  505. position:sticky;top:72px;z-index:100;padding:12px 0;
  506. }
  507. .col-tabs{
  508. max-width:1200px;margin:0 auto;display:flex;justify-content:center;
  509. gap:24px;align-items:center;
  510. }
  511. .col-tab{
  512. padding:6px 32px;font-size:16px;color:#606266;
  513. border:none;border-radius:24px;transition:.3s;white-space:nowrap;
  514. font-weight:500;background:transparent;
  515. }
  516. .col-tab:hover{color:#fff;background:rgba(232,117,26,.8);}
  517. .col-tab.active{
  518. color:#fff;background:var(--orange);font-weight:600;
  519. }
  520. /* Breadcrumb */
  521. .col-breadcrumb-wrap{
  522. background:#fff;border-bottom:none;
  523. }
  524. .col-breadcrumb{
  525. max-width:1200px;margin:0 auto;padding:20px 0;
  526. font-size:14px;color:#909399;
  527. }
  528. .col-breadcrumb a{color:#606266;transition:.2s;}
  529. .col-breadcrumb a:hover{color:var(--orange);}
  530. .col-breadcrumb .sep{margin:0 8px;color:#C0C4CC;}
  531. .col-breadcrumb .current{color:var(--orange);}
  532. /* Content Area */
  533. .col-content-wrap{background:#fff;min-height:50vh;}
  534. .col-content{
  535. max-width:1200px;margin:0 auto;padding:0 0 40px;
  536. }
  537. .col-empty{
  538. text-align:center;padding:80px 0;color:var(--gray-300);font-size:15px;grid-column:1/-1;
  539. }
  540. /* Section Title */
  541. .col-section-title{
  542. font-size:28px;font-weight:700;color:var(--gray-900);
  543. margin-bottom:32px;padding-bottom:16px;
  544. border-bottom:3px solid var(--orange);display:inline-block;
  545. }
  546. /* Page Content */
  547. .col-page-body{line-height:2;font-size:15px;color:var(--gray-700);}
  548. .col-page-body img{max-width:100%;height:auto;border-radius:8px;margin:16px auto;display:block;}
  549. .col-page-body p{margin-bottom:16px;}
  550. /* Article List V2 */
  551. .col-article-list-v2{display:flex;flex-direction:column;gap:32px;}
  552. /* Featured (first article) */
  553. .col-art-featured{
  554. display:block;position:relative;border-radius:14px;overflow:hidden;
  555. height:400px;box-shadow:0 8px 32px rgba(0,0,0,.1);
  556. }
  557. .col-art-featured-img{width:100%;height:100%;}
  558. .col-art-featured-img img{width:100%;height:100%;object-fit:cover;transition:.6s;}
  559. .col-art-featured:hover .col-art-featured-img img{transform:scale(1.04);}
  560. .col-art-featured-overlay{
  561. position:absolute;bottom:0;left:0;right:0;
  562. padding:28px 32px;background:linear-gradient(transparent 0%,rgba(0,0,0,.35) 30%,rgba(0,0,0,.8) 100%);
  563. color:#fff;
  564. }
  565. .col-art-featured-overlay h3{font-size:22px;font-weight:700;line-height:1.5;margin-bottom:6px;}
  566. .col-art-featured-overlay p{font-size:14px;opacity:.8;line-height:1.7;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
  567. .col-art-date{font-size:12px;opacity:.6;margin-top:6px;display:inline-flex;align-items:center;gap:4px;}
  568. .col-art-date::before{content:'';display:inline-block;width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") no-repeat center/contain;opacity:.7;}
  569. .col-art-tag{
  570. display:inline-block;padding:4px 12px;border-radius:4px;
  571. background:var(--orange);color:#fff;font-size:12px;font-weight:600;
  572. margin-bottom:10px;letter-spacing:.5px;
  573. }
  574. /* Card list */
  575. .col-art-cards{display:flex;flex-direction:column;gap:20px;}
  576. .col-art-card{
  577. display:flex;gap:0;border-radius:12px;overflow:hidden;
  578. background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.06);
  579. border:1px solid var(--gray-100);transition:.3s;
  580. }
  581. .col-art-card:hover{box-shadow:0 8px 28px rgba(232,117,26,.1);border-color:rgba(232,117,26,.2);transform:translateY(-2px);}
  582. .col-art-card{height:180px;}
  583. .col-art-card-cover{flex-shrink:0;width:260px;height:100%;overflow:hidden;}
  584. .col-art-card-cover img{width:100%;height:100%;object-fit:cover;transition:.4s;}
  585. .col-art-card:hover .col-art-card-cover img{transform:scale(1.06);}
  586. .col-art-no-cover{
  587. width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  588. background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%);
  589. color:#fff;font-size:28px;font-weight:700;letter-spacing:2px;
  590. }
  591. .col-art-card-body{
  592. flex:1;padding:20px 24px;display:flex;flex-direction:column;justify-content:space-between;
  593. }
  594. .col-art-tag-sm{
  595. display:inline-block;padding:2px 10px;border-radius:4px;
  596. background:rgba(232,117,26,.08);color:var(--orange);font-size:12px;font-weight:500;
  597. margin-bottom:8px;
  598. }
  599. .col-art-card-body h4{font-size:17px;font-weight:600;color:var(--gray-900);line-height:1.5;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
  600. .col-art-card-body p{font-size:13px;color:var(--gray-500);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0;}
  601. .col-art-card-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:12px;}
  602. .col-art-card-date{font-size:12px;color:var(--gray-300);font-family:var(--font-en);display:inline-flex;align-items:center;gap:4px;}
  603. .col-art-card-date::before{content:'';display:inline-block;width:13px;height:13px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C4C8CE' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") no-repeat center/contain;}
  604. .col-art-card-more{font-size:13px;color:var(--orange);font-weight:500;opacity:0;transition:.3s;}
  605. .col-art-card:hover .col-art-card-more{opacity:1;}
  606. /* Image Grid (Certificate Style) */
  607. .col-image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
  608. .col-image-item{
  609. background:#fff;border-radius:8px;overflow:hidden;
  610. box-shadow:0 4px 16px rgba(0,0,0,.08);transition:.3s;cursor:pointer;
  611. }
  612. .col-image-item:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(232,117,26,.15);}
  613. .col-image-thumb{
  614. width:100%;height:320px;background:var(--gray-bg);
  615. display:flex;align-items:center;justify-content:center;overflow:hidden;
  616. }
  617. .col-image-thumb img{width:100%;height:100%;object-fit:contain;padding:16px;}
  618. .col-image-title{
  619. padding:16px;text-align:center;font-size:14px;color:var(--gray-900);background:#fff;
  620. }
  621. /* Text List */
  622. .col-text-list{display:flex;flex-direction:column;}
  623. .col-text-item{
  624. display:flex;align-items:center;justify-content:space-between;
  625. padding:16px 0;border-bottom:1px solid var(--gray-100);transition:.2s;
  626. }
  627. .col-text-item:hover{padding-left:8px;}
  628. .col-text-title{font-size:15px;color:var(--gray-700);}
  629. .col-text-title a{color:var(--gray-700);transition:.2s;}
  630. .col-text-title a:hover{color:var(--orange);}
  631. .col-text-date{font-size:13px;color:var(--gray-300);flex-shrink:0;margin-left:24px;}
  632. /* Person Grid (Team Member Card Style) */
  633. /* Featured first person - large horizontal card */
  634. .board-featured{
  635. display:flex;gap:40px;align-items:flex-start;
  636. background:#fff;border:1px solid #ececec;border-radius:12px;
  637. padding:36px;margin-bottom:48px;transition:.3s;
  638. }
  639. .board-featured:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);}
  640. .board-featured .featured-photo{
  641. width:280px;min-width:280px;height:340px;
  642. border-radius:8px;overflow:hidden;background:#F5F6F8;
  643. }
  644. .board-featured .featured-photo img{width:100%;height:100%;object-fit:cover;}
  645. .board-featured .featured-info{flex:1;}
  646. .board-featured .featured-info h3{font-size:26px;font-weight:700;color:#303133;margin-bottom:8px;}
  647. .board-featured .featured-info .position{font-size:15px;font-weight:700;color:#E8751A;margin-bottom:20px;}
  648. .board-featured .featured-info .bio{font-size:14px;color:#606266;line-height:2;}
  649. /* Team grid */
  650. .team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;row-gap:40px;}
  651. .team-member{
  652. background:#fff;border-radius:12px;overflow:hidden;
  653. border:1px solid #ececec;transition:.3s;text-align:center;
  654. }
  655. .team-member:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);}
  656. .member-photo{
  657. width:160px;height:160px;border-radius:6px;
  658. background:#F5F6F8;overflow:hidden;margin:24px auto 0;
  659. }
  660. .member-photo img{width:100%;height:100%;object-fit:cover;}
  661. .member-placeholder{
  662. width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  663. background:var(--orange);color:#fff;font-size:48px;font-weight:700;
  664. }
  665. .member-info{padding:16px 20px 24px;}
  666. .member-info h3{font-size:22px;font-weight:600;color:#303133;margin-bottom:6px;}
  667. .member-position{font-size:14px;font-weight:700;color:#E8751A;margin-bottom:12px;}
  668. .member-bio{
  669. font-size:14px;color:#606266;line-height:1.8;text-align:left;
  670. display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
  671. }
  672. /* Job Recruitment - Arco Design Style */
  673. .job-layout{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:start;}
  674. .job-layout .job-hero-banner{grid-column:1 / -1;}
  675. .job-hero-banner{background:linear-gradient(135deg,#EDF4FF 0%,#E8EDFB 100%);border-radius:16px;padding:20px 32px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden;}
  676. .job-hero-banner::before{content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:rgba(22,93,255,.06);border-radius:50%;}
  677. .job-hero-text h2{font-size:24px;font-weight:700;color:#1D2129;margin-bottom:8px;}
  678. .job-hero-text p{font-size:14px;color:#4E5969;line-height:1.8;}
  679. .job-hero-stats{display:flex;gap:32px;position:relative;z-index:1;}
  680. .job-hero-stat{text-align:center;}
  681. .job-hero-stat .num{font-size:28px;font-weight:700;color:#165DFF;line-height:1;margin-bottom:4px;}
  682. .job-hero-stat .label{font-size:12px;color:#86909C;}
  683. .job-nav{position:sticky;top:60px;background:#fff;border:1px solid #F2F3F5;border-radius:12px;overflow:hidden;}
  684. .job-nav-title{padding:14px 16px;font-size:14px;font-weight:600;color:#1D2129;border-bottom:1px solid #F2F3F5;background:#FAFBFC;}
  685. .job-nav-list{list-style:none;padding:6px 0;margin:0;}
  686. .job-nav-list li a{display:block;padding:10px 16px;font-size:13px;color:#4E5969;text-decoration:none;border-left:3px solid transparent;transition:all .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  687. .job-nav-list li a:hover{color:#165DFF;background:#F7F8FA;}
  688. .job-nav-list li a.active{color:#165DFF;background:#EDF4FF;border-left-color:#165DFF;font-weight:500;}
  689. .job-main{display:flex;flex-direction:column;gap:20px;}
  690. .job-card{background:#fff;border:1px solid #F2F3F5;border-radius:16px;overflow:hidden;transition:all .25s;}
  691. .job-card:hover{border-color:#E5E6EB;box-shadow:0 8px 24px rgba(0,0,0,.06);}
  692. .job-card-header{padding:24px 28px 20px;border-bottom:1px solid #F2F3F5;display:flex;align-items:center;justify-content:space-between;}
  693. .job-card-title{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
  694. .job-card-title h3{font-size:18px;font-weight:600;color:#1D2129;}
  695. .job-card-tags{display:flex;gap:8px;}
  696. .job-tag{padding:3px 10px;font-size:12px;border-radius:4px;font-weight:500;}
  697. .job-tag.location{background:#EDF4FF;color:#165DFF;}
  698. .job-tag.type{border-radius:4px;font-weight:500;}
  699. .job-tag.type.fulltime{background:#E8FFEA;color:#00B42A;}
  700. .job-tag.type.parttime{background:#FFF3E8;color:#E8751A;}
  701. .job-card-body{padding:24px 28px;}
  702. .job-section{margin-bottom:20px;}
  703. .job-section:last-child{margin-bottom:0;}
  704. .job-section-title{font-size:14px;font-weight:600;color:#1D2129;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
  705. .job-section-title::before{content:'';width:3px;height:14px;background:#165DFF;border-radius:2px;}
  706. .job-section-content{font-size:14px;color:#4E5969;line-height:1.9;padding-left:11px;white-space:pre-line;}
  707. .job-card-footer{padding:16px 28px;background:#FAFBFC;border-top:1px solid #F2F3F5;display:flex;align-items:center;justify-content:space-between;}
  708. .job-contact{font-size:13px;color:#86909C;display:flex;align-items:center;gap:16px;}
  709. .job-contact a{color:#165DFF;text-decoration:none;font-weight:500;}
  710. .job-contact a:hover{text-decoration:underline;}
  711. .job-apply-btn{padding:7px 24px;background:linear-gradient(135deg,#165DFF,#3B82F6);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;}
  712. .job-apply-btn:hover{box-shadow:0 4px 12px rgba(22,93,255,.3);transform:translateY(-1px);}
  713. .job-empty{text-align:center;padding:60px 20px;color:#C9CDD4;grid-column:1 / -1;}
  714. .job-empty .empty-icon{font-size:48px;margin-bottom:16px;}
  715. .job-empty p{font-size:14px;color:#86909C;}
  716. /* Column Page Responsive */
  717. /* ===== Form Page (前台表单) ===== */
  718. .col-form-btn-wrap{text-align:center;padding:40px 0 20px;}
  719. .col-form-btn{
  720. display:inline-block;padding:14px 60px;border:none;border-radius:30px;
  721. background:var(--orange);color:#fff;font-size:16px;font-weight:600;
  722. cursor:pointer;transition:.3s;letter-spacing:1px;
  723. }
  724. .col-form-btn:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,117,26,.3);}
  725. /* Form Dialog Overlay */
  726. .col-form-overlay{
  727. position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.5);
  728. display:flex;align-items:center;justify-content:center;
  729. opacity:0;visibility:hidden;transition:.3s;
  730. }
  731. .col-form-overlay.open{opacity:1;visibility:visible;}
  732. .col-form-dialog{
  733. background:#fff;border-radius:12px;width:90%;max-width:520px;
  734. max-height:85vh;display:flex;flex-direction:column;
  735. box-shadow:0 20px 60px rgba(0,0,0,.2);
  736. transform:translateY(20px);transition:.3s;
  737. }
  738. .col-form-overlay.open .col-form-dialog{transform:translateY(0);}
  739. .col-form-dialog-header{
  740. display:flex;align-items:center;justify-content:space-between;
  741. padding:20px 24px;border-bottom:1px solid var(--gray-100);
  742. font-size:18px;font-weight:600;color:var(--gray-900);
  743. }
  744. .col-form-close{
  745. width:32px;height:32px;border:none;background:none;
  746. font-size:24px;color:var(--gray-500);cursor:pointer;transition:.2s;
  747. }
  748. .col-form-close:hover{color:var(--gray-900);}
  749. .col-form-dialog-body{flex:1;overflow-y:auto;padding:24px;}
  750. .col-form-group{margin-bottom:20px;}
  751. .col-form-label{display:block;font-size:14px;font-weight:500;color:var(--gray-700);margin-bottom:8px;}
  752. .col-form-required{color:#E84040;margin-left:2px;}
  753. .col-form-input,.col-form-textarea{
  754. width:100%;padding:10px 14px;border:1px solid var(--gray-100);border-radius:6px;
  755. font-size:14px;color:var(--gray-900);transition:.2s;font-family:inherit;
  756. }
  757. .col-form-input:focus,.col-form-textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 2px rgba(232,117,26,.1);}
  758. .col-form-textarea{resize:vertical;min-height:80px;}
  759. .col-form-options{display:flex;flex-wrap:wrap;gap:12px;}
  760. .col-form-radio,.col-form-checkbox{
  761. display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;color:var(--gray-700);
  762. }
  763. .col-form-radio input,.col-form-checkbox input{accent-color:var(--orange);}
  764. .col-form-upload{display:flex;flex-direction:column;gap:8px;}
  765. .col-form-upload-area{
  766. border:2px dashed var(--gray-100);border-radius:8px;cursor:pointer;transition:.2s;overflow:hidden;
  767. }
  768. .col-form-upload-area:hover{border-color:var(--orange);background:rgba(232,117,26,.02);}
  769. .col-form-upload-preview{min-height:100px;display:flex;align-items:center;justify-content:center;}
  770. .col-form-upload-preview img{max-width:100%;max-height:200px;object-fit:contain;display:block;margin:0 auto;}
  771. .col-form-upload-placeholder{
  772. display:flex;flex-direction:column;align-items:center;gap:8px;
  773. color:var(--gray-400);font-size:13px;padding:24px;
  774. }
  775. .col-form-dialog-footer{padding:16px 24px;border-top:1px solid var(--gray-100);}
  776. .col-form-submit{
  777. display:block;width:100%;padding:12px;border:none;border-radius:8px;
  778. background:var(--orange);color:#fff;font-size:16px;font-weight:600;
  779. cursor:pointer;transition:.3s;
  780. }
  781. .col-form-submit:hover{background:var(--orange-dark);}
  782. /* ===== Inline Form (页面内嵌表单) ===== */
  783. .col-inline-form-wrap{
  784. margin-top:48px;max-width:680px;margin-left:auto;margin-right:auto;
  785. background:var(--gray-bg);border-radius:16px;padding:40px 48px;
  786. border:1px solid var(--gray-100);
  787. }
  788. .col-inline-form-header{text-align:center;margin-bottom:32px;}
  789. .col-inline-form-header h3{
  790. font-size:22px;font-weight:700;color:var(--gray-900);margin-bottom:8px;
  791. position:relative;display:inline-block;
  792. }
  793. .col-inline-form-header h3::after{
  794. content:'';display:block;width:40px;height:3px;
  795. background:linear-gradient(90deg,var(--orange),var(--orange-light));
  796. margin:10px auto 0;border-radius:2px;
  797. }
  798. .col-inline-form-header p{font-size:14px;color:var(--gray-500);margin-top:8px;}
  799. .col-inline-form{display:flex;flex-direction:column;gap:0;}
  800. .col-ifield{margin-bottom:24px;}
  801. .col-ifield-label{display:block;font-size:14px;font-weight:600;color:var(--gray-700);margin-bottom:8px;}
  802. .col-ifield-req{color:#E84040;margin-left:2px;}
  803. .col-ifield-input,.col-ifield-textarea{
  804. width:100%;padding:12px 16px;border:1px solid var(--gray-100);border-radius:8px;
  805. font-size:14px;color:var(--gray-900);transition:.2s;font-family:inherit;
  806. background:#fff;
  807. }
  808. .col-ifield-input:focus,.col-ifield-textarea:focus{
  809. outline:none;border-color:var(--orange);
  810. box-shadow:0 0 0 3px rgba(232,117,26,.1);
  811. }
  812. .col-ifield-textarea{resize:vertical;min-height:100px;}
  813. .col-ifield-options{display:flex;flex-wrap:wrap;gap:16px;}
  814. .col-ifield-radio,.col-ifield-checkbox{
  815. display:flex;align-items:center;gap:8px;cursor:pointer;
  816. font-size:14px;color:var(--gray-700);
  817. padding:8px 16px;background:#fff;border:1px solid var(--gray-100);
  818. border-radius:8px;transition:.2s;
  819. }
  820. .col-ifield-radio:hover,.col-ifield-checkbox:hover{border-color:var(--orange);background:rgba(232,117,26,.02);}
  821. .col-ifield-radio input,.col-ifield-checkbox input{accent-color:var(--orange);}
  822. .col-ifield-upload{display:flex;flex-direction:column;gap:8px;}
  823. .col-ifield-upload-area{
  824. border:2px dashed var(--gray-100);border-radius:12px;cursor:pointer;
  825. transition:.2s;overflow:hidden;background:#fff;
  826. }
  827. .col-ifield-upload-area:hover{border-color:var(--orange);background:rgba(232,117,26,.02);}
  828. .col-ifield-upload-preview{min-height:120px;display:flex;align-items:center;justify-content:center;}
  829. .col-ifield-upload-preview img{max-width:100%;max-height:200px;object-fit:contain;display:block;margin:0 auto;}
  830. .col-ifield-upload-placeholder{
  831. display:flex;flex-direction:column;align-items:center;gap:8px;
  832. color:var(--gray-300);font-size:13px;padding:32px;
  833. }
  834. .col-ifield-submit-wrap{text-align:center;margin-top:8px;}
  835. .col-ifield-submit{
  836. display:inline-block;padding:14px 80px;border:none;border-radius:30px;
  837. background:var(--orange);color:#fff;font-size:16px;font-weight:600;
  838. cursor:pointer;transition:.3s;letter-spacing:1px;
  839. }
  840. .col-ifield-submit:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,117,26,.3);}
  841. .col-ifield-submit:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none;}
  842. /* ========== Article Detail ========== */
  843. .article-detail-wrap{max-width:1200px;margin:0 auto;padding:20px 40px 60px;display:grid;grid-template-columns:1fr 300px;gap:40px;align-items:start;}
  844. .article-detail-main{min-width:0;}
  845. .article-header{margin-bottom:32px;}
  846. .article-title{font-size:32px;font-weight:700;color:var(--gray-900);line-height:1.4;margin-bottom:16px;}
  847. .article-meta{display:flex;gap:24px;align-items:center;flex-wrap:wrap;padding:16px 0;border-bottom:1px solid var(--gray-100);margin-bottom:32px;font-size:14px;color:var(--gray-400);}
  848. .article-meta span{display:flex;align-items:center;gap:6px;}
  849. .article-share{display:flex;align-items:center;gap:8px;margin-left:auto;}
  850. .article-share-label{font-size:14px;color:var(--gray-600);margin-right:4px;}
  851. .article-share-btn{width:32px;height:32px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.3s;background:var(--gray-bg);color:var(--gray-600);}
  852. .article-share-btn.wechat:hover{background:#07C160;color:#fff;transform:translateY(-2px);}
  853. .article-share-btn.weibo:hover{background:#E6162D;color:#fff;transform:translateY(-2px);}
  854. .article-body{font-size:16px;line-height:2;color:var(--gray-700);}
  855. .article-body h2{font-size:20px;font-weight:600;color:var(--gray-900);margin:28px 0 14px;border-left:4px solid var(--orange);padding-left:14px;}
  856. .article-body h3{font-size:17px;font-weight:600;color:var(--gray-900);margin:20px 0 10px;}
  857. .article-body p{margin-bottom:14px;}
  858. .article-body img{max-width:100%;border-radius:6px;margin:12px auto;display:block;}
  859. .article-body blockquote{border-left:4px solid var(--orange);padding:14px 20px;margin:16px 0;background:var(--orange-light);color:var(--gray-600);}
  860. .article-body ul,.article-body ol{padding-left:26px;margin-bottom:14px;}
  861. .article-body li{margin-bottom:6px;}
  862. .article-body table{width:100%;border-collapse:collapse;margin:16px 0;}
  863. .article-body td,.article-body th{border:1px solid var(--gray-100);padding:10px 14px;font-size:14px;}
  864. .article-body th{background:var(--gray-bg);font-weight:600;}
  865. .article-body a{color:var(--orange);}
  866. /* 上一篇/下一篇卡片 */
  867. .article-nav{display:flex;justify-content:space-between;gap:24px;margin-top:48px;padding-top:32px;border-top:1px solid var(--gray-100);}
  868. .article-nav-item{flex:1;padding:20px;background:var(--gray-bg);border-radius:10px;text-decoration:none;transition:.3s;min-width:0;}
  869. .article-nav-item:hover{background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.08);transform:translateY(-2px);}
  870. .article-nav-item.next{text-align:right;}
  871. .article-nav-label{display:block;font-size:13px;color:var(--gray-400);margin-bottom:8px;}
  872. .article-nav-title{display:block;font-size:15px;color:var(--gray-900);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
  873. .article-nav-item:hover .article-nav-title{color:var(--orange);}
  874. .article-nav-item.disabled{pointer-events:none;opacity:.6;}
  875. /* 侧边栏 */
  876. .article-sidebar{position:sticky;top:20px;display:flex;flex-direction:column;gap:24px;}
  877. .sidebar-section{background:var(--gray-bg);border-radius:12px;padding:24px 20px;}
  878. .sidebar-title{font-size:16px;font-weight:600;color:var(--gray-900);margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--orange);}
  879. .related-list{display:flex;flex-direction:column;}
  880. .related-item{display:flex;flex-direction:column;gap:4px;padding:12px 0;border-bottom:1px solid var(--gray-100);text-decoration:none;transition:.2s;}
  881. .related-item:last-child{border-bottom:none;}
  882. .related-item:hover .related-name{color:var(--orange);}
  883. .related-date{font-size:12px;color:var(--gray-400);}
  884. .related-name{font-size:14px;color:var(--gray-600);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:.2s;}
  885. .category-list{display:flex;flex-direction:column;}
  886. .category-item{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;font-size:14px;color:var(--gray-600);text-decoration:none;border-radius:6px;transition:.2s;}
  887. .category-item:hover{color:var(--orange);background:rgba(232,117,26,.08);}
  888. .category-item.active{color:var(--orange);font-weight:600;background:rgba(232,117,26,.08);}
  889. .category-count{font-size:12px;background:var(--gray-100);color:var(--gray-400);padding:2px 8px;border-radius:10px;}
  890. .category-item.active .category-count{background:rgba(232,117,26,.15);color:var(--orange);}
  891. /* 微信分享弹窗 */
  892. .qr-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:10000;align-items:center;justify-content:center;}
  893. .qr-modal.show{display:flex;}
  894. .qr-modal-content{background:#fff;border-radius:12px;padding:32px;text-align:center;max-width:320px;}
  895. .qr-modal-title{font-size:18px;font-weight:600;color:var(--gray-900);margin-bottom:16px;}
  896. .qr-code{width:200px;height:200px;margin:0 auto 16px;background:var(--gray-bg);display:flex;align-items:center;justify-content:center;border-radius:8px;}
  897. .qr-tip{font-size:14px;color:var(--gray-400);margin-bottom:20px;}
  898. .qr-close-btn{width:100%;padding:10px;background:var(--orange);color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:.2s;}
  899. .qr-close-btn:hover{background:#C96012;}
  900. /* ===== Text Card Grid (封面卡片) ===== */
  901. .col-text-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
  902. .col-text-card{
  903. display:block;background:#fff;border-radius:8px;overflow:hidden;
  904. box-shadow:0 4px 16px rgba(0,0,0,.08);transition:.3s;cursor:pointer;
  905. position:relative;
  906. }
  907. .col-text-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(232,117,26,.15);}
  908. .col-text-cover{
  909. width:100%;aspect-ratio:300/426;overflow:hidden;background:var(--gray-bg);position:relative;
  910. }
  911. .col-text-cover img{width:100%;height:100%;object-fit:cover;transition:.3s;}
  912. .col-text-card:hover .col-text-cover img{transform:scale(1.05);}
  913. .col-text-file-tag{
  914. position:absolute;top:12px;right:12px;z-index:2;
  915. padding:4px 12px;border-radius:4px;
  916. background:var(--orange);color:#fff;font-size:12px;font-weight:700;
  917. letter-spacing:.5px;font-family:var(--font-en);
  918. }
  919. .col-text-overlay{
  920. position:absolute;top:0;left:0;right:0;bottom:0;
  921. display:flex;align-items:flex-start;justify-content:center;
  922. padding:24px;padding-top:28%;text-align:center;
  923. }
  924. .col-text-overlay-title{
  925. color:#333;font-size:16px;font-weight:600;line-height:1.8;
  926. text-shadow:0 1px 2px rgba(255,255,255,.8),0 0 8px rgba(255,255,255,.6);
  927. display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
  928. }
  929. .col-text-date-badge{
  930. position:absolute;right:8px;bottom:8px;
  931. padding:4px 10px;border-radius:4px;
  932. background:rgba(0,0,0,.55);color:#fff;font-size:12px;
  933. font-family:var(--font-en);letter-spacing:.5px;
  934. }
  935. .col-text-placeholder{
  936. display:flex;align-items:center;justify-content:center;
  937. background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%);
  938. }
  939. .col-text-placeholder-inner{
  940. text-align:center;padding:24px;color:#fff;
  941. }
  942. .col-text-placeholder-title{
  943. display:block;font-size:16px;font-weight:600;line-height:1.6;
  944. display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
  945. }
  946. .col-text-placeholder-year{
  947. display:block;font-family:var(--font-en);font-size:32px;font-weight:700;
  948. margin-top:12px;opacity:.8;
  949. }
  950. /* (card info removed - using date badge only) */
  951. /* ===== Document List (文档列表样式) ===== */
  952. .doc-list{display:flex;flex-direction:column;}
  953. .doc-item{display:flex;align-items:center;justify-content:space-between;padding:20px 0;border-bottom:1px solid var(--gray-100);transition:.3s;text-decoration:none;cursor:pointer;}
  954. .doc-item:hover{background:rgba(232,117,26,.03);padding-left:16px;padding-right:16px;}
  955. .doc-item:hover .doc-title{color:var(--orange);}
  956. .doc-item-left{display:flex;align-items:center;gap:16px;flex:1;min-width:0;}
  957. .doc-tag{display:inline-block;padding:4px 12px;background:rgba(232,117,26,.08);color:var(--orange);border-radius:4px;font-size:12px;white-space:nowrap;flex-shrink:0;}
  958. .doc-title{font-size:16px;color:var(--gray-900);transition:.3s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  959. .doc-date{font-size:14px;color:var(--gray-400);white-space:nowrap;margin-left:24px;}
  960. /* ===== Text Detail Download ===== */
  961. .text-detail-download{
  962. margin-top:40px;padding:24px;background:var(--gray-bg);border-radius:8px;
  963. text-align:center;
  964. }
  965. .text-download-btn{
  966. display:inline-flex;align-items:center;gap:10px;
  967. padding:12px 32px;background:var(--orange);color:#fff;
  968. border-radius:24px;font-size:15px;font-weight:500;transition:.3s;
  969. }
  970. .text-download-btn:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,117,26,.3);color:#fff;}
  971. .text-download-type{
  972. display:inline-block;padding:2px 8px;background:rgba(255,255,255,.25);
  973. border-radius:3px;font-size:11px;font-weight:600;letter-spacing:.5px;
  974. }
  975. /* Text Grid Responsive */
  976. /* ===== Home Generic Section (text/person/page/job etc.) ===== */
  977. .slide-section{
  978. height:100vh;display:flex;align-items:center;justify-content:center;
  979. background:#F8F9FA;padding:80px 60px;
  980. }
  981. .section-wrap{width:100%;max-width:1200px;margin:0 auto;}
  982. /* Home text grid */
  983. .home-text-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
  984. .home-text-card{
  985. display:block;position:relative;border-radius:8px;overflow:hidden;
  986. aspect-ratio:300/426;background:#eee;transition:transform .3s;
  987. }
  988. .home-text-card:hover{transform:translateY(-4px);}
  989. .home-text-card .cover{width:100%;height:100%;background-size:cover;background-position:center;}
  990. .home-text-card .cover-placeholder{
  991. display:flex;align-items:center;justify-content:center;
  992. background:linear-gradient(135deg,var(--orange),var(--orange-light));
  993. color:#fff;font-size:16px;padding:20px;text-align:center;
  994. }
  995. .home-text-card .date-badge{
  996. position:absolute;bottom:10px;right:10px;
  997. background:rgba(0,0,0,.5);color:#fff;font-size:12px;
  998. padding:2px 8px;border-radius:4px;
  999. }
  1000. /* Home person grid */
  1001. .home-person-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;text-align:center;}
  1002. .home-person-card .avatar{
  1003. width:120px;height:120px;border-radius:50%;margin:0 auto 12px;
  1004. background-size:cover;background-position:center;background-color:#eee;
  1005. }
  1006. .home-person-card .name{font-size:16px;font-weight:600;margin-bottom:4px;}
  1007. .home-person-card .title{font-size:13px;color:var(--gray-500);}
  1008. /* Home page content */
  1009. .home-page-content{max-height:60vh;overflow-y:auto;line-height:1.8;}
  1010. .home-page-content img{max-width:100%;height:auto;}
  1011. /* Slide with footer - allow scroll for content + footer */
  1012. .slide-with-footer{flex-direction:column;justify-content:flex-start;overflow-y:auto;padding-bottom:0;}
  1013. .slide-with-footer .section-wrap{flex:1;display:flex;flex-direction:column;justify-content:center;padding-bottom:20px;}
  1014. .slide-with-footer>.footer-component{margin:0 -60px;width:calc(100% + 120px);flex-shrink:0;}
  1015. /* Home form */
  1016. .home-form-wrap{max-width:600px;margin:20px auto 0;}
  1017. .home-inline-form .home-form-field{margin-bottom:16px;}
  1018. .home-inline-form .home-form-field label{display:block;font-size:14px;color:#333;margin-bottom:6px;font-weight:500;}
  1019. .home-inline-form .home-form-field input,
  1020. .home-inline-form .home-form-field textarea,
  1021. .home-inline-form .home-form-field select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none;transition:border-color .3s;}
  1022. .home-inline-form .home-form-field input:focus,
  1023. .home-inline-form .home-form-field textarea:focus,
  1024. .home-inline-form .home-form-field select:focus{border-color:#ff7800;}
  1025. .home-inline-form .home-form-field textarea{resize:vertical;min-height:80px;}
  1026. .home-form-submit{text-align:center;padding-top:10px;}
  1027. .home-form-submit button{background:#ff7800;color:#fff;border:none;padding:12px 48px;border-radius:6px;font-size:15px;cursor:pointer;transition:background .3s;}
  1028. .home-form-submit button:hover{background:#e66a00;}
  1029. /* Home job list */
  1030. .home-job-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
  1031. .home-job-card{background:#fff;border:1px solid #eee;border-radius:8px;padding:20px;transition:box-shadow .3s;}
  1032. .home-job-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.08);}
  1033. .home-job-card .job-title{font-size:16px;font-weight:600;color:#333;margin-bottom:8px;}
  1034. .home-job-card .job-meta{display:flex;gap:12px;font-size:13px;color:#999;margin-bottom:8px;}
  1035. .home-job-card .job-meta span{display:flex;align-items:center;gap:4px;}
  1036. .home-job-card .job-desc{font-size:13px;color:#666;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
  1037. /* ===== About Intro Section ===== */
  1038. .about-intro-section{margin-bottom:60px;}
  1039. .about-intro-section:last-child{margin-bottom:0;}
  1040. .about-section-header{display:flex;align-items:baseline;gap:12px;margin-bottom:40px;}
  1041. .about-section-header h2{font-size:24px;font-weight:700;color:#1D2129;position:relative;padding-left:14px;}
  1042. .about-section-header h2::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:2px;background:#E8751A;}
  1043. .about-section-header p{font-size:13px;color:#C9CDD4;letter-spacing:2px;}
  1044. .about-section-alt{background:#F7F8FA;border-radius:16px;padding:48px 40px;margin-top:48px;}
  1045. /* Intro Hero */
  1046. .about-intro-hero{display:grid;grid-template-columns:1fr 500px;gap:40px;align-items:end;background:#fff;border:1px solid #F2F3F5;border-radius:16px;padding:36px;}
  1047. .about-intro-hero-text{display:flex;flex-direction:column;gap:16px;}
  1048. .about-intro-hero-text p{font-size:15px;color:#4E5969;line-height:2;}
  1049. .about-intro-hero-img{border-radius:16px;overflow:hidden;border:1px solid #F2F3F5;}
  1050. .about-intro-hero-img img{width:100%;height:auto;display:block;object-fit:cover;}
  1051. /* Stats */
  1052. .about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px;}
  1053. .about-stat-card{background:#fff;border:1px solid #F2F3F5;border-radius:12px;padding:24px 16px;text-align:center;transition:all .2s;}
  1054. .about-stat-card:hover{border-color:#E8751A;box-shadow:0 4px 16px rgba(232,117,26,.1);}
  1055. .about-stat-num{font-size:32px;font-weight:700;color:#E8751A;line-height:1.2;margin-bottom:4px;white-space:nowrap;}
  1056. .about-stat-num span{font-size:14px;font-weight:500;color:#86909C;margin-left:2px;}
  1057. .about-stat-label{font-size:13px;color:#86909C;}
  1058. /* Values */
  1059. .about-values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px;}
  1060. .about-value-card{background:#fff;border:1px solid #F2F3F5;border-radius:12px;padding:28px 24px;text-align:center;transition:all .25s;position:relative;overflow:hidden;}
  1061. .about-value-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:#E8751A;transform:scaleX(0);transition:transform .3s;transform-origin:left;}
  1062. .about-value-card:hover{border-color:#E5E6EB;box-shadow:0 8px 24px rgba(0,0,0,.06);}
  1063. .about-value-card:hover::before{transform:scaleX(1);}
  1064. .about-value-icon{width:64px;height:64px;border-radius:14px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;background:rgba(232,117,26,.1);}
  1065. .about-value-icon img{width:36px;height:36px;filter:brightness(0) saturate(100%) invert(55%) sepia(95%) saturate(600%) hue-rotate(360deg) brightness(95%) contrast(90%);}
  1066. .about-value-card h3{font-size:17px;font-weight:600;color:#1D2129;margin-bottom:8px;}
  1067. .about-value-card p{font-size:14px;color:#86909C;line-height:1.7;}
  1068. .about-scope-card{background:#fff;border:1px solid #F2F3F5;border-radius:12px;padding:28px 32px;}
  1069. .about-scope-card h3{font-size:16px;font-weight:600;color:#1D2129;margin-bottom:14px;padding-left:12px;border-left:3px solid #E8751A;}
  1070. .about-scope-card p{font-size:14px;color:#4E5969;line-height:2;}
  1071. /* Strategy */
  1072. .about-strategy-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
  1073. .about-strategy-card{background:#fff;border:1px solid #F2F3F5;border-radius:12px;overflow:hidden;transition:all .25s;}
  1074. .about-strategy-card:hover{border-color:#E5E6EB;box-shadow:0 8px 24px rgba(0,0,0,.06);transform:translateY(-2px);}
  1075. .about-strategy-img{width:100%;height:220px;object-fit:cover;display:block;background:#F2F3F5;}
  1076. .about-strategy-body{position:relative;padding:40px 24px 28px;text-align:center;}
  1077. .about-strategy-badge{width:56px;height:56px;border-radius:50%;position:absolute;top:-28px;left:50%;transform:translateX(-50%);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.1);border:3px solid #fff;}
  1078. .about-badge-blue{background:linear-gradient(135deg,#165DFF,#3B82F6);}
  1079. .about-badge-orange{background:linear-gradient(135deg,#E8751A,#F5A623);}
  1080. .about-badge-green{background:linear-gradient(135deg,#00B42A,#34D399);}
  1081. .about-badge-red{background:linear-gradient(135deg,#F53F3F,#F76560);}
  1082. .about-badge-purple{background:linear-gradient(135deg,#722ED1,#9254DE);}
  1083. .about-badge-cyan{background:linear-gradient(135deg,#0FC6C2,#14C9C9);}
  1084. .about-badge-gold{background:linear-gradient(135deg,#D4A017,#FAAD14);}
  1085. .about-badge-pink{background:linear-gradient(135deg,#EB2F96,#F759AB);}
  1086. .about-strategy-card h3{font-size:18px;font-weight:600;color:#1D2129;margin-bottom:10px;}
  1087. .about-strategy-card p{font-size:14px;color:#86909C;line-height:1.8;}
  1088. /* Qualifications */
  1089. .about-qual-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
  1090. .about-qual-card{background:#fff;border:1px solid #ebeef0;border-radius:12px;padding:24px 16px;text-align:center;transition:all .25s;}
  1091. .about-qual-card:hover{border-color:#dcdfe3;}
  1092. .about-qual-img{width:100%;height:auto;border-radius:8px;margin-bottom:12px;}
  1093. .about-qual-card h4{font-size:14px;font-weight:600;color:#1D2129;margin-bottom:6px;line-height:1.5;}
  1094. .about-qual-card p{font-size:12px;color:#C9CDD4;line-height:1.6;}
  1095. /* Compliance */
  1096. .about-compliance-banner{background:linear-gradient(135deg,#1D2129 0%,#2A3441 100%);border-radius:16px;padding:40px;color:#fff;position:relative;overflow:hidden;}
  1097. .about-compliance-banner::before{content:'';position:absolute;top:-50px;right:-50px;width:180px;height:180px;border-radius:50%;background:rgba(232,117,26,.12);}
  1098. .about-compliance-banner>*{position:relative;z-index:1;}
  1099. .about-compliance-lead{font-size:14px;color:rgba(255,255,255,.6);line-height:1.9;margin-bottom:28px;}
  1100. .about-compliance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
  1101. .about-compliance-item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:22px;transition:all .2s;}
  1102. .about-compliance-item:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15);}
  1103. .about-compliance-item h4{font-size:15px;color:#E8751A;margin-bottom:8px;font-weight:600;}
  1104. .about-compliance-item p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.8;}
  1105. /* About Intro Responsive */
  1106. /* ===== Contact Us ===== */
  1107. .ct-layout{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:stretch;}
  1108. .ct-info-panel{display:flex;flex-direction:column;gap:20px;}
  1109. .ct-brand-card{background:linear-gradient(135deg,#FFF7ED 0%,#FFF0E0 100%);border-radius:16px;padding:28px 24px;position:relative;overflow:hidden;}
  1110. .ct-brand-card::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;background:rgba(232,117,26,.08);border-radius:50%;}
  1111. .ct-brand-card h3{font-size:20px;font-weight:700;color:#1D2129;margin-bottom:8px;position:relative;z-index:1;}
  1112. .ct-brand-card .ct-en{font-size:13px;color:#86909C;font-style:italic;margin-bottom:12px;position:relative;z-index:1;}
  1113. .ct-brand-card p{font-size:14px;color:#4E5969;line-height:1.8;position:relative;z-index:1;}
  1114. .ct-info-list{background:#fff;border:1px solid #F2F3F5;border-radius:16px;overflow:hidden;}
  1115. .ct-info-row{display:flex;align-items:center;gap:14px;padding:16px 24px;transition:background .2s;}
  1116. .ct-info-row:not(:last-child){border-bottom:1px solid #F7F8FA;}
  1117. .ct-info-row:hover{background:#FAFBFC;}
  1118. .ct-info-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
  1119. .ct-info-icon.orange{background:rgba(232,117,26,.1);}
  1120. .ct-info-icon.blue{background:rgba(22,93,255,.1);}
  1121. .ct-info-icon.green{background:rgba(0,180,42,.1);}
  1122. .ct-info-icon.purple{background:rgba(114,46,209,.1);}
  1123. .ct-info-text{flex:1;}
  1124. .ct-info-text .ct-label{font-size:12px;color:#86909C;margin-bottom:2px;}
  1125. .ct-info-text .ct-value{font-size:14px;color:#1D2129;font-weight:500;}
  1126. .ct-info-text .ct-value a{color:#E8751A;text-decoration:none;}
  1127. .ct-info-text .ct-value a:hover{text-decoration:underline;}
  1128. .ct-qr-row{gap:16px;}
  1129. .ct-qr-inline{width:72px;height:72px;border-radius:10px;border:1px solid #F2F3F5;flex-shrink:0;object-fit:cover;}
  1130. .ct-map-panel{display:flex;flex-direction:column;height:100%;}
  1131. .ct-map-card{background:#fff;border:1px solid #F2F3F5;border-radius:16px;overflow:hidden;flex:1;display:flex;flex-direction:column;}
  1132. .ct-map-header{padding:16px 24px;border-bottom:1px solid #F2F3F5;display:flex;align-items:center;gap:8px;}
  1133. .ct-map-header h4{font-size:15px;font-weight:600;color:#1D2129;}
  1134. .ct-map-body{width:100%;flex:1;min-height:380px;background:#F7F8FA;display:flex;align-items:center;justify-content:center;color:#C9CDD4;font-size:14px;}
  1135. /* Contact Responsive */
  1136. /* Map tooltip */
  1137. .ct-map-tooltip{background:#fff;color:#1D2129;font-size:13px;padding:6px 12px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.15);white-space:nowrap;pointer-events:none;}
  1138. #ct-ol-map{min-height:380px;}
  1139. #ct-ol-map canvas{border-radius:0 0 16px 16px;}
  1140. /* ===== Search Result Page ===== */
  1141. .search-header{background:#fff;padding:16px 0;box-shadow:0 2px 8px rgba(0,0,0,.04);}
  1142. .search-header-inner{max-width:1200px;margin:0 auto;padding:0 20px;}
  1143. .search-box{max-width:800px;margin:0 auto;display:flex;align-items:center;background:#F5F6F8;border-radius:50px;padding:0 8px 0 32px;border:1px solid var(--orange);height:56px;}
  1144. .search-box input{flex:1;border:none;background:transparent;outline:none;font-size:16px;padding:0;height:100%;font-family:var(--font-cn);color:var(--gray-900);}
  1145. .search-box input::placeholder{color:var(--gray-300);}
  1146. .search-box-btn{background:var(--orange);border:none;cursor:pointer;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0;}
  1147. .search-box-btn:hover{background:var(--orange-dark);}
  1148. .search-clear-btn{background:none;border:none;cursor:pointer;color:var(--gray-300);width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:color .2s;}
  1149. .search-clear-btn:hover{color:var(--gray-500);}
  1150. .search-container{max-width:1200px;margin:0 auto;padding:40px 20px 60px;}
  1151. .search-info{margin-bottom:32px;padding-bottom:20px;border-bottom:2px solid #E4E7ED;}
  1152. .search-keyword-text{font-size:18px;color:var(--gray-900);margin-bottom:8px;}
  1153. .search-keyword-text .kw{color:var(--orange);font-weight:600;}
  1154. .search-stats{font-size:14px;color:var(--gray-500);}
  1155. .filter-tabs{display:flex;gap:16px;margin-bottom:32px;flex-wrap:wrap;}
  1156. .filter-tab{padding:8px 24px;font-size:14px;color:#606266;background:#fff;border:1px solid #DCDFE6;border-radius:20px;cursor:pointer;transition:.3s;text-decoration:none;}
  1157. .filter-tab:hover{color:var(--orange);border-color:var(--orange);}
  1158. .filter-tab.active{color:#fff;background:var(--orange);border-color:var(--orange);}
  1159. .result-list{display:flex;flex-direction:column;gap:24px;}
  1160. .result-item{background:#fff;border-radius:12px;padding:32px;border:1px solid #F2F3F5;transition:all .25s;display:block;text-decoration:none;color:inherit;}
  1161. .result-item:hover{border-color:#E5E6EB;box-shadow:0 8px 24px rgba(0,0,0,.06);}
  1162. .result-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
  1163. .result-type{display:inline-block;padding:4px 12px;background:#FFF8F0;color:var(--orange);border-radius:4px;font-size:12px;font-weight:600;}
  1164. .result-date{font-size:14px;color:var(--gray-500);}
  1165. .result-title{font-size:20px;font-weight:600;color:var(--gray-900);margin-bottom:12px;line-height:1.4;}
  1166. .result-title .highlight{color:var(--orange);background:rgba(232,117,26,.1);padding:0 4px;}
  1167. .result-desc{font-size:15px;line-height:1.8;color:#606266;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
  1168. .result-desc .highlight{color:var(--orange);font-weight:600;}
  1169. .result-footer{margin-top:16px;padding-top:16px;border-top:1px solid #F5F6F8;display:flex;align-items:center;justify-content:space-between;}
  1170. .result-path{font-size:13px;color:var(--gray-500);}
  1171. .result-more{font-size:14px;color:var(--orange);display:flex;align-items:center;gap:4px;}
  1172. .search-empty{text-align:center;padding:80px 20px;background:#fff;border-radius:12px;}
  1173. .search-empty-icon{font-size:64px;color:#C0C4CC;margin-bottom:24px;}
  1174. .search-empty h3{font-size:20px;color:var(--gray-900);margin-bottom:12px;}
  1175. .search-empty p{font-size:15px;color:var(--gray-500);line-height:1.8;}
  1176. .search-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:40px;}
  1177. .page-btn{min-width:40px;height:40px;padding:0 12px;background:#fff;border:1px solid #DCDFE6;border-radius:6px;font-size:14px;color:#606266;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center;text-decoration:none;}
  1178. .page-btn:hover{color:var(--orange);border-color:var(--orange);}
  1179. .page-btn.active{color:#fff;background:var(--orange);border-color:var(--orange);}
  1180. .page-btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;}
  1181. /* ========== Project List ========== */
  1182. .project-list { display: flex; flex-direction: column; gap: 32px; }
  1183. .project-item {
  1184. display: grid; grid-template-columns: 445px 1fr; gap: 32px;
  1185. background: #fff; border-radius: 12px; overflow: hidden;
  1186. border: 1px solid #F2F3F5; transition: all 0.25s;
  1187. text-decoration: none; color: inherit;
  1188. }
  1189. .project-item:hover { border-color: #E5E6EB; box-shadow: 0 8px 24px rgba(0,0,0,0.06); }
  1190. .project-cover {
  1191. width: 445px; height: 280px; background: #F5F6F8;
  1192. display: flex; align-items: center; justify-content: center; overflow: hidden;
  1193. }
  1194. .project-cover img { width: 100%; height: 100%; object-fit: cover; }
  1195. .project-cover-placeholder { font-size: 16px; color: #909399; }
  1196. .project-info { padding: 32px 32px 32px 0; display: flex; flex-direction: column; justify-content: space-between; }
  1197. .project-header { margin-bottom: 16px; }
  1198. .project-title { font-size: 22px; font-weight: 600; color: #303133; margin-bottom: 12px; line-height: 1.4; }
  1199. .project-meta { display: flex; align-items: center; gap: 16px; font-size: 14px; color: #909399; }
  1200. .project-tag { display: inline-block; padding: 4px 12px; background: #FFF8F0; color: #E8751A; border-radius: 4px; font-size: 12px; }
  1201. .project-date { display: flex; align-items: center; gap: 4px; }
  1202. .project-desc {
  1203. font-size: 15px; line-height: 1.8; color: #606266; margin-bottom: 20px;
  1204. display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;
  1205. }
  1206. .project-footer { display: flex; align-items: center; justify-content: space-between; }
  1207. .project-stats { display: flex; gap: 24px; font-size: 14px; color: #909399; }
  1208. .project-stat-item { display: flex; align-items: center; gap: 6px; }
  1209. .project-stat-item .label { color: #909399; }
  1210. .project-stat-item .value { color: #E8751A; font-weight: 600; }
  1211. .view-detail-btn {
  1212. padding: 8px 24px; background: transparent; color: #E8751A;
  1213. border: 1px solid #E8751A; border-radius: 20px; font-size: 14px;
  1214. cursor: pointer; transition: 0.3s; display: inline-block;
  1215. }
  1216. .view-detail-btn:hover { background: #E8751A; color: #fff; }
  1217. @media (max-width: 768px) {
  1218. .view-detail-btn { display: none; }
  1219. }
  1220. /* ========== Project Detail ========== */
  1221. .proj-detail-wrap {
  1222. max-width: 1200px; margin: 0 auto; padding: 40px 0 60px;
  1223. display: grid; grid-template-columns: 1fr 280px; gap: 40px; align-items: start;
  1224. }
  1225. .proj-detail-main:only-child { grid-column: 1 / -1; }
  1226. .proj-detail-main { background: #fff; }
  1227. .proj-detail-title { font-size: 32px; font-weight: 700; color: #303133; margin-bottom: 16px; line-height: 1.4; }
  1228. .proj-detail-meta {
  1229. display: flex; gap: 24px; align-items: center; padding: 16px 0;
  1230. border-bottom: 1px solid #E4E7ED; margin-bottom: 32px; font-size: 14px; color: #909399;
  1231. }
  1232. .proj-detail-meta span{display:flex;align-items:center;gap:6px;}
  1233. .proj-section { margin-bottom: 48px; }
  1234. .proj-section:last-child { margin-bottom: 0; }
  1235. .proj-section-title {
  1236. font-size: 24px; font-weight: 700; color: #303133;
  1237. margin-bottom: 20px; padding-bottom: 12px; border-bottom: 2px solid #E8751A;
  1238. }
  1239. .proj-section-content { font-size: 16px; line-height: 2; color: #606266; }
  1240. .proj-section-content p { margin-bottom: 16px; }
  1241. .proj-section-content img { max-width: 100%; border-radius: 8px; margin: 24px auto; display: block; }
  1242. /* Timeline */
  1243. .proj-timeline { position: relative; padding-left: 0; }
  1244. .proj-timeline-item {
  1245. display: grid; grid-template-columns: 120px 1fr; gap: 40px;
  1246. margin-bottom: 48px; position: relative;
  1247. }
  1248. .proj-timeline-item:last-child { margin-bottom: 0; }
  1249. .proj-timeline-item::before {
  1250. content: ""; position: absolute; left: 140px; top: 30px; bottom: -62px;
  1251. width: 2px; background: #E4E7ED; transform: translateX(-50%);
  1252. }
  1253. .proj-timeline-item:last-child::before { display: none; }
  1254. .proj-timeline-item::after {
  1255. content: ""; position: absolute; left: 140px; top: 16px;
  1256. width: 12px; height: 12px; background: #E8751A; border-radius: 50%;
  1257. border: 3px solid #fff; box-shadow: 0 0 0 2px #E8751A;
  1258. transform: translateX(-50%); z-index: 1;
  1259. }
  1260. .proj-timeline-date { text-align: right; padding-top: 4px; position: relative; white-space: nowrap; }
  1261. .proj-timeline-year { font-size: 18px; font-weight: 700; color: #E8751A; }
  1262. .proj-timeline-body { background: #F5F6F8; border-radius: 12px; padding: 24px 28px; min-width: 0; overflow: hidden; }
  1263. .proj-timeline-year-mobile { display: none; font-size: 16px; font-weight: 700; color: #E8751A; margin-bottom: 12px; }
  1264. .proj-timeline-title { font-size: 20px; font-weight: 700; color: #303133; margin-bottom: 12px; }
  1265. .proj-timeline-period { font-size: 16px; font-weight: 600; color: #606266; margin-bottom: 16px; }
  1266. .proj-timeline-body p { font-size: 15px; line-height: 2; color: #606266; margin-bottom: 20px; }
  1267. .proj-timeline-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 20px; }
  1268. .proj-timeline-stat { display: flex; align-items: baseline; font-size: 14px; }
  1269. .proj-stat-label { color: #909399; margin-right: 8px; white-space: nowrap; }
  1270. .proj-stat-value { color: #303133; font-weight: 500; }
  1271. /* Sidebar Anchor Nav */
  1272. .proj-detail-sidebar { position: sticky; top: 80px; }
  1273. .proj-anchor-nav { background: #F5F6F8; border-radius: 12px; padding: 24px 20px; }
  1274. .proj-anchor-title {
  1275. font-size: 16px; font-weight: 600; color: #303133;
  1276. margin-bottom: 16px; padding-bottom: 12px; border-bottom: 2px solid #E8751A;
  1277. }
  1278. .proj-anchor-list { display: flex; flex-direction: column; }
  1279. .proj-anchor-item {
  1280. padding: 10px 16px; font-size: 15px; color: #606266; cursor: pointer;
  1281. transition: 0.2s; border-radius: 6px; text-decoration: none; display: block;
  1282. border-left: 3px solid transparent;
  1283. }
  1284. .proj-anchor-item:hover { color: #E8751A; background: rgba(232,117,26,0.08); padding-left: 20px; }
  1285. .proj-anchor-item.active {
  1286. color: #E8751A; background: rgba(232,117,26,0.08);
  1287. border-left-color: #E8751A; font-weight: 600;
  1288. }
  1289. /* ========== Side Toolbar ========== */
  1290. .side-toolbar {
  1291. position: fixed; right: 20px; bottom: 120px; z-index: 999;
  1292. display: flex; flex-direction: column; gap: 4px;
  1293. opacity: 0; visibility: hidden; transform: translateY(20px);
  1294. transition: opacity .3s, visibility .3s, transform .3s;
  1295. }
  1296. .side-toolbar.show { opacity: 1; visibility: visible; transform: translateY(0); }
  1297. .side-tool {
  1298. width: 48px; height: 48px; background: #E8751A; border-radius: 8px;
  1299. display: flex; align-items: center; justify-content: center;
  1300. cursor: pointer; transition: background .2s, box-shadow .2s;
  1301. box-shadow: 0 2px 12px rgba(232,117,26,0.3);
  1302. }
  1303. .side-tool:hover { background: #d06816; box-shadow: 0 4px 20px rgba(232,117,26,0.45); }
  1304. .side-tool-icon { width: 24px; height: 24px; }
  1305. /* QR popover */
  1306. .side-tool-qr { position: relative; }
  1307. .side-tool-qrpop {
  1308. position: absolute; right: 56px; bottom: -20px;
  1309. background: #fff; border-radius: 10px; padding: 16px;
  1310. box-shadow: 0 4px 24px rgba(0,0,0,0.15);
  1311. opacity: 0; visibility: hidden; transform: translateX(8px);
  1312. transition: opacity .25s, visibility .25s, transform .25s;
  1313. display: flex; flex-direction: column; align-items: center; gap: 10px;
  1314. pointer-events: none; white-space: nowrap; min-width: 160px;
  1315. }
  1316. .side-tool-qr:hover .side-tool-qrpop {
  1317. opacity: 1; visibility: visible; transform: translateX(0); pointer-events: auto;
  1318. }
  1319. .side-tool-qrpop-tip { font-size: 12px; color: #b0b0b0; }
  1320. .side-tool-qrpop img { width: 130px; height: 130px; border-radius: 6px; display: block; }