*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5}.login-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;display:flex;align-items:center;justify-content:center}.login-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 15px 35px #0000001a;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:#333;font-size:24px;margin-bottom:.5rem}.login-header p{color:#666;font-size:14px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input{width:100%;padding:12px;border:2px solid #e1e1e1;border-radius:8px;font-size:16px;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.login-btn{width:100%;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease}.login-btn:hover{transform:translateY(-2px)}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.alert{padding:12px;border-radius:8px;margin-bottom:1rem}.alert.error{background-color:#fee;color:#c33;border:1px solid #fcc}.alert.success{background-color:#efe;color:#373;border:1px solid #cfc}.demo-info{background:#f8f9fa;padding:1rem;border-radius:8px;margin-top:1.5rem;border-left:4px solid #667eea}.demo-info h4{color:#333;margin-bottom:.5rem;font-size:14px}.demo-info p{color:#666;font-size:12px;margin:0}.admin-layout{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.header h1{font-size:24px;font-weight:600}.user-info{display:flex;align-items:center;gap:1rem}.logout-btn{background:#fff3;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;transition:background-color .3s ease}.logout-btn:hover{background:#ffffff4d}.container{width:100%;margin:0;padding:2rem;display:flex;gap:2rem;flex:1}.nav-tabs{display:flex;flex-direction:column;gap:.5rem;width:220px;flex-shrink:0;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 20px #00000014;border:1px solid #e1e1e1;height:fit-content}.nav-tab{padding:12px 16px;background:none;border:none;color:#666;cursor:pointer;border-radius:8px;transition:all .3s ease;text-align:left;font-size:14px}.nav-tab:hover{background:#f8f9fa}.nav-tab.active{color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a)}.content-area{flex:1;min-width:0}.card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 20px #00000014;border:1px solid #e1e1e1;margin-bottom:2rem}.card h3{color:#333;margin-bottom:1rem;font-size:18px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.stats-card{text-align:center}.stats-number{font-size:36px;font-weight:700;color:#667eea;margin-bottom:.5rem}.stats-label{color:#666;font-size:14px}.user-table{width:100%;border-collapse:collapse;margin-top:1rem}.user-table th,.user-table td{padding:12px;text-align:left;border-bottom:1px solid #e1e1e1}.user-table th{background-color:#f8f9fa;font-weight:600;color:#333}.user-table tr:hover{background-color:#f8f9fa}.loading{text-align:center;padding:2rem;color:#666}.error{background-color:#fee;color:#c33;padding:1rem;border-radius:8px;border:1px solid #fcc;margin-bottom:1rem}.upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;margin-bottom:1.5rem;transition:transform .2s ease}.upload-btn:hover{transform:translateY(-2px)}.plugin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.plugin-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 20px #00000014;border:1px solid #e1e1e1;cursor:pointer;transition:all .3s ease}.plugin-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f}.plugin-header{display:flex;align-items:center;margin-bottom:1rem}.plugin-icon{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:700;margin-right:1rem}.plugin-info h4{color:#333;font-size:16px;margin-bottom:.25rem}.plugin-info .version{color:#666;font-size:12px}.plugin-description{color:#666;font-size:14px;line-height:1.5;margin-bottom:1rem}.plugin-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#999}.plugin-status{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600}.plugin-status.active{background-color:#e7f5e7;color:#2d5a2d}.plugin-status.inactive{background-color:#ffeaa7;color:#8b6914}.plugin-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014}.plugin-detail-info{display:flex;align-items:center}.plugin-detail-icon{width:64px;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700;margin-right:1.5rem}.plugin-detail-meta h2{color:#333;font-size:24px;margin-bottom:.5rem}.plugin-detail-meta .package-name{color:#666;font-size:14px;margin-bottom:.25rem}.plugin-detail-meta .current-version{color:#667eea;font-size:14px;font-weight:600}.update-btn{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background-color .3s ease}.update-btn:hover{background:#218838}.back-btn{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:12px;margin-bottom:1rem;transition:background-color .3s ease}.back-btn:hover{background:#5a6268}.version-history{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 20px #00000014}.version-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e1e1e1;transition:background-color .3s ease}.version-item:last-child{border-bottom:none}.version-item:hover{background-color:#f8f9fa}.version-info h4{color:#333;font-size:16px;margin-bottom:.25rem}.version-info .upload-time{color:#666;font-size:12px}.version-info .download-url{margin-top:.5rem}.version-info .download-url span{color:#666;font-size:12px}.version-info .download-url a{color:#667eea;text-decoration:none;font-size:12px}.version-badge{padding:4px 12px;background:#667eea;color:#fff;border-radius:12px;font-size:12px;font-weight:600}.version-badge.current{background:#28a745}.download-btn{background:#17a2b8;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:background-color .3s ease;margin-right:.5rem}.download-btn:hover{background:#138496}.version-actions{display:flex;align-items:center;gap:.5rem}.plugin-uploader{width:100%;height:100%}.uploader-header{margin-bottom:2rem}.uploader-header h2{color:#333;font-size:24px;margin-bottom:.5rem}.uploader-header p{color:#666;font-size:14px}.upload-container{display:flex;flex-direction:column;gap:1.5rem;height:calc(100vh - 250px)}.upload-area{flex:1;min-height:400px;border:3px dashed #d1d5db;border-radius:12px;background:#f9fafb;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;position:relative}.upload-area:hover{border-color:#667eea;background:#f0f4ff}.upload-area.drag-over{border-color:#667eea;background:#e0e7ff;transform:scale(1.02)}.upload-area.has-file{border-color:#10b981;background:#ecfdf5}.upload-placeholder{text-align:center;color:#6b7280}.upload-icon{font-size:72px;color:#9ca3af;margin-bottom:1rem;font-weight:300}.upload-text p{margin:.5rem 0;font-size:16px}.upload-hint{font-size:14px!important;color:#9ca3af!important}.file-info{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;position:relative}.file-icon{font-size:48px}.file-details{flex:1}.file-name{font-size:18px;font-weight:600;color:#333;margin:0 0 .5rem}.file-size{font-size:14px;color:#666;margin:0}.remove-file-btn{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;border-radius:50%;border:none;background:#ef4444;color:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background-color .3s ease}.remove-file-btn:hover{background:#dc2626}.upload-submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;align-self:center;min-width:200px}.upload-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #667eea4d}.upload-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.upload-progress{display:flex;flex-direction:column;gap:.5rem;align-items:center}.progress-bar{width:100%;max-width:400px;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.progress-text{font-size:14px;color:#666;margin:0}.upload-result{padding:1rem;border-radius:8px;text-align:center;font-weight:600}.upload-result.success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.upload-result.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.plugin-config-info{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 20px #00000014;border:1px solid #e1e1e1}.plugin-config-info h3{color:#333;font-size:18px;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #667eea}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.config-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.config-label{font-weight:600;color:#374151;font-size:14px}.config-value{color:#667eea;font-weight:500;font-size:14px;text-align:right;word-break:break-all}@media (max-width: 768px){.container{flex-direction:column;gap:1rem}.nav-tabs{min-width:auto;flex-direction:row;overflow-x:auto;padding:1rem}.nav-tab{white-space:nowrap;min-width:120px}.plugin-grid{grid-template-columns:1fr}.plugin-detail-header{flex-direction:column;gap:1rem;align-items:flex-start}.version-item{flex-direction:column;align-items:flex-start;gap:1rem}.version-actions{align-self:flex-end}}
