@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+SC:wght@400;500;600;700&display=swap";:root{color:#1e293b;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;font-family:Inter,Noto Sans SC,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow-x:hidden}body{min-width:320px;min-height:100vh;margin:0}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}a{color:#6366f1;font-weight:500;text-decoration:none;transition:color .2s}a:hover{color:#4f46e5}h1,h2,h3,h4,h5,h6{color:#1e293b;font-weight:600;line-height:1.3}button{cursor:pointer;font-family:inherit}img{max-width:100%;height:auto}::selection{color:#1e293b;background-color:#6366f126}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.site-header{z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;border-bottom:1px solid #e2e8f0;height:60px;transition:box-shadow .3s;position:fixed;top:0;left:0;right:0}.site-header:hover{box-shadow:0 1px 2px #0000000d}.site-header .header-inner{align-items:center;gap:32px;max-width:1400px;height:100%;margin:0 auto;padding:0 24px;display:flex}.site-header .header-logo{flex-shrink:0;align-items:center;gap:10px;text-decoration:none;transition:opacity .2s;display:flex}.site-header .header-logo:hover{opacity:.85}.site-header .header-logo .logo-icon{align-items:center;display:flex}.site-header .header-logo .logo-text{color:#1e293b;letter-spacing:.5px;font-size:18px;font-weight:700}.site-header .header-nav{flex:1;align-items:center;gap:4px;display:flex}.site-header .header-nav .nav-item{color:#64748b;white-space:nowrap;cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.site-header .header-nav .nav-item .nav-icon{align-items:center;font-size:15px;display:flex}.site-header .header-nav .nav-item:hover{color:#1890ff;background:#eef2ff}.site-header .header-nav .nav-item.active{color:#1890ff;background:#eef2ff;font-weight:600}.site-header .header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.site-header .header-actions .search-trigger{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:all .2s;display:flex}.site-header .header-actions .search-trigger:hover{color:#1890ff;background:#eef2ff;border-color:#1890ff}.site-header .header-actions .mobile-toggle{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:all .2s;display:none}.site-header .header-actions .mobile-toggle:hover{color:#1890ff;border-color:#1890ff}.site-header .mobile-overlay{display:none}@media (max-width:768px){.site-header .header-inner{padding:0 16px}.site-header .header-nav{z-index:999;background:#fff;border-bottom:1px solid #e2e8f0;flex-direction:column;gap:4px;padding:16px;display:none;position:fixed;top:60px;left:0;right:0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.site-header .header-nav.mobile-open{display:flex}.site-header .header-nav .nav-item{border-radius:6px;width:100%;padding:12px 16px;font-size:15px}.site-header .header-actions .mobile-toggle{display:flex}.site-header .mobile-overlay{z-index:998;background:#0000004d;display:block;position:fixed;inset:60px 0 0}}@media (max-width:576px){.site-header .header-inner{gap:12px;padding:0 12px}.site-header .header-logo .logo-text{font-size:16px}}.mobile-bottom-nav{z-index:1000;background:#fff;border-top:1px solid #e2e8f0;justify-content:space-around;align-items:stretch;height:56px;display:none;position:fixed;bottom:0;left:0;right:0}@media (max-width:768px){.mobile-bottom-nav{display:flex}}.mobile-bottom-nav .nav-item{color:#94a3b8;cursor:pointer;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;text-decoration:none;transition:color .2s;display:flex}.mobile-bottom-nav .nav-item .icon{font-size:20px;line-height:1}.mobile-bottom-nav .nav-item .label{font-size:11px;font-weight:500}.mobile-bottom-nav .nav-item.active,.mobile-bottom-nav .nav-item:hover{color:#1890ff}.app-sidebar{z-index:100;background:#fff;border-right:1px solid #e2e8f0;width:220px;transition:transform .3s;position:fixed;top:60px;bottom:0;left:0;overflow:hidden}.app-sidebar .sidebar-scroll{height:100%;padding:16px 12px;overflow-y:auto}.app-sidebar .sidebar-scroll::-webkit-scrollbar{width:4px}.app-sidebar .sidebar-scroll::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:2px}.app-sidebar .sidebar-group{margin-bottom:24px}.app-sidebar .sidebar-group .sidebar-group-title{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 12px;font-size:11px;font-weight:600}.app-sidebar .sidebar-group .sidebar-item{color:#64748b;cursor:pointer;border-radius:6px;align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.app-sidebar .sidebar-group .sidebar-item .sidebar-item-icon{flex-shrink:0;align-items:center;width:20px;font-size:16px;display:flex}.app-sidebar .sidebar-group .sidebar-item .sidebar-item-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.app-sidebar .sidebar-group .sidebar-item:hover{color:#1890ff;background:#eef2ff}.app-sidebar .sidebar-group .sidebar-item.active{color:#1890ff;background:#eef2ff;font-weight:600}.app-sidebar .sidebar-group .sidebar-item.active .sidebar-item-icon{color:#1890ff}@media (max-width:992px){.app-sidebar{transform:translate(-100%)}.app-sidebar.open{transform:translate(0);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}}.app-layout{width:100%;min-height:100vh;padding-top:60px;display:flex}.app-main{flex:1;width:100%;min-height:calc(100vh - 60px);transition:margin-left .3s}.app-main.with-sidebar{margin-left:220px}@media (max-width:992px){.app-main.with-sidebar{margin-left:0}}.home-page{background:#f8fafc;min-height:calc(100vh - 60px)}.home-page .hero-section{text-align:center;background:linear-gradient(135deg,#eef2ff 0%,#f5f3ff 50%,#eff6ff 100%);padding:60px 24px 48px}@media (max-width:768px){.home-page .hero-section{padding:40px 16px 36px}}.home-page .hero-section .hero-content{max-width:640px;margin:0 auto}.home-page .hero-section .hero-title{color:#1890ff;letter-spacing:1px;margin-bottom:12px;font-size:42px;font-weight:700}@media (max-width:768px){.home-page .hero-section .hero-title{font-size:32px}}@media (max-width:576px){.home-page .hero-section .hero-title{font-size:28px}}.home-page .hero-section .hero-subtitle{color:#64748b;margin-bottom:32px;font-size:16px;font-weight:400}@media (max-width:576px){.home-page .hero-section .hero-subtitle{margin-bottom:24px;font-size:14px}}.home-page .hero-section .quick-links{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:flex}.home-page .hero-section .quick-links .quick-tag{color:#1890ff;cursor:pointer;background:#6366f114;border-radius:9999px;padding:4px 14px;font-size:12px;font-weight:500;transition:all .2s;display:inline-block}.home-page .hero-section .quick-links .quick-tag:hover{color:#4f46e5;background:#6366f129}.home-page .resources-section{padding:32px 24px 48px}@media (max-width:768px){.home-page .resources-section{padding:24px 16px 36px}}@media (max-width:576px){.home-page .resources-section{padding:20px 12px 28px}}.home-page .resources-section .resources-container{max-width:1200px;margin:0 auto}.home-page .resources-section .resource-group{margin-bottom:36px}.home-page .resources-section .resource-group .group-header{align-items:center;margin-bottom:16px;display:flex}.home-page .resources-section .resource-group .group-header .group-tag{color:#fff;letter-spacing:.3px;border-radius:9999px;align-items:center;padding:4px 14px;font-size:12px;font-weight:600;display:inline-flex}.home-page .resources-section .resource-group .group-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}@media (max-width:576px){.home-page .resources-section .resource-group .group-grid{grid-template-columns:1fr;gap:10px}}.home-page .resources-section .resource-group .resource-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:12px;align-items:center;gap:14px;padding:16px 18px;transition:all .2s;display:flex}.home-page .resources-section .resource-group .resource-card:hover{border-color:#e2e8f0;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.home-page .resources-section .resource-group .resource-card .card-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;display:flex}.home-page .resources-section .resource-group .resource-card .card-info{flex:1;min-width:0}.home-page .resources-section .resource-group .resource-card .card-info .card-title{color:#1e293b;margin-bottom:3px;font-size:14px;font-weight:600}.home-page .resources-section .resource-group .resource-card .card-info .card-desc{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.home-page .home-footer{text-align:center;background:#fff;border-top:1px solid #e2e8f0;padding:20px 24px}.home-page .home-footer .footer-inner{color:#94a3b8;font-size:12px}.home-page .home-footer .footer-inner .footer-dot{margin:0 8px}.about-page{max-width:900px;margin:0 auto;padding:32px 24px 60px}@media (max-width:768px){.about-page{padding:24px 16px 48px}}@media (max-width:576px){.about-page{padding:16px 12px 40px}}.about-page .section-title{color:#1e293b;border-left:4px solid #1890ff;margin-bottom:20px;padding-left:12px;font-size:22px;font-weight:700;line-height:1.2}.about-page .profile-hero{text-align:center;padding:40px 0 32px}@media (max-width:576px){.about-page .profile-hero{padding:28px 0 24px}}.about-page .profile-hero .profile-avatar{margin-bottom:16px;display:inline-block;position:relative}.about-page .profile-hero .profile-avatar .avatar-placeholder{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;display:flex;box-shadow:0 6px 20px #6366f14d}.about-page .profile-hero .profile-avatar .status-dot{background:#22c55e;border:3px solid #fff;border-radius:50%;width:16px;height:16px;position:absolute;bottom:4px;right:4px}.about-page .profile-hero .profile-name{color:#1e293b;margin-bottom:6px;font-size:28px;font-weight:700}@media (max-width:576px){.about-page .profile-hero .profile-name{font-size:24px}}.about-page .profile-hero .profile-subtitle{color:#64748b;margin-bottom:18px;font-size:16px}.about-page .profile-hero .profile-tags{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.about-page .profile-hero .profile-tags .ptag{color:#fff;letter-spacing:.3px;border-radius:9999px;padding:4px 16px;font-size:12px;font-weight:600;display:inline-block}.about-page .intro-section{margin-bottom:36px}.about-page .intro-section .intro-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:28px 30px;position:relative}.about-page .intro-section .intro-card:before{content:"";background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:16px 16px 0 0;height:4px;position:absolute;top:0;left:0;right:0}.about-page .intro-section .intro-card .intro-label{color:#1890ff;background:#eef2ff;border-radius:9999px;align-items:center;gap:6px;margin-bottom:18px;padding:4px 14px;font-size:12px;font-weight:600;display:inline-flex}.about-page .intro-section .intro-card .intro-text{color:#64748b;margin-bottom:10px;font-size:14px;line-height:1.85}.about-page .intro-section .intro-card .intro-text.last{margin-bottom:0}.about-page .intro-section .intro-card .intro-text strong{color:#1890ff;font-weight:600}.about-page .tech-section{margin-bottom:36px}.about-page .tech-section .tech-group{margin-bottom:20px}.about-page .tech-section .tech-group:last-child{margin-bottom:0}.about-page .tech-section .tech-group .tech-group-header{margin-bottom:12px}.about-page .tech-section .tech-group .tech-group-header .tech-group-tag{color:#fff;border-radius:9999px;align-items:center;padding:4px 14px;font-size:12px;font-weight:600;display:inline-flex}.about-page .tech-section .tech-group .tech-list{flex-wrap:wrap;gap:10px;display:flex}.about-page .tech-section .tech-group .tech-list .tech-chip{cursor:default;background:#fff;border:1.5px solid;border-radius:9999px;align-items:center;gap:6px;padding:7px 16px;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex}.about-page .tech-section .tech-group .tech-list .tech-chip .chip-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.about-page .tech-section .tech-group .tech-list .tech-chip:hover{transform:translateY(-1px);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.about-page .services-section{margin-bottom:36px}.about-page .services-section .services-grid{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}@media (max-width:768px){.about-page .services-section .services-grid{grid-template-columns:1fr}}.about-page .services-section .service-card{background:#fff;border:1px solid #f1f5f9;border-radius:12px;padding:24px;transition:all .2s}.about-page .services-section .service-card:hover{border-color:#e2e8f0;transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.about-page .services-section .service-card .svc-icon{border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;margin-bottom:14px;display:flex}.about-page .services-section .service-card .svc-title{color:#1e293b;margin-bottom:12px;font-size:16px;font-weight:600}.about-page .services-section .service-card .svc-list{margin:0;padding:0;list-style:none}.about-page .services-section .service-card .svc-list li{color:#64748b;align-items:center;gap:7px;padding:4px 0;font-size:14px;display:flex}.about-page .services-section .service-card .svc-list li .anticon{flex-shrink:0;font-size:13px}.about-page .process-section{margin-bottom:36px}.about-page .process-section .process-track{align-items:flex-start;display:flex}@media (max-width:768px){.about-page .process-section .process-track{flex-direction:column;align-items:stretch}}.about-page .process-section .process-node{text-align:center;flex:1;padding:16px 12px}@media (max-width:768px){.about-page .process-section .process-node{text-align:left;align-items:center;gap:16px;padding:12px 0;display:flex}}.about-page .process-section .process-node .node-circle{color:#1890ff;background:#eef2ff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 10px;font-size:22px;display:flex}@media (max-width:768px){.about-page .process-section .process-node .node-circle{width:44px;height:44px;margin:0;font-size:18px}}.about-page .process-section .process-node .node-step{color:#1890ff2e;margin-bottom:4px;font-size:28px;font-weight:700}@media (max-width:768px){.about-page .process-section .process-node .node-step{display:none}}.about-page .process-section .process-node .node-title{color:#1e293b;margin-bottom:3px;font-size:14px;font-weight:600}.about-page .process-section .process-node .node-desc{color:#94a3b8;font-size:12px}.about-page .process-section .track-line{background:#e2e8f0;flex-shrink:0;width:40px;height:2px;margin-top:40px}@media (max-width:768px){.about-page .process-section .track-line{width:2px;height:20px;margin:0 0 0 21px}}.about-page .advantage-section{margin-bottom:36px}.about-page .advantage-section .advantage-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (max-width:768px){.about-page .advantage-section .advantage-grid{grid-template-columns:1fr}}.about-page .advantage-section .advantage-item{text-align:center;background:linear-gradient(135deg,#eef2ff 0%,#f5f3ff 50%,#eff6ff 100%);border:1px solid #f1f5f9;border-radius:12px;padding:24px 20px}.about-page .advantage-section .advantage-item .adv-icon{color:#1890ff;margin-bottom:12px;font-size:28px}.about-page .advantage-section .advantage-item .adv-title{color:#1e293b;margin-bottom:6px;font-size:14px;font-weight:600}.about-page .advantage-section .advantage-item .adv-desc{color:#64748b;font-size:12px}.about-page .contact-section .contact-card{text-align:center;background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:36px 32px}@media (max-width:576px){.about-page .contact-section .contact-card{padding:28px 20px}}.about-page .contact-section .contact-card .contact-title{color:#1890ff;margin-bottom:8px;font-size:24px;font-weight:700}.about-page .contact-section .contact-card .contact-desc{color:#64748b;margin-bottom:20px;font-size:14px}.about-page .contact-section .contact-card .contact-rows{flex-direction:column;gap:10px;margin-bottom:24px;display:inline-flex}.about-page .contact-section .contact-card .contact-rows .contact-row{color:#1e293b;align-items:center;gap:10px;font-size:14px;display:flex}.about-page .contact-section .contact-card .contact-rows .contact-row .anticon{color:#1890ff;font-size:18px}.about-page .contact-section .contact-card .contact-tip{color:#64748b;background:#eef2ff;border-radius:6px;margin-top:16px;padding:12px 16px;font-size:12px;line-height:1.6}.blog-container{max-width:800px;margin:0 auto;padding:32px 24px}@media (max-width:768px){.blog-container{padding:24px 16px}}.blog-container .developing-section{justify-content:center;align-items:center;min-height:50vh;display:flex}.blog-container .developing-section .developing-card{text-align:center;border:1px solid #f1f5f9;border-radius:16px}.blog-container .developing-section .developing-card .developing-content{padding:20px}.blog-container .developing-section .developing-card .developing-content h2{color:#1e293b;margin-bottom:12px;font-size:24px}.blog-container .developing-section .developing-card .developing-content p{color:#64748b;margin-bottom:0;font-size:14px}.blog-container .developing-section .developing-card .developing-content .developing-icon{margin-top:16px;font-size:48px}.tech-category-page{max-width:960px;margin:0 auto;padding:32px 24px}@media (max-width:768px){.tech-category-page{padding:24px 16px}}.tech-category-page .page-header{margin-bottom:36px}.tech-category-page .page-header .page-title{color:#1e293b;margin-bottom:8px;font-size:28px;font-weight:700}.tech-category-page .page-header .page-desc{color:#64748b;margin:0;font-size:16px}.tech-category-page .categories-container .category-section{margin-bottom:36px}.tech-category-page .categories-container .category-section .section-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.tech-category-page .categories-container .category-section .section-header .section-indicator{border-radius:2px;flex-shrink:0;width:4px;height:36px}.tech-category-page .categories-container .category-section .section-header .section-title{color:#1e293b;margin-bottom:2px;font-size:20px;font-weight:600}.tech-category-page .categories-container .category-section .section-header .section-desc{color:#94a3b8;margin:0;font-size:12px}.tech-category-page .categories-container .category-section .section-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;display:grid}@media (max-width:576px){.tech-category-page .categories-container .category-section .section-grid{grid-template-columns:1fr}}.tech-category-page .categories-container .category-section .category-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:12px;align-items:center;gap:14px;padding:16px 18px;transition:all .2s;display:flex}.tech-category-page .categories-container .category-section .category-card:hover{border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.tech-category-page .categories-container .category-section .category-card:hover .arrow-icon{opacity:1;transform:translate(2px)}.tech-category-page .categories-container .category-section .category-card .category-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.tech-category-page .categories-container .category-section .category-card .category-info{flex:1;min-width:0}.tech-category-page .categories-container .category-section .category-card .category-info .category-name{color:#1e293b;margin-bottom:3px;font-size:14px;font-weight:600}.tech-category-page .categories-container .category-section .category-card .category-info .category-detail{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.tech-category-page .categories-container .category-section .category-card .arrow-icon{color:#94a3b8;opacity:0;flex-shrink:0;transition:all .2s}.resources-page{max-width:1200px;margin:0 auto;padding:32px 24px}@media (max-width:768px){.resources-page{padding:24px 16px}}.resources-page .page-header{margin-bottom:36px}.resources-page .page-header .page-title{color:#1e293b;margin-bottom:8px;font-size:28px;font-weight:700}.resources-page .page-header .page-desc{color:#64748b;margin:0;font-size:16px}.resources-page .resources-container .resource-section{margin-bottom:36px}.resources-page .resources-container .resource-section .section-header{margin-bottom:16px}.resources-page .resources-container .resource-section .section-header .section-tag{color:#fff;border-radius:9999px;align-items:center;padding:4px 14px;font-size:12px;font-weight:600;display:inline-flex}.resources-page .resources-container .resource-section .section-grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:12px;display:grid}@media (max-width:576px){.resources-page .resources-container .resource-section .section-grid{grid-template-columns:1fr}}.resources-page .resources-container .resource-section .resource-link-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:12px;align-items:center;gap:14px;padding:16px 18px;transition:all .2s;display:flex}.resources-page .resources-container .resource-section .resource-link-card:hover{border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.resources-page .resources-container .resource-section .resource-link-card:hover .external-icon{opacity:1;transform:translate(1px,-1px)}.resources-page .resources-container .resource-section .resource-link-card .link-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;display:flex}.resources-page .resources-container .resource-section .resource-link-card .link-info{flex:1;min-width:0}.resources-page .resources-container .resource-section .resource-link-card .link-info .link-title{color:#1e293b;margin-bottom:3px;font-size:14px;font-weight:600}.resources-page .resources-container .resource-section .resource-link-card .link-info .link-desc{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.resources-page .resources-container .resource-section .resource-link-card .external-icon{color:#94a3b8;opacity:0;flex-shrink:0;transition:all .2s}.cooperation-page{max-width:1000px;margin:0 auto;padding:32px 24px}@media (max-width:768px){.cooperation-page{padding:24px 16px}}.cooperation-page .page-header{margin-bottom:36px}.cooperation-page .page-header .page-title{color:#1e293b;margin-bottom:8px;font-size:28px;font-weight:700}.cooperation-page .page-header .page-desc{color:#64748b;margin:0;font-size:16px}.cooperation-page .cooperation-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:48px;display:grid}@media (max-width:576px){.cooperation-page .cooperation-grid{grid-template-columns:1fr}}.cooperation-page .cooperation-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:12px;padding:24px;transition:all .2s}.cooperation-page .cooperation-card:hover{border-color:#e2e8f0;transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.cooperation-page .cooperation-card .coop-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;font-size:24px;display:flex}.cooperation-page .cooperation-card .coop-title{color:#1e293b;margin-bottom:8px;font-size:16px;font-weight:600}.cooperation-page .cooperation-card .coop-desc{color:#64748b;margin:0;font-size:14px;line-height:1.6}.cooperation-page .contact-section .contact-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;gap:24px;padding:32px;display:flex}@media (max-width:576px){.cooperation-page .contact-section .contact-card{text-align:center;flex-direction:column;align-items:center;padding:24px}}.cooperation-page .contact-section .contact-card .contact-icon{color:#1890ff;background:#eef2ff;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;display:flex}.cooperation-page .contact-section .contact-card .contact-info{flex:1}.cooperation-page .contact-section .contact-card .contact-info .contact-title{color:#1e293b;margin-bottom:8px;font-size:20px;font-weight:600}.cooperation-page .contact-section .contact-card .contact-info .contact-desc{color:#64748b;margin-bottom:16px;font-size:14px}.cooperation-page .contact-section .contact-card .contact-info .contact-details{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.cooperation-page .contact-section .contact-card .contact-info .contact-details .contact-item{color:#1e293b;align-items:center;gap:10px;font-size:14px;display:flex}.cooperation-page .contact-section .contact-card .contact-info .contact-details .contact-item .anticon{color:#1890ff;font-size:16px}.cooperation-page .contact-section .contact-card .contact-info .contact-tip{color:#64748b;background:#eef2ff;border-radius:6px;margin-top:16px;padding:12px 16px;font-size:12px;line-height:1.6}.certificate-page{max-width:1100px;margin:0 auto;padding:32px 24px}@media (max-width:768px){.certificate-page{padding:24px 16px}}.certificate-page .page-header{margin-bottom:36px}.certificate-page .page-header .page-title{color:#1e293b;margin-bottom:8px;font-size:28px;font-weight:700}.certificate-page .page-header .page-desc{color:#64748b;margin:0;font-size:16px}.certificate-page .cert-grid{grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px;margin-bottom:48px;display:grid}@media (max-width:576px){.certificate-page .cert-grid{grid-template-columns:1fr}}.certificate-page .cert-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:12px;padding:24px;transition:all .2s}.certificate-page .cert-card:hover{border-color:#e2e8f0;transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.certificate-page .cert-card .cert-top{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.certificate-page .cert-card .cert-top .cert-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.certificate-page .cert-card .cert-top .cert-tags{gap:6px;display:flex}.certificate-page .cert-card .cert-top .cert-tags .cert-tag{color:#64748b;background:#f1f5f9;border-radius:9999px;padding:2px 10px;font-size:11px;font-weight:500}.certificate-page .cert-card .cert-title{color:#1e293b;margin-bottom:8px;font-size:16px;font-weight:600}.certificate-page .cert-card .cert-desc{color:#64748b;margin-bottom:14px;font-size:14px;line-height:1.5}.certificate-page .cert-card .cert-features{flex-wrap:wrap;gap:8px;display:flex}.certificate-page .cert-card .cert-features .feature-item{color:#94a3b8;align-items:center;gap:4px;font-size:12px;display:flex}.certificate-page .cert-card .cert-features .feature-item .anticon{color:#10b981;font-size:12px}.certificate-page .process-section{margin-bottom:48px}.certificate-page .process-section .process-title{color:#1e293b;margin-bottom:24px;font-size:20px;font-weight:600}.certificate-page .process-section .process-steps{align-items:flex-start;gap:0;display:flex}@media (max-width:768px){.certificate-page .process-section .process-steps{flex-direction:column;gap:0}}.certificate-page .process-section .process-step{text-align:center;flex:1;padding:20px 16px;position:relative}.certificate-page .process-section .process-step .step-number{color:#1890ff33;letter-spacing:-1px;margin-bottom:8px;font-size:32px;font-weight:700}.certificate-page .process-section .process-step .step-icon{color:#1890ff;background:#eef2ff;border-radius:9999px;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 12px;font-size:22px;display:flex}.certificate-page .process-section .process-step .step-title{color:#1e293b;margin-bottom:4px;font-size:14px;font-weight:600}.certificate-page .process-section .process-step .step-desc{color:#94a3b8;font-size:12px}.certificate-page .process-section .step-connector{background:#e2e8f0;flex-shrink:0;width:48px;height:2px;margin-top:72px}@media (max-width:768px){.certificate-page .process-section .step-connector{width:2px;height:24px;margin:0 auto}}.certificate-page .inquiry-section .inquiry-card{text-align:center;background:linear-gradient(135deg,#eef2ff 0%,#f5f3ff 50%,#eff6ff 100%);border:1px solid #f1f5f9;border-radius:16px;padding:40px 32px}.certificate-page .inquiry-section .inquiry-card .inquiry-title{color:#1890ff;margin-bottom:10px;font-size:24px;font-weight:700}.certificate-page .inquiry-section .inquiry-card .inquiry-desc{color:#64748b;margin-bottom:24px;font-size:14px}.certificate-page .inquiry-section .inquiry-card .inquiry-contacts{flex-wrap:wrap;justify-content:center;gap:32px;margin-bottom:24px;display:flex}.certificate-page .inquiry-section .inquiry-card .inquiry-contacts .inquiry-item{color:#1e293b;align-items:center;gap:8px;font-size:14px;display:flex}.certificate-page .inquiry-section .inquiry-card .inquiry-contacts .inquiry-item .anticon{color:#1890ff;font-size:18px}.certificate-page .inquiry-section .inquiry-card .inquiry-tip{color:#64748b;background:#eef2ff;border-radius:6px;margin-top:16px;padding:12px 16px;font-size:12px;line-height:1.6}.devhub-page{max-width:1100px;margin:0 auto;padding:24px}.devhub-page .page-header{text-align:center;margin-bottom:24px}.devhub-page .page-header .page-title{color:#1e293b;margin:0 0 8px;font-size:32px;font-weight:700}.devhub-page .page-header .page-desc{color:#64748b;margin:0;font-size:14px}.devhub-page .tab-nav{background:#f1f5f9;border-radius:12px;gap:4px;margin-bottom:24px;padding:4px;display:flex}.devhub-page .tab-nav .tab-item{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.devhub-page .tab-nav .tab-item:hover{color:#1e293b;background:#fff9}.devhub-page .tab-nav .tab-item.active{color:#1890ff;background:#fff;box-shadow:0 1px 2px #0000000d}.devhub-page .tab-nav .tab-item .anticon{font-size:16px}.devhub-page .quiz-section .quiz-toolbar{margin-bottom:16px}.devhub-page .quiz-section .quiz-toolbar .quiz-categories{-webkit-overflow-scrolling:touch;scrollbar-width:none;border-bottom:1px solid #f1f5f9;gap:4px;margin-bottom:14px;padding-bottom:14px;display:flex;overflow-x:auto}.devhub-page .quiz-section .quiz-toolbar .quiz-categories::-webkit-scrollbar{display:none}.devhub-page .quiz-section .quiz-toolbar .quiz-categories .qt-cat{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9999px;flex-shrink:0;padding:6px 16px;font-size:12px;font-weight:500;transition:all .2s}.devhub-page .quiz-section .quiz-toolbar .quiz-categories .qt-cat:hover{color:#1e293b;background:#f1f5f9}.devhub-page .quiz-section .quiz-toolbar .quiz-categories .qt-cat.active{color:#fff;background:#1890ff}.devhub-page .quiz-section .quiz-toolbar .quiz-filters{justify-content:space-between;align-items:center;gap:16px;display:flex}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .difficulty-btns{gap:6px;display:flex}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .difficulty-btns .diff-btn{color:#64748b;cursor:pointer;background:0 0;border:1.5px solid #e2e8f0;border-radius:9999px;padding:5px 14px;font-size:11px;font-weight:500;transition:all .2s}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .difficulty-btns .diff-btn:hover{color:#1e293b;border-color:#94a3b8}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .difficulty-btns .diff-btn.active{color:#fff;border-color:#0000}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .difficulty-btns .diff-btn.active:first-child{background:#1890ff;border-color:#1890ff}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .quiz-search{background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:8px;padding:6px 14px;transition:border-color .2s;display:flex}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .quiz-search:focus-within{border-color:#1890ff}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .quiz-search .anticon{color:#94a3b8;font-size:14px}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .quiz-search input{color:#1e293b;background:0 0;border:none;outline:none;width:160px;font-size:12px}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .quiz-search input::placeholder{color:#94a3b8}.devhub-page .quiz-section .quiz-table{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.devhub-page .quiz-section .quiz-table .qt-header{color:#64748b;text-transform:uppercase;letter-spacing:.5px;background:#f1f5f9;align-items:center;padding:12px 20px;font-size:11px;font-weight:600;display:flex}.devhub-page .quiz-section .quiz-table .qt-col-id{flex-shrink:0;width:50px}.devhub-page .quiz-section .quiz-table .qt-col-title{flex:1;min-width:0}.devhub-page .quiz-section .quiz-table .qt-col-date{text-align:center;flex-shrink:0;width:72px}.devhub-page .quiz-section .quiz-table .qt-col-acc,.devhub-page .quiz-section .quiz-table .qt-col-diff{text-align:center;flex-shrink:0;width:80px}.devhub-page .quiz-section .quiz-table .qt-empty{text-align:center;color:#94a3b8;padding:60px 20px;font-size:14px}.devhub-page .quiz-section .quiz-table .qt-row{cursor:pointer;color:#1e293b;border-top:1px solid #f1f5f9;align-items:center;padding:14px 20px;font-size:14px;transition:background .15s;display:flex}.devhub-page .quiz-section .quiz-table .qt-row:hover{background:#f8f9ff}.devhub-page .quiz-section .quiz-table .qt-row.expanded{background:#eef2ff}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-id{color:#94a3b8;font-size:12px}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-title{flex-wrap:wrap;align-items:center;gap:8px;font-weight:500;line-height:1.4;display:flex}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-title .qt-new-badge{color:#fff;letter-spacing:.5px;background:#ff375f;border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:700;line-height:16px;animation:.3s fadeIn;display:inline-block}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-title .qt-cat-tag{color:#64748b;background:#f1f5f9;border-radius:9999px;flex-shrink:0;padding:1px 8px;font-size:11px;font-weight:400;display:inline-block}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-date{color:#94a3b8;font-size:11px}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-acc{color:#64748b;font-size:12px}.devhub-page .quiz-section .quiz-table .qt-row.is-new{background:#fffbeb}.devhub-page .quiz-section .quiz-table .qt-row.is-new:hover{background:#fef3c7}.devhub-page .quiz-section .quiz-table .qt-row .diff-badge{font-size:11px;font-weight:600}.devhub-page .quiz-section .quiz-table .qt-answer{background:#f8fafc;border-top:1px dashed #e2e8f0;animation:.2s fadeIn}.devhub-page .quiz-section .quiz-table .qt-answer .qt-answer-inner{color:#64748b;padding:16px 20px 16px 70px;font-size:14px;line-height:1.8}.devhub-page .quiz-section .quiz-table .qt-answer .qt-answer-inner strong{color:#1890ff;margin-right:4px}.devhub-page .quiz-section .quiz-footer{justify-content:space-between;align-items:center;margin-top:16px;padding:0 4px;display:flex}.devhub-page .quiz-section .quiz-footer .quiz-count{color:#94a3b8;font-size:12px}.devhub-page .pagination{align-items:center;gap:4px;display:flex}.devhub-page .pagination button{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;padding:0 8px;font-size:12px;transition:all .15s;display:flex}.devhub-page .pagination button:hover:not(:disabled):not(.active){color:#1890ff;border-color:#1890ff}.devhub-page .pagination button.active{color:#fff;background:#1890ff;border-color:#1890ff}.devhub-page .pagination button:disabled{opacity:.35;cursor:not-allowed}.devhub-page .pagination .page-ellipsis{text-align:center;color:#94a3b8;width:32px;font-size:12px}.devhub-page .news-section{position:relative}.devhub-page .news-section .news-toolbar{margin-bottom:4px}.devhub-page .news-section .news-toolbar .news-source-tabs{gap:0;margin-bottom:12px;display:flex}.devhub-page .news-section .news-toolbar .news-source-tabs button{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 24px;font-size:14px;font-weight:600;transition:color .2s;position:relative}.devhub-page .news-section .news-toolbar .news-source-tabs button:hover{color:#1e293b}.devhub-page .news-section .news-toolbar .news-source-tabs button.active{color:#1890ff;border-bottom-color:#1890ff}.devhub-page .news-section .news-toolbar .news-sub-toolbar{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:8px;display:flex}.devhub-page .news-section .news-toolbar .news-sort-tabs{gap:0;display:flex}.devhub-page .news-section .news-toolbar .news-sort-tabs button{color:#64748b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;padding:6px 14px;font-size:12px;font-weight:500;transition:all .2s}.devhub-page .news-section .news-toolbar .news-sort-tabs button:first-child{border-radius:6px 0 0 6px}.devhub-page .news-section .news-toolbar .news-sort-tabs button:last-child{border-left:none;border-radius:0 6px 6px 0}.devhub-page .news-section .news-toolbar .news-sort-tabs button:hover{color:#1e293b}.devhub-page .news-section .news-toolbar .news-sort-tabs button.active{color:#fff;background:#1890ff;border-color:#1890ff}.devhub-page .news-section .news-toolbar .news-tags{flex-wrap:wrap;gap:6px;display:flex}.devhub-page .news-section .news-toolbar .news-tags .news-tag-chip{color:#64748b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:9999px;padding:4px 12px;font-size:11px;transition:all .2s}.devhub-page .news-section .news-toolbar .news-tags .news-tag-chip:hover{color:#1890ff;border-color:#1890ff}.devhub-page .news-section .news-toolbar .news-tags .news-tag-chip.active{color:#fff;background:#1890ff;border-color:#1890ff}.devhub-page .news-section .news-loading,.devhub-page .news-section .news-error{text-align:center;color:#64748b;padding:60px 20px}.devhub-page .news-section .news-loading .anticon,.devhub-page .news-section .news-error .anticon{margin-right:8px;font-size:18px}.devhub-page .news-section .news-error .retry-btn{color:#1890ff;cursor:pointer;background:0 0;border:1px solid #1890ff;border-radius:6px;align-items:center;gap:6px;margin-top:16px;padding:8px 20px;display:inline-flex}.devhub-page .news-section .news-error .retry-btn:hover{color:#fff;background:#1890ff}.devhub-page .news-section .news-list{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.devhub-page .news-section .news-item{cursor:pointer;border-bottom:1px solid #f1f5f9;gap:16px;padding:18px 20px;transition:background .15s;display:flex}.devhub-page .news-section .news-item:last-child{border-bottom:none}.devhub-page .news-section .news-item:hover{background:#f8f9ff}.devhub-page .news-section .news-item .news-item-content{flex:1;min-width:0}.devhub-page .news-section .news-item .news-item-content .news-item-title{color:#1e293b;-webkit-line-clamp:1;-webkit-box-orient:vertical;margin:0 0 6px;font-size:15px;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.devhub-page .news-section .news-item .news-item-content .news-item-desc{color:#64748b;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 10px;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}.devhub-page .news-section .news-item .news-item-content .news-item-meta{color:#94a3b8;flex-wrap:wrap;align-items:center;gap:4px;font-size:11px;display:flex}.devhub-page .news-section .news-item .news-item-content .news-item-meta .meta-author{color:#64748b;font-weight:500}.devhub-page .news-section .news-item .news-item-content .news-item-meta .meta-sep{background:#94a3b8;border-radius:50%;width:3px;height:3px;margin:0 4px}.devhub-page .news-section .news-item .news-item-content .news-item-meta .meta-tag{color:#64748b;background:#f1f5f9;border-radius:9999px;margin-left:4px;padding:1px 8px}.devhub-page .news-section .news-item .news-item-thumb{background-color:#f1f5f9;background-position:50%;background-size:cover;border-radius:6px;flex-shrink:0;width:120px;height:80px}.devhub-page .news-section .news-footer{justify-content:center;align-items:center;gap:16px;margin-top:16px;padding:4px 0;display:flex}.devhub-page .news-section .news-footer button{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:6px;padding:8px 20px;font-size:12px;transition:all .2s;display:flex}.devhub-page .news-section .news-footer button:hover:not(:disabled){color:#1890ff;border-color:#1890ff}.devhub-page .news-section .news-footer button:disabled{opacity:.35;cursor:not-allowed}.devhub-page .news-section .news-footer .page-info{color:#64748b;font-size:12px}.devhub-page .news-section .article-reader{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:32px;animation:.2s fadeIn}.devhub-page .news-section .article-reader .reader-toolbar{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.devhub-page .news-section .article-reader .reader-toolbar .back-btn{color:#1e293b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;transition:all .2s;display:flex}.devhub-page .news-section .article-reader .reader-toolbar .back-btn:hover{color:#1890ff;border-color:#1890ff}.devhub-page .news-section .article-reader .reader-toolbar .original-link{color:#1890ff;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:12px;text-decoration:none;display:flex}.devhub-page .news-section .article-reader .reader-toolbar .original-link:hover{opacity:.7}.devhub-page .news-section .article-reader .reader-cover{object-fit:cover;border-radius:6px;width:100%;max-height:360px;margin-bottom:24px}.devhub-page .news-section .article-reader .reader-title{color:#1e293b;margin:0 0 12px;font-size:24px;font-weight:700;line-height:1.3}.devhub-page .news-section .article-reader .reader-meta{color:#64748b;align-items:center;gap:8px;margin-bottom:12px;font-size:12px;display:flex}.devhub-page .news-section .article-reader .reader-meta .meta-dot{background:#94a3b8;border-radius:50%;width:3px;height:3px}.devhub-page .news-section .article-reader .reader-tags{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.devhub-page .news-section .article-reader .reader-tags .reader-tag{color:#1890ff;background:#eef2ff;border-radius:9999px;padding:3px 10px;font-size:11px}.devhub-page .news-section .article-reader .article-body{color:#1e293b;font-size:15px;line-height:1.8}.devhub-page .news-section .article-reader .article-body h1,.devhub-page .news-section .article-reader .article-body h2,.devhub-page .news-section .article-reader .article-body h3,.devhub-page .news-section .article-reader .article-body h4,.devhub-page .news-section .article-reader .article-body h5,.devhub-page .news-section .article-reader .article-body h6{color:#1e293b;margin-top:28px;margin-bottom:12px;font-weight:600}.devhub-page .news-section .article-reader .article-body h1{font-size:24px}.devhub-page .news-section .article-reader .article-body h2{border-bottom:1px solid #f1f5f9;padding-bottom:8px;font-size:20px}.devhub-page .news-section .article-reader .article-body h3{font-size:17px}.devhub-page .news-section .article-reader .article-body p{margin:0 0 16px}.devhub-page .news-section .article-reader .article-body a{color:#1890ff;text-decoration:none}.devhub-page .news-section .article-reader .article-body a:hover{text-decoration:underline}.devhub-page .news-section .article-reader .article-body img{border-radius:6px;max-width:100%;margin:12px 0}.devhub-page .news-section .article-reader .article-body pre{color:#e2e8f0;background:#1e293b;border-radius:6px;margin:16px 0;padding:16px 20px;font-size:13px;line-height:1.6;overflow-x:auto}.devhub-page .news-section .article-reader .article-body code{color:#ef4444;background:#f1f5f9;border-radius:4px;padding:2px 6px;font-size:13px}.devhub-page .news-section .article-reader .article-body pre code{color:inherit;background:0 0;padding:0}.devhub-page .news-section .article-reader .article-body ul,.devhub-page .news-section .article-reader .article-body ol{margin:0 0 16px;padding-left:24px}.devhub-page .news-section .article-reader .article-body ul li,.devhub-page .news-section .article-reader .article-body ol li{margin-bottom:6px}.devhub-page .news-section .article-reader .article-body blockquote{color:#64748b;background:#eef2ff;border-left:4px solid #1890ff;border-radius:0 6px 6px 0;margin:16px 0;padding:12px 20px}.devhub-page .news-section .article-reader .article-body blockquote p:last-child{margin-bottom:0}.devhub-page .news-section .article-reader .article-body table{border-collapse:collapse;width:100%;margin:16px 0}.devhub-page .news-section .article-reader .article-body table th,.devhub-page .news-section .article-reader .article-body table td{text-align:left;border:1px solid #e2e8f0;padding:10px 14px;font-size:14px}.devhub-page .news-section .article-reader .article-body table th{background:#f1f5f9;font-weight:600}.devhub-page .news-section .article-loading-overlay{z-index:100;background:#ffffffbf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.devhub-page .news-section .article-loading-overlay .loading-spinner{color:#1e293b;background:#fff;border-radius:12px;padding:20px 32px;font-size:14px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.devhub-page .news-section .article-loading-overlay .loading-spinner .anticon{color:#1890ff;margin-right:8px}.devhub-page .ai-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;height:calc(100vh - 280px);min-height:500px;display:flex;overflow:hidden}.devhub-page .ai-section .ai-toolbar{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.devhub-page .ai-section .ai-toolbar .ai-toolbar-left{align-items:center;gap:12px;min-width:0;display:flex}.devhub-page .ai-section .ai-toolbar .ai-history-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.devhub-page .ai-section .ai-toolbar .ai-history-btn:hover{color:#1e293b;background:#f1f5f9}.devhub-page .ai-section .ai-toolbar .ai-history-btn.active{color:#1890ff;background:#eef2ff}.devhub-page .ai-section .ai-toolbar .ai-model-label{color:#64748b;flex-shrink:0;align-items:center;gap:6px;font-size:12px;display:flex}.devhub-page .ai-section .ai-toolbar .ai-model-label .anticon{color:#1890ff}.devhub-page .ai-section .ai-toolbar .ai-mode-tabs{border:1px solid #e2e8f0;border-radius:6px;gap:0;display:flex;overflow:hidden}.devhub-page .ai-section .ai-toolbar .ai-mode-tabs button{color:#64748b;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:6px 14px;font-size:12px;transition:all .2s;display:flex}.devhub-page .ai-section .ai-toolbar .ai-mode-tabs button:hover{color:#1890ff}.devhub-page .ai-section .ai-toolbar .ai-mode-tabs button.active{color:#fff;background:#1890ff}.devhub-page .ai-section .ai-toolbar .ai-actions{gap:4px;display:flex}.devhub-page .ai-section .ai-toolbar .ai-actions button{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.devhub-page .ai-section .ai-toolbar .ai-actions button:hover{color:#1e293b;background:#f1f5f9}.devhub-page .ai-section .ai-main{flex:1;min-height:0;display:flex}.devhub-page .ai-section .ai-history-panel{background:#f8fafc;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:260px;display:flex;overflow:hidden}.devhub-page .ai-section .ai-history-panel .ai-history-header{color:#1e293b;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:12px 14px;font-size:12px;font-weight:600;display:flex}.devhub-page .ai-section .ai-history-panel .ai-history-header .ai-new-chat-btn{color:#1890ff;cursor:pointer;background:0 0;border:1px solid #1890ff;border-radius:6px;padding:4px 12px;font-size:11px;transition:all .2s}.devhub-page .ai-section .ai-history-panel .ai-history-header .ai-new-chat-btn:hover{background:#eef2ff}.devhub-page .ai-section .ai-history-panel .ai-history-list{flex:1;padding:8px 0;overflow-y:auto}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-empty{text-align:center;color:#94a3b8;padding:24px 14px;font-size:12px}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item{border-radius:6px;align-items:center;gap:4px;margin:0 6px;padding:6px 14px;transition:background .15s;display:flex}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item:hover{background:#f1f5f9}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item.active{background:#eef2ff}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item .ai-history-item-btn{text-align:left;cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;gap:2px;min-width:0;padding:4px 0;display:flex}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item .ai-history-item-btn .ai-history-item-title{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item .ai-history-item-btn .ai-history-item-time{color:#94a3b8;font-size:11px}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item .ai-history-item-del{color:#94a3b8;cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex}.devhub-page .ai-section .ai-history-panel .ai-history-list .ai-history-item .ai-history-item-del:hover{color:#ef4444;opacity:1;background:#ff375f14}.devhub-page .ai-section .ai-history-panel .ai-history-clear-all{color:#64748b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:6px;margin:8px 14px;padding:8px 12px;font-size:11px;transition:all .2s}.devhub-page .ai-section .ai-history-panel .ai-history-clear-all:hover{color:#ef4444;border-color:#ef4444}.devhub-page .ai-section .chat-wrap{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.devhub-page .ai-section .chat-container{flex:1;padding:20px;overflow-y:auto}.devhub-page .ai-section .chat-welcome{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.devhub-page .ai-section .chat-welcome .welcome-icon{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;font-size:24px;display:flex}.devhub-page .ai-section .chat-welcome h3{color:#1e293b;margin:0 0 8px;font-size:20px}.devhub-page .ai-section .chat-welcome p{color:#64748b;margin:0 0 6px;font-size:14px}.devhub-page .ai-section .chat-welcome .quick-hint{color:#94a3b8;margin-top:8px;font-size:12px}.devhub-page .ai-section .chat-welcome .quick-questions{flex-wrap:wrap;justify-content:center;gap:8px;max-width:600px;margin-top:18px;display:flex}.devhub-page .ai-section .chat-welcome .quick-questions .quick-q-btn{color:#1e293b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:9999px;padding:8px 16px;font-size:12px;transition:all .2s}.devhub-page .ai-section .chat-welcome .quick-questions .quick-q-btn:hover{color:#1890ff;background:#eef2ff;border-color:#1890ff}.devhub-page .ai-section .chat-messages{flex-direction:column;gap:20px;display:flex}.devhub-page .ai-section .chat-messages .chat-msg{gap:12px;display:flex}.devhub-page .ai-section .chat-messages .chat-msg .msg-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.devhub-page .ai-section .chat-messages .chat-msg.user .msg-avatar{color:#1890ff;background:#eef2ff}.devhub-page .ai-section .chat-messages .chat-msg.assistant .msg-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.devhub-page .ai-section .chat-messages .chat-msg .msg-body{flex:1;min-width:0}.devhub-page .ai-section .chat-messages .chat-msg .msg-content{color:#1e293b;word-break:break-word;font-size:14px;line-height:1.7}.devhub-page .ai-section .chat-messages .chat-msg .msg-content .msg-image-wrap{border:1px solid #f1f5f9;border-radius:6px;margin:8px 0;display:block;overflow:hidden}.devhub-page .ai-section .chat-messages .chat-msg .msg-content .msg-image{vertical-align:top;max-width:100%;max-height:360px;display:block}.devhub-page .ai-section .chat-messages .chat-msg .msg-content .ai-inline-code{color:#ef4444;background:#f1f5f9;border-radius:4px;padding:2px 6px;font-size:13px}.devhub-page .ai-section .chat-messages .chat-msg .msg-content .ai-code-block{color:#e2e8f0;background:#1e293b;border-radius:6px;margin:10px 0;padding:14px 18px;font-size:13px;line-height:1.6;overflow-x:auto}.devhub-page .ai-section .chat-messages .chat-msg .msg-content .ai-code-block code{font-family:Fira Code,Consolas,monospace}.devhub-page .ai-section .chat-messages .chat-msg.user .msg-content{background:#eef2ff;border-radius:4px 12px 12px;padding:10px 16px}.devhub-page .ai-section .chat-messages .chat-msg .typing-indicator{gap:4px;padding:12px 16px;display:flex}.devhub-page .ai-section .chat-messages .chat-msg .typing-indicator span{background:#94a3b8;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite typingBounce}.devhub-page .ai-section .chat-messages .chat-msg .typing-indicator span:nth-child(2){animation-delay:.15s}.devhub-page .ai-section .chat-messages .chat-msg .typing-indicator span:nth-child(3){animation-delay:.3s}.devhub-page .ai-section .chat-input-area{background:#f8fafc;border-top:1px solid #e2e8f0;gap:10px;padding:16px 20px;display:flex}.devhub-page .ai-section .chat-input-area .chat-input{color:#1e293b;resize:none;background:#fff;border:1px solid #e2e8f0;border-radius:6px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .2s}.devhub-page .ai-section .chat-input-area .chat-input:focus{border-color:#1890ff;box-shadow:0 0 0 2px #6366f11a}.devhub-page .ai-section .chat-input-area .chat-input:disabled{background:#f1f5f9}.devhub-page .ai-section .chat-input-area .chat-input::placeholder{color:#94a3b8}.devhub-page .ai-section .chat-input-area .send-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:16px;transition:opacity .2s;display:flex}.devhub-page .ai-section .chat-input-area .send-btn:hover:not(:disabled){opacity:.85}.devhub-page .ai-section .chat-input-area .send-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}@media (max-width:992px){.devhub-page .quiz-section .quiz-toolbar .quiz-filters{flex-wrap:wrap}.devhub-page .news-section .news-item .news-item-thumb{width:100px;height:66px}}@media (max-width:768px){.devhub-page{padding:16px}.devhub-page .page-header .page-title{font-size:24px}.devhub-page .tab-nav .tab-item{gap:6px;padding:10px 12px;font-size:12px}.devhub-page .quiz-section .quiz-toolbar .quiz-categories{gap:2px}.devhub-page .quiz-section .quiz-toolbar .quiz-categories .qt-cat{padding:5px 10px;font-size:11px}.devhub-page .quiz-section .quiz-toolbar .quiz-filters{flex-direction:column;align-items:stretch}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .difficulty-btns{flex-wrap:wrap}.devhub-page .quiz-section .quiz-toolbar .quiz-filters .quiz-search input{width:100%}.devhub-page .quiz-section .quiz-table .qt-header{display:none}.devhub-page .quiz-section .quiz-table .qt-row{flex-wrap:wrap;gap:6px}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-id{width:30px}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-title{flex-basis:calc(100% - 40px);order:1}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-date{text-align:left;order:2;width:auto;font-size:11px}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-acc{text-align:left;order:3;width:auto;font-size:11px}.devhub-page .quiz-section .quiz-table .qt-row .qt-col-diff{text-align:left;order:4;width:auto}.devhub-page .quiz-section .quiz-table .qt-answer .qt-answer-inner{padding-left:20px}.devhub-page .quiz-section .quiz-footer{flex-direction:column;gap:12px}.devhub-page .news-section .news-item .news-item-thumb{display:none}.devhub-page .news-section .article-reader{padding:16px}.devhub-page .news-section .article-reader .reader-title{font-size:20px}.devhub-page .ai-section{height:calc(100vh - 260px);min-height:400px}.devhub-page .ai-section .ai-main{position:relative}.devhub-page .ai-section .ai-toolbar .ai-toolbar-left{flex-wrap:wrap;gap:8px}.devhub-page .ai-section .ai-toolbar .ai-toolbar-left .ai-mode-tabs{order:3;width:100%}.devhub-page .ai-section .ai-history-panel{z-index:10;position:absolute;top:0;bottom:0;left:0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.devhub-page .ai-section .chat-welcome .quick-questions .quick-q-btn{padding:6px 12px;font-size:11px}}.tech-tutorial-page{max-width:960px;padding:24px}@media (max-width:768px){.tech-tutorial-page{padding:16px}}.tech-tutorial-page .tutorial-header{align-items:flex-start;gap:14px;margin-bottom:32px;display:flex}.tech-tutorial-page .tutorial-header .tutorial-indicator{border-radius:2px;flex-shrink:0;width:4px;height:36px;margin-top:2px}.tech-tutorial-page .tutorial-header .tutorial-title{color:#1e293b;margin:0 0 6px;font-size:24px;font-weight:700}.tech-tutorial-page .tutorial-header .tutorial-desc{color:#64748b;margin:0;font-size:14px}.tech-tutorial-page .tutorial-sections .tutorial-section{margin-bottom:28px}.tech-tutorial-page .tutorial-sections .tutorial-section .section-label{color:#fff;border-radius:9999px;align-items:center;margin-bottom:12px;padding:3px 12px;font-size:12px;font-weight:600;display:inline-flex}.tech-tutorial-page .tutorial-sections .tutorial-section .section-links{flex-direction:column;gap:8px;display:flex}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:12px;justify-content:space-between;align-items:center;padding:14px 18px;transition:all .2s;display:flex}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card:hover{border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card:hover .card-arrow{opacity:1;transform:translate(1px,-1px)}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card .card-body{flex:1;min-width:0}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card .card-body .card-title{color:#1e293b;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;font-size:14px;font-weight:600;display:flex}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card .card-body .card-tag{border:1px solid;border-radius:9999px;padding:1px 8px;font-size:11px;font-weight:500}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card .card-body .card-desc{color:#94a3b8;font-size:12px;line-height:1.5}.tech-tutorial-page .tutorial-sections .tutorial-section .tutorial-card .card-arrow{color:#94a3b8;opacity:0;flex-shrink:0;margin-left:12px;transition:all .2s}.App{flex-direction:column;width:100%;min-height:100vh;display:flex}
