*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1a3a5c;--primary-light: #2a5a8c;--primary-dark: #0f2440;--accent: #c4922e;--accent-light: #e0b54a;--bg: #f5f5f0;--surface: #ffffff;--text: #2c2c2c;--text-light: #6b6b6b;--border: #d4d4d0;--success: #2d6a4f;--danger: #c0392b;--radius: 8px;--shadow: 0 2px 8px rgba(0,0,0,.08);--shadow-lg: 0 4px 16px rgba(0,0,0,.12);--max-width: 1200px}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,Microsoft YaHei,PingFang SC,Helvetica Neue,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-light)}img{max-width:100%;height:auto}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 1rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.navbar-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;height:60px;gap:1rem}.navbar-logo{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--primary);white-space:nowrap}.navbar-logo .logo-icon{font-size:1.5rem}.navbar-links{display:flex;gap:.25rem;margin-left:auto;align-items:center}.navbar-links a,.navbar-links button{padding:.4rem .75rem;border-radius:var(--radius);font-size:.9rem;color:var(--text);transition:background .2s;border:none;background:none;cursor:pointer;font-family:inherit;white-space:nowrap}.navbar-links a:hover,.navbar-links button:hover{background:var(--bg)}.navbar-links a.active{color:var(--primary);font-weight:600}.nav-user{font-size:.85rem;color:var(--text-light);margin-right:.5rem}.navbar-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem}.footer{background:var(--primary-dark);color:#ccc;padding:2rem 1rem 1rem;margin-top:auto}.footer-inner{max-width:var(--max-width);margin:0 auto;text-align:center}.footer p{margin-bottom:.5rem;font-size:.85rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.5rem;border-radius:var(--radius);font-size:.95rem;font-weight:500;cursor:pointer;border:none;transition:all .2s;font-family:inherit}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light)}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-light)}.btn-outline{background:transparent;border:1.5px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-sm{padding:.35rem .75rem;font-size:.85rem}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.3rem;font-weight:500;font-size:.9rem}.form-input,.form-select,.form-textarea{width:100%;padding:.6rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;transition:border-color .2s;background:var(--surface)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary)}.form-textarea{resize:vertical;min-height:100px}.form-error{color:var(--danger);font-size:.85rem;margin-top:.25rem}.form-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-checkbox input{width:1rem;height:1rem}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-lg)}.hero{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;padding:4rem 1rem;text-align:center}.hero h1{font-size:2rem;margin-bottom:.75rem}.hero p{font-size:1.1rem;opacity:.9;margin-bottom:1.5rem;max-width:600px;margin-left:auto;margin-right:auto}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:var(--max-width);margin:-2rem auto 2rem;padding:0 1rem;position:relative;z-index:10}.stat-card{background:var(--surface);border-radius:var(--radius);padding:1.5rem;text-align:center;box-shadow:var(--shadow)}.stat-card .stat-number{font-size:1.75rem;font-weight:700;color:var(--primary)}.stat-card .stat-label{font-size:.85rem;color:var(--text-light);margin-top:.25rem}.section{max-width:var(--max-width);margin:2rem auto;padding:0 1rem}.section-title{font-size:1.4rem;font-weight:700;margin-bottom:1rem;color:var(--primary)}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.resource-card{background:var(--surface);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);border:1px solid var(--border);transition:all .2s;display:flex;flex-direction:column}.resource-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.resource-card .rc-category{display:inline-block;font-size:.75rem;background:var(--bg);color:var(--primary);padding:.15rem .5rem;border-radius:999px;margin-bottom:.5rem;width:fit-content}.resource-card .rc-title{font-size:1.05rem;font-weight:600;margin-bottom:.4rem;line-height:1.4}.resource-card .rc-title a{color:var(--text)}.resource-card .rc-title a:hover{color:var(--primary)}.resource-card .rc-desc{font-size:.85rem;color:var(--text-light);margin-bottom:.75rem;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.resource-card .rc-meta{font-size:.8rem;color:var(--text-light);display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border)}.content-layout{display:grid;grid-template-columns:220px 1fr;gap:1.5rem}.filter-panel{background:var(--surface);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);height:fit-content;position:sticky;top:80px}.filter-panel h3{font-size:1rem;margin-bottom:.75rem}.filter-categories{list-style:none}.filter-categories li{margin-bottom:.25rem}.filter-categories button{width:100%;text-align:left;padding:.4rem .5rem;border:none;background:none;cursor:pointer;border-radius:var(--radius);font-size:.9rem;font-family:inherit;color:var(--text);transition:background .15s}.filter-categories button:hover{background:var(--bg)}.filter-categories button.active{background:var(--primary);color:#fff}.pagination{display:flex;justify-content:center;gap:.25rem;margin-top:2rem}.pagination button{min-width:2.25rem;height:2.25rem;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);cursor:pointer;font-size:.9rem;font-family:inherit;transition:all .15s}.pagination button:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.detail-header{margin-bottom:1.5rem}.detail-header h1{font-size:1.5rem;margin-bottom:.5rem}.detail-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;background:var(--bg);padding:1rem;border-radius:var(--radius);margin-bottom:1.5rem}.detail-meta-item{font-size:.9rem}.detail-meta-item strong{color:var(--text)}.detail-desc{line-height:1.8;margin-bottom:1.5rem}.download-section{text-align:center;padding:2rem;background:var(--bg);border-radius:var(--radius)}.upload-page{max-width:700px;margin:2rem auto;padding:0 1rem}.upload-page h1{margin-bottom:1.5rem}.upload-success{max-width:600px;margin:3rem auto;text-align:center;padding:0 1rem}.upload-success .success-icon{font-size:4rem;margin-bottom:1rem}.upload-success h1{color:var(--success);margin-bottom:.5rem}.upload-success p{color:var(--text-light);margin-bottom:1.5rem;line-height:1.8}.auth-page{max-width:440px;margin:2rem auto;padding:2rem;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.auth-page h1{text-align:center;margin-bottom:1.5rem}.auth-page .auth-link{text-align:center;margin-top:1rem;font-size:.9rem}.admin-layout{display:grid;grid-template-columns:200px 1fr;min-height:calc(100vh - 160px)}.admin-sidebar{background:var(--primary-dark);padding:1.5rem 0}.admin-sidebar a{display:block;padding:.6rem 1.5rem;color:#ccc;font-size:.9rem;transition:all .15s}.admin-sidebar a:hover,.admin-sidebar a.active{background:#ffffff1a;color:#fff}.admin-content{padding:1.5rem}.admin-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius);overflow:hidden}.admin-table th,.admin-table td{padding:.75rem 1rem;text-align:left;font-size:.9rem;border-bottom:1px solid var(--border)}.admin-table th{background:var(--bg);font-weight:600}.admin-table tr:hover td{background:var(--bg)}.badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.8rem;font-weight:500}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-danger{background:#f8d7da;color:#721c24}.text-center{text-align:center}.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mb-1{margin-bottom:1rem}.mb-2{margin-bottom:2rem}.loading{text-align:center;padding:2rem;color:var(--text-light)}.empty{text-align:center;padding:3rem;color:var(--text-light);font-size:1rem}.error-message{background:#f8d7da;color:#721c24;padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.success-message{background:#d4edda;color:#155724;padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.toast{position:fixed;top:1rem;right:1rem;z-index:1000;padding:.75rem 1.25rem;border-radius:var(--radius);animation:slideIn .3s}.toast-error{background:#f8d7da;color:#721c24}.toast-success{background:#d4edda;color:#155724}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 768px){.navbar-links{display:none}.navbar-links.open{display:flex;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:var(--surface);padding:.5rem;border-bottom:1px solid var(--border)}.navbar-toggle{display:block;margin-left:auto}.stats-grid{grid-template-columns:repeat(2,1fr)}.content-layout{grid-template-columns:1fr}.filter-panel{position:static}.admin-layout{grid-template-columns:1fr}.admin-sidebar{display:flex;overflow-x:auto;padding:.5rem}.admin-sidebar a{white-space:nowrap;padding:.4rem .75rem}.hero h1{font-size:1.5rem}.resource-grid{grid-template-columns:1fr}.detail-meta{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr 1fr}.detail-meta{grid-template-columns:1fr}}
