.project-detail{min-height:100vh;background:#f5f5f5}.detail-content{padding:0}.content-wrapper{max-width:1200px;margin:0 auto;padding:24px 16px}.loading-container{display:flex;justify-content:center;align-items:center;height:400px}.project-info-card,.project-header{margin-bottom:24px}.project-title{margin-bottom:16px}.project-icon{font-size:32px;margin-right:8px}.project-tags{margin-top:8px}.project-meta{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.meta-item{display:flex;align-items:center;gap:4px;font-size:14px}.project-description,.project-detailed-description{margin-bottom:24px}.detailed-content{line-height:1.8;white-space:pre-wrap}.source-code-section{margin-bottom:24px}.code-actions{display:flex;align-items:center;margin-bottom:16px}.source-code-display{border-radius:6px;overflow:hidden;max-height:500px;overflow-y:auto}.source-code-display pre{margin:0!important;font-size:13px!important}.comments-section{margin-bottom:24px}.comment-input-section{padding:16px;background:#fafafa;border-radius:6px;margin-bottom:16px}.comment-rating{margin-bottom:12px;display:flex;align-items:center;gap:8px}.comment-actions{margin-top:12px;text-align:right}.comment-item{padding:16px 0;border-bottom:1px solid #f0f0f0}.comment-item:last-child{border-bottom:none}.comment-content{width:100%}.comment-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px}.comment-meta{flex:1}.comment-info{display:flex;align-items:center;gap:8px;margin-top:4px}.comment-body{margin:8px 0 8px 52px}.comment-actions{margin-left:52px;display:flex;gap:8px}.reply-input-section{margin:12px 0 12px 52px;padding:12px;background:#fafafa;border-radius:6px}.reply-actions{margin-top:8px;display:flex;gap:8px;justify-content:flex-end}.replies-section{margin:12px 0 0 52px;padding-left:20px;border-left:2px solid #f0f0f0}.reply-item{display:flex;gap:8px;margin-bottom:12px;padding:8px;background:#fafafa;border-radius:4px}.reply-content{flex:1;font-size:14px}.action-card{margin-bottom:16px;position:sticky;top:24px}.action-buttons{margin-bottom:16px}.download-tips{margin-top:16px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stat-item{text-align:center;padding:12px;background:#fafafa;border-radius:6px}.stat-value{font-size:24px;font-weight:700;color:#1890ff;margin-bottom:4px}.stat-label{font-size:12px;color:#666}@media (max-width: 768px){.content-wrapper{padding:16px 12px}.project-meta{flex-direction:column;align-items:flex-start;gap:8px}.meta-item{font-size:13px}.comment-header{flex-direction:column;gap:8px}.comment-body,.comment-actions,.reply-input-section,.replies-section{margin-left:0}.stats-grid{grid-template-columns:1fr;gap:8px}.action-card{position:static;margin-top:16px}.source-code-display{max-height:300px}.source-code-display pre{font-size:11px!important}}@media (max-width: 576px){.project-title h2{font-size:20px}.project-icon{font-size:24px}.code-actions{flex-direction:column;gap:8px;align-items:flex-start}}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.loading-container p{margin-top:16px;font-size:16px}.app{min-height:100vh;background-color:#f0f2f5}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);position:relative}.login-container:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>')}.login-box{background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-radius:20px;padding:48px;box-shadow:0 20px 40px #0003;width:400px;max-width:90vw;position:relative;z-index:1}.login-logo-icon{width:80px;height:80px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff;margin:0 auto 16px;box-shadow:0 8px 16px #667eea4d}.login-title{font-size:28px;font-weight:600;color:#262626;margin:0 0 8px}.login-subtitle{font-size:16px;color:#8c8c8c;margin:0}.main-layout{min-height:100vh}.main-layout .ant-layout-sider{background:linear-gradient(180deg,#001529 0%,#002140 100%);box-shadow:2px 0 8px #00000026}.brand-logo{display:flex;align-items:center;padding:16px 24px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.brand-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;margin-right:12px;box-shadow:0 4px 8px #667eea4d}.brand-logo span{color:#fff;font-size:18px;font-weight:600}.main-layout .ant-menu-dark{background:transparent}.main-layout .ant-menu-dark .ant-menu-item{border-radius:8px;margin:4px 8px}.main-layout .ant-menu-dark .ant-menu-item-selected{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 8px #667eea4d}.page-header{margin-bottom:24px;padding:24px 0;border-bottom:1px solid #f0f0f0}.page-title{font-size:28px;font-weight:600;color:#262626;margin:0 0 8px}.page-description{font-size:16px;color:#8c8c8c;margin:0}.stats-card{border:none;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000001a;transition:all .3s ease}.stats-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.stats-icon{font-size:24px;margin-bottom:12px;opacity:.9}.stats-value{font-size:32px;font-weight:700;line-height:1;margin-bottom:8px}.stats-label{font-size:14px;opacity:.9;display:flex;align-items:center;justify-content:space-between}.data-table{border-radius:12px;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0}.data-table .ant-card-head{border-bottom:1px solid #f0f0f0;background:#fafafa}.data-table .ant-card-head-title{font-weight:600;color:#262626}.fade-in{animation:fadeIn .5s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.login-box{padding:32px 24px}.login-title,.stats-value,.page-title{font-size:24px}}.ant-layout-header{background:white!important;padding:0 16px!important;display:flex!important;align-items:center!important;justify-content:space-between!important;box-shadow:0 2px 8px #0000001a!important}.ant-table-thead>tr>th{background:#fafafa!important;font-weight:600!important}.ant-progress-line{margin-bottom:8px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5715;color:#000000d9;background-color:#f0f2f5}#root{height:100%}.app{height:100vh;overflow:hidden}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#fff}.loading-container p{margin-top:16px;color:#666;font-size:16px}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="%23ffffff" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>') repeat;pointer-events:none}.login-box{width:400px;padding:40px;background:rgba(255,255,255,.95);border-radius:16px;box-shadow:0 20px 40px #0000001a;backdrop-filter:blur(10px);position:relative;z-index:1}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{width:64px;height:64px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#fff;font-size:32px;font-weight:700}.login-title{font-size:24px;font-weight:600;color:#333;margin-bottom:8px}.login-subtitle{color:#666;font-size:14px}.main-layout{height:100vh}.main-layout .ant-layout-sider{background:#001529;box-shadow:2px 0 8px #0000001a}.main-layout .ant-layout-header{background:#fff;box-shadow:0 2px 8px #0000000f;padding:0 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f0f0f0}.main-layout .ant-layout-content{margin:24px;padding:24px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000f;overflow-y:auto}.page-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.page-title{font-size:20px;font-weight:600;color:#262626;margin:0}.page-description{color:#8c8c8c;font-size:14px;margin-top:4px}.stats-card{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;color:#fff}.stats-card .ant-card-body{padding:24px}.stats-card .stats-icon{font-size:32px;margin-bottom:12px;opacity:.8}.stats-card .stats-value{font-size:32px;font-weight:700;margin-bottom:4px}.stats-card .stats-label{font-size:14px;opacity:.9}.data-table{background:white;border-radius:8px;overflow:hidden}.data-table .ant-table-thead>tr>th{background:#fafafa;border-bottom:1px solid #f0f0f0;font-weight:600}.action-buttons{display:flex;gap:8px;margin-bottom:16px}@media (max-width: 768px){.main-layout .ant-layout-content{margin:16px;padding:16px}.login-box{width:90%;margin:0 20px;padding:32px 24px}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
