:root{--primary-color: #2563EB;--primary-hover: #1D4ED8;--primary-light: #EFF6FF;--primary-gradient: linear-gradient(135deg, #2563EB 0%, #3B82F6 100%);--bg-color: #F8FAFC;--card-bg: #FFFFFF;--text-primary: #0F172A;--text-secondary: #475569;--text-muted: #94A3B8;--border-color: #E2E8F0;--success-color: #059669;--warning-color: #D97706;--error-color: #DC2626;--header-height: 64px;--card-radius: 12px;--input-radius: 8px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .05);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background-color:var(--bg-color);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.container{max-width:900px;margin:0 auto;padding:0 24px}.card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--shadow-md);padding:32px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.form-label .required{color:var(--error-color);margin-left:2px}.form-label .tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--border-color);color:var(--text-muted);font-size:10px;margin-left:4px;cursor:help}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;font-size:14px;border:1px solid var(--border-color);border-radius:var(--input-radius);background:var(--card-bg);color:var(--text-primary);transition:all .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.radio-group{display:flex;gap:24px}.radio-item{display:flex;align-items:center;gap:8px;cursor:pointer}.radio-item input[type=radio]{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.tag-selector{display:flex;flex-wrap:wrap;gap:8px}.tag-item{display:inline-flex;align-items:center;padding:6px 14px;border:1px solid var(--border-color);border-radius:20px;font-size:13px;cursor:pointer;transition:all .2s ease;background:var(--card-bg);color:var(--text-secondary)}.tag-item:hover{border-color:var(--primary-color);color:var(--primary-color)}.tag-item.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:500;border:none;border-radius:var(--input-radius);cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #2563eb33}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2563eb40}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-color)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.progress-bar{width:100%;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary-gradient);border-radius:4px;transition:width .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.admin-layout{display:flex;min-height:100vh;background:var(--bg-color)}.admin-sidebar{width:240px;background:#0f172a;color:#fff;display:flex;flex-direction:column;transition:width .3s ease;position:fixed;height:100vh;z-index:100;border-right:1px solid #1E293B}.admin-layout.collapsed .admin-sidebar{width:72px}.sidebar-header{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid #1E293B;height:var(--header-height)}.sidebar-logo-svg{width:24px;height:24px;color:var(--primary-color)}.sidebar-title{font-size:16px;font-weight:600;white-space:nowrap;color:#f8fafc;letter-spacing:.5px}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;color:#94a3b8;text-decoration:none;transition:all .2s ease;white-space:nowrap;font-size:14px;font-weight:500}.sidebar-item:hover{background:#1e293b;color:#f1f5f9}.sidebar-item.active{background:var(--primary-color);color:#fff}.sidebar-icon-wrapper{display:flex;align-items:center;justify-content:center;min-width:24px}.sidebar-icon-svg{width:20px;height:20px}.sidebar-label{font-size:13px}.sidebar-footer{padding:16px;border-top:1px solid #1E293B}.sidebar-toggle{width:100%;padding:8px;background:#1e293b;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:14px;transition:all .2s}.sidebar-toggle:hover{background:#334155;color:#fff}.admin-main{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease;background-color:var(--bg-color)}.admin-layout.collapsed .admin-main{margin-left:72px}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:0 32px;height:var(--header-height);background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:50}.header-title{font-size:18px;font-weight:600;color:var(--text-primary)}.header-right{display:flex;align-items:center;gap:16px}.header-user{font-size:14px;color:var(--text-secondary);font-weight:500}.header-logout{padding:6px 16px;font-size:13px}.admin-content{flex:1;padding:32px;max-width:1600px;width:100%;margin:0 auto}.admin-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.admin-page-title{font-size:20px;font-weight:600;color:var(--text-primary)}.admin-card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px;border:1px solid var(--border-color)}.admin-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.admin-table{width:100%;border-collapse:separate;border-spacing:0}.admin-table th,.admin-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.admin-table th{font-size:13px;font-weight:600;color:var(--text-secondary);background:var(--bg-color);text-transform:uppercase;letter-spacing:.5px}.admin-table th:first-child{border-top-left-radius:8px}.admin-table th:last-child{border-top-right-radius:8px}.admin-table td{font-size:14px;color:var(--text-primary)}.admin-table tr:hover td{background:var(--bg-color)}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.status-badge.warning{background:#fef3c7;color:#b45309;border:1px solid #FDE68A}.status-badge.error{background:#fee2e2;color:#991b1b;border:1px solid #FECACA}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--card-bg);border-radius:var(--card-radius);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-icon{font-size:24px;margin-bottom:16px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:12px;color:var(--primary-color)}.stat-card-value{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.stat-card-label{font-size:13px;color:var(--text-secondary)}.action-buttons{display:flex;gap:8px}.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}.btn-danger{background:#fff;color:var(--error-color);border:1px solid var(--error-color);box-shadow:none}.btn-danger:hover{background:#fef2f2;box-shadow:none}.workbench-page{min-height:100vh;background:#f5f7fa;display:flex;flex-direction:column}.wb-nav{display:flex;justify-content:space-between;align-items:center;padding:0 32px;height:64px;background:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:100}.nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;color:#333;font-weight:700;font-size:16px}.logo-badge{background:#f0f2f5;color:#666;font-size:11px;padding:2px 6px;border-radius:4px}.wb-container{display:flex;flex:1;max-width:1400px;margin:0 auto;width:100%;padding:24px 32px;gap:24px}.wb-sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:16px}.user-card-mini{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000a}.user-info-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.user-avatar-small{width:48px;height:48px;border-radius:50%;overflow:hidden;border:2px solid #f0f0f0}.user-avatar-small img{width:100%;height:100%;object-fit:cover}.user-text{flex:1}.user-name{font-size:15px;font-weight:600;color:#333}.user-role-badge{font-size:11px;color:#667eea;background:#f0f4ff;display:inline-block;padding:1px 6px;border-radius:4px;margin-top:2px}.quota-header{display:flex;justify-content:space-between;font-size:12px;color:#666;margin-bottom:6px}.recharge-link{color:#667eea;text-decoration:none}.quota-bar-bg{height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden;margin-bottom:6px}.quota-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px}.quota-nums{text-align:right;font-size:12px}.quota-current{font-size:16px;font-weight:700;color:#333}.quota-total{color:#999}.step-progress-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000a}.card-title{font-size:14px;font-weight:600;color:#333;margin-bottom:16px}.vertical-steps{display:flex;flex-direction:column}.v-step{display:flex;gap:12px;position:relative}.v-step-icon{width:24px;height:24px;border-radius:50%;background:#f0f2f5;color:#999;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;z-index:1}.v-step.active .v-step-icon{background:#667eea;color:#fff}.v-step.current .v-step-icon{box-shadow:0 0 0 4px #667eea33}.v-step-content{padding-bottom:24px}.v-step:last-child .v-step-content{padding-bottom:0}.v-step-line{width:2px;background:#f0f2f5;margin-left:11px;margin-top:-18px;margin-bottom:6px;height:40px}.v-step-line.active{background:#667eea}.v-step-title{font-size:14px;font-weight:500;color:#666;line-height:1.2}.v-step.active .v-step-title{color:#333;font-weight:600}.v-step-desc{font-size:11px;color:#999;margin-top:2px}.tips-card{background:#fdf6ec;border-radius:12px;padding:16px;display:flex;gap:12px}.tips-icon{font-size:20px}.tips-content h4{font-size:13px;color:#e6a23c;margin-bottom:4px;font-weight:600}.tips-content p{font-size:12px;color:#e6a23c;opacity:.9;line-height:1.5}.wb-content{flex:1;min-width:0}@media(max-width:1024px){.wb-container{padding:16px;flex-direction:column}.wb-sidebar{width:100%;flex-direction:row;overflow-x:auto}.user-card-mini,.step-progress-card{min-width:240px}.vertical-steps{flex-direction:row;gap:16px}.v-step-line{display:none}}.home-page{min-height:100vh;background:var(--bg-color)}.home-nav{display:flex;justify-content:space-between;align-items:center;padding:0 48px;height:var(--header-height);background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border-color)}.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;color:var(--text-primary)}.logo-icon-svg{width:28px;height:28px;color:var(--primary-color)}.logo-badge{background:var(--primary-light);color:var(--primary-color);font-size:11px;padding:3px 8px;border-radius:12px;font-weight:600;border:1px solid rgba(37,99,235,.1)}.nav-link{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.nav-link:hover{color:var(--primary-color)}.nav-right{display:flex;align-items:center;gap:16px}.nav-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--input-radius);font-size:14px;font-weight:500;text-decoration:none;transition:all .2s}.nav-btn-outline{border:1px solid var(--border-color);color:var(--text-primary);background:#fff}.nav-btn-outline:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--primary-light)}.nav-icon{width:16px;height:16px}.nav-btn-admin{background:var(--text-primary);color:#fff;border:1px solid var(--text-primary)}.nav-btn-admin:hover{background:#000;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.nav-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;border:1px solid var(--border-color);cursor:pointer;transition:all .2s}.nav-avatar:hover{border-color:var(--primary-color)}.hero-section{display:flex;flex-direction:column;align-items:center;padding:100px 24px 80px;text-align:center;background:radial-gradient(circle at 50% 0%,#EFF6FF 0%,transparent 40%)}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:#fff;border:1px solid var(--border-color);border-radius:100px;font-size:13px;color:var(--text-secondary);margin-bottom:32px;box-shadow:var(--shadow-sm)}.badge-dot{width:6px;height:6px;background:var(--primary-color);border-radius:50%;box-shadow:0 0 0 2px var(--primary-light)}.hero-title{font-size:56px;font-weight:800;line-height:1.1;margin-bottom:24px;color:var(--text-primary);letter-spacing:-.02em}.title-gradient{color:var(--primary-color)}.hero-desc{font-size:18px;color:var(--text-secondary);margin-bottom:40px;max-width:580px;line-height:1.6}.hero-features{display:flex;gap:16px;margin-bottom:48px}.feature-tag{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff9;border:1px solid var(--border-color);border-radius:100px;font-size:14px;color:var(--text-secondary);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.feature-icon-svg{width:16px;height:16px;color:var(--primary-color)}.hero-cta{padding:14px 40px;background:var(--primary-color);color:#fff;border:none;border-radius:100px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #2563eb40}.hero-cta:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #2563eb4d}.hero-note{margin-top:24px;font-size:12px;color:var(--text-muted)}.scroll-hint{margin-top:60px;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:12px}.scroll-arrow{font-size:16px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.features-section{padding:80px 48px;background:#fff;border-top:1px solid var(--border-color)}.section-title{text-align:center;font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:60px;letter-spacing:-.01em}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1200px;margin:0 auto}.feature-card{background:var(--bg-color);border:1px solid transparent;border-radius:16px;padding:32px 24px;text-align:center;transition:all .2s}.feature-card:hover{background:#fff;border-color:var(--border-color);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.feature-card-icon{width:64px;height:64px;margin:0 auto 20px;background:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);color:var(--primary-color)}.feature-icon-lg{width:32px;height:32px}.feature-card h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.feature-card p{font-size:14px;color:var(--text-secondary);line-height:1.6}.process-section{padding:80px 48px;background:var(--bg-color);border-top:1px solid var(--border-color)}.process-steps{display:flex;justify-content:center;align-items:center;gap:32px;max-width:1000px;margin:0 auto}.process-step{flex:1;background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:32px 24px;text-align:center;box-shadow:var(--shadow-sm)}.step-number{width:40px;height:40px;background:var(--primary-light);color:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;margin:0 auto 16px}.process-step h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.process-step p{font-size:13px;color:var(--text-secondary)}.process-arrow{font-size:24px;color:var(--text-muted)}.home-footer{padding:48px;background:#fff;color:var(--text-primary);text-align:center;border-top:1px solid var(--border-color)}.footer-logo{display:flex;justify-content:center;align-items:center;gap:8px;font-size:18px;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.footer-desc{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.footer-copyright{color:var(--text-muted);font-size:13px}.floating-btn{position:fixed;bottom:32px;right:32px;width:50px;height:50px;background:var(--text-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #00000026;transition:all .2s}.floating-icon{width:24px;height:24px}.floating-btn:hover{transform:scale(1.05);background:#000}@media(max-width:1024px){.features-grid{grid-template-columns:repeat(2,1fr)}.process-steps{flex-direction:column}.process-arrow{transform:rotate(90deg)}}@media(max-width:768px){.home-nav{padding:12px 16px}.nav-links{display:none}.hero-title{font-size:40px}.hero-features{flex-direction:column}.features-grid{grid-template-columns:1fr}}.user-center-page{min-height:100vh;background:linear-gradient(180deg,#f8f9ff,#fff)}.uc-nav{display:flex;justify-content:space-between;align-items:center;padding:16px 48px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.05);position:sticky;top:0;z-index:100}.nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;color:#333;font-weight:700;font-size:18px}.logo-icon{font-size:28px}.logo-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500}.nav-left{display:flex;align-items:center;gap:48px}.nav-links{display:flex;gap:32px}.nav-link{color:#666;text-decoration:none;font-size:14px;transition:color .2s}.nav-link:hover{color:#667eea}.nav-right{display:flex;align-items:center;gap:12px}.nav-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:14px;text-decoration:none;transition:all .2s}.nav-btn-outline{border:1px solid #e0e0e0;color:#333;background:#fff}.nav-btn-outline:hover{border-color:#667eea;color:#667eea}.nav-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.nav-btn-admin{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none}.nav-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid #e0e0e0;cursor:pointer;transition:border-color .2s}.nav-avatar:hover{border-color:#667eea}.nav-avatar img{width:100%;height:100%;object-fit:cover}.uc-container{display:flex;gap:24px;max-width:1400px;margin:0 auto;padding:32px 48px}.uc-sidebar{width:280px;flex-shrink:0}.user-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:32px 24px;text-align:center;color:#fff;margin-bottom:16px}.user-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;margin:0 auto 16px;border:3px solid rgba(255,255,255,.3);background:#fff}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-name{font-size:20px;font-weight:700;margin-bottom:12px}.user-badges{display:flex;justify-content:center;gap:8px;margin-bottom:20px}.badge{font-size:11px;padding:4px 10px;border-radius:12px}.badge-vip{background:#fff3;color:gold}.badge-code{background:#fff3;color:#fff}.user-quota{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff26;border-radius:12px;margin-bottom:8px}.quota-label{font-size:13px;opacity:.9}.quota-icon{font-size:20px}.quota-value{font-size:36px;font-weight:800;margin-bottom:4px}.quota-detail{font-size:12px;opacity:.8}.user-menu{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000f;margin-bottom:16px}.menu-item{display:flex;align-items:center;gap:12px;padding:16px 20px;cursor:pointer;transition:all .2s;border-bottom:1px solid #f0f0f0}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:#f8f9ff}.menu-item.active{background:linear-gradient(135deg,#f8f9ff,#e8ebff);border-left:3px solid #667eea}.menu-icon{font-size:24px}.menu-content{flex:1}.menu-title{font-size:15px;font-weight:600;color:#333;display:inline}.menu-tag{display:inline-block;margin-left:8px;font-size:11px;padding:2px 8px;background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:#fff;border-radius:10px}.menu-desc{font-size:12px;color:#999;margin-top:4px}.menu-arrow{font-size:20px;color:#ccc}.help-card{display:flex;align-items:center;gap:12px;padding:16px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;cursor:pointer;transition:transform .2s}.help-card:hover{transform:scale(1.02)}.help-icon{font-size:24px}.uc-content{flex:1;background:#fff;border-radius:20px;box-shadow:0 2px 12px #0000000f;overflow:hidden}.content-header{padding:24px 32px 0}.content-title{font-size:24px;font-weight:700;color:#333;margin-bottom:8px}.content-subtitle{font-size:14px;color:#667eea}.content-tabs{display:flex;gap:8px;padding:20px 32px;border-bottom:1px solid #f0f0f0}.tab-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;background:#f8f9ff;border:1px solid #e8e8ff;border-radius:8px;font-size:14px;color:#666;cursor:pointer;transition:all .2s}.tab-btn:hover{border-color:#667eea;color:#667eea}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.content-body{padding:32px;min-height:400px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.8}.empty-state h3{font-size:18px;color:#333;margin-bottom:8px}.empty-state p{font-size:14px;color:#999;margin-bottom:24px}.empty-btn{padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;text-decoration:none;font-size:14px;transition:all .2s}.empty-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.records-table{overflow-x:auto}.records-table table{width:100%;border-collapse:collapse}.records-table th,.records-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #f0f0f0}.records-table th{font-size:13px;font-weight:600;color:#666;background:#f8f9ff}.records-table td{font-size:14px;color:#333}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px}.status-pending{background:#fff3cd;color:#856404}.status-processing{background:#cce5ff;color:#004085}.status-completed{background:#d4edda;color:#155724}.status-failed{background:#f8d7da;color:#721c24}.action-btns{display:flex;gap:8px}.action-btn{padding:6px 12px;background:#f8f9ff;border:1px solid #e8e8ff;border-radius:6px;font-size:13px;color:#667eea;text-decoration:none;transition:all .2s}.action-btn:hover{background:#667eea;color:#fff}.floating-btn{position:fixed;bottom:32px;right:32px;width:56px;height:56px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;box-shadow:0 4px 20px #667eea66;transition:all .3s}.floating-btn:hover{transform:scale(1.1)}@media(max-width:1024px){.uc-container{flex-direction:column;padding:24px}.uc-sidebar{width:100%}.user-card{padding:24px}}@media(max-width:768px){.uc-nav{padding:12px 16px}.nav-links{display:none}.content-tabs{flex-wrap:wrap}}.status-progress{width:140px}.progress-text{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-bottom:4px;color:#666}.status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:4px}.status-dot.status-processing{background:#667eea}.status-dot.status-pending{background:#ffc107}.percent{font-weight:600;color:#667eea}.progress-cnt{height:4px;background:#f0f0f0;border-radius:2px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;transition:width .3s ease}.badge-group{background:#ffffff40;color:#fff;font-weight:500}.checkin-section{max-width:600px;margin:0 auto}.checkin-done{text-align:center;padding:60px 20px;background:linear-gradient(135deg,#d4edda,#c3e6cb);border-radius:16px}.checkin-done .checkin-icon{font-size:64px;margin-bottom:16px}.checkin-done h3{font-size:24px;color:#155724;margin-bottom:12px}.checkin-done .points{font-size:28px;font-weight:700;color:#667eea}.checkin-done .checkin-type{margin-top:8px;color:#666;font-size:14px}.checkin-options{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.checkin-card{position:relative;padding:40px 24px;border-radius:16px;text-align:center;cursor:pointer;transition:all .3s}.checkin-card.stable{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.checkin-card.random{background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:#fff}.checkin-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.checkin-card .card-icon{font-size:48px;margin-bottom:16px}.checkin-card h3{font-size:20px;margin-bottom:8px}.checkin-card .points-preview{font-size:24px;font-weight:700;margin-bottom:8px}.checkin-card .card-desc{font-size:13px;opacity:.85}.checkin-card .loading-overlay{position:absolute;inset:0;background:#00000080;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:16px}.checkin-result{padding:16px;border-radius:8px;text-align:center;margin-bottom:24px}.checkin-result.success{background:#d4edda;color:#155724}.checkin-result.error{background:#f8d7da;color:#721c24}.checkin-tips{background:#f8f9ff;border-radius:12px;padding:20px}.checkin-tips h4{font-size:15px;color:#333;margin-bottom:12px}.checkin-tips ul{list-style:none;padding:0;margin:0}.checkin-tips li{font-size:13px;color:#666;padding:6px 0 6px 20px;position:relative}.checkin-tips li:before{content:"•";position:absolute;left:0;color:#667eea}.profile-section{max-width:600px}.profile-avatar-section,.profile-info-section,.profile-password-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #f0f0f0}.profile-section h3{font-size:16px;color:#333;margin-bottom:16px}.avatar-preview{width:100px;height:100px;border-radius:50%;overflow:hidden;border:3px solid #e0e0e0;margin-bottom:12px}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-hint{font-size:13px;color:#999}.info-row{margin-bottom:16px}.info-row label{display:block;font-size:14px;color:#666;margin-bottom:6px}.info-row input{width:100%;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px}.info-row .input-disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.info-row .info-hint{display:block;font-size:12px;color:#999;margin-top:4px}.password-form .form-row{margin-bottom:16px}.password-form label{display:block;font-size:14px;color:#666;margin-bottom:6px}.password-form input{width:100%;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px}.password-form input:focus{outline:none;border-color:#667eea}.password-form .message{padding:10px;border-radius:6px;margin-bottom:16px;font-size:14px}.password-form .message.success{background:#d4edda;color:#155724}.password-form .message.error{background:#f8d7da;color:#721c24}.btn-save{padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.btn-save:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:20px 0;margin-top:16px;border-top:1px solid #f0f0f0}.pagination .page-btn{padding:8px 16px;background:#f8f9ff;border:1px solid #e8e8ff;border-radius:6px;font-size:13px;color:#667eea;cursor:pointer;transition:all .2s}.pagination .page-btn:hover:not(:disabled){background:#667eea;color:#fff}.pagination .page-btn:disabled{opacity:.5;cursor:not-allowed}.pagination .page-info{font-size:14px;color:#666}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:400% 400%;animation:gradientShift 15s ease infinite;padding:20px;position:relative;overflow:hidden}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.login-page:before{content:"";position:absolute;top:-200px;right:-200px;width:500px;height:500px;background:#ffffff1a;border-radius:50%;pointer-events:none}.login-page:after{content:"";position:absolute;bottom:-150px;left:-150px;width:400px;height:400px;background:#ffffff14;border-radius:50%;pointer-events:none}.login-container{width:100%;max-width:420px;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:48px 40px;box-shadow:0 25px 80px #00000040;position:relative;z-index:1;border:1px solid rgba(255,255,255,.3)}.login-header{text-align:center;margin-bottom:36px}.login-logo-svg{width:64px!important;height:64px!important;margin-bottom:20px;color:#667eea!important;filter:drop-shadow(0 4px 12px rgba(102,126,234,.3))}.login-title{font-size:28px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px;letter-spacing:-.5px}.login-subtitle{font-size:15px;color:#666;font-weight:400}.login-form{display:flex;flex-direction:column;gap:22px}.login-form .form-group{position:relative}.login-form .form-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:8px;letter-spacing:.3px}.login-form .form-input{width:100%;padding:14px 16px;font-size:15px;border:2px solid #e5e7eb;border-radius:12px;background:#f9fafb;transition:all .3s ease;color:#1f2937}.login-form .form-input::placeholder{color:#9ca3af}.login-form .form-input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea26}.login-error{padding:14px 18px;background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border-radius:12px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;border:1px solid #fca5a5}.login-error:before{content:"⚠️"}.login-success{padding:14px 18px;background:linear-gradient(135deg,#d1fae5,#a7f3d0)!important;color:#065f46!important;border-radius:12px;font-size:14px;font-weight:500;border:1px solid #6ee7b7}.login-btn{width:100%;padding:16px;font-size:16px;font-weight:600;margin-top:12px;border:none;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #667eea66;position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.login-btn:hover:before{left:100%}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #667eea80}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer{text-align:center;margin-top:28px;font-size:14px;color:#6b7280}.login-footer a{color:#667eea;text-decoration:none;font-weight:600;transition:all .2s}.login-footer a:hover{color:#764ba2;text-decoration:none}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:#9ca3af;font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,#e5e7eb,transparent)}@media(max-width:480px){.login-container{padding:36px 28px;border-radius:20px}.login-title{font-size:24px}}.record-detail-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.detail-nav{display:flex;justify-content:space-between;align-items:center;padding:16px 32px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.detail-nav .nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;color:#fff}.detail-nav .logo-icon{font-size:24px}.detail-nav .logo-text{font-size:18px;font-weight:600}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#fff;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-icon{font-size:64px;margin-bottom:16px}.detail-container{max-width:1000px;margin:0 auto;padding:24px}.detail-header-card{background:#fff;border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:0 10px 40px #0000001a}.header-main{display:flex;align-items:center;gap:16px;margin-bottom:16px}.software-name{font-size:28px;font-weight:700;color:#1f2937;margin:0}.header-meta{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px}.meta-item{display:flex;align-items:center;gap:6px;color:#6b7280;font-size:14px}.meta-icon{font-size:16px}.header-actions{display:flex;flex-wrap:wrap;gap:12px;padding-top:20px;border-top:1px solid #E5E7EB}.status-badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500}.status-pending,.status-processing,.status-generating_code,.status-generating_manual,.status-creating_docs{background:#fef3c7;color:#92400e}.status-completed{background:#d1fae5;color:#065f46}.status-failed{background:#fee2e2;color:#991b1b}.detail-content{display:flex;flex-direction:column;gap:24px}.detail-section{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 20px #0000000d}.section-title{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #E5E7EB}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item.full-width{grid-column:1 / -1}.info-item label{font-size:12px;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-item span{font-size:15px;color:#374151}.info-block{margin-bottom:16px}.info-block label{display:block;font-size:12px;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.info-block p{font-size:15px;color:#374151;line-height:1.6;margin:0;background:#f9fafb;padding:12px 16px;border-radius:8px}.tag-group{margin-bottom:16px}.tag-group label{display:block;font-size:12px;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{display:inline-flex;padding:6px 12px;background:#f3f4f6;color:#4b5563;border-radius:6px;font-size:13px;font-weight:500}.tag-primary{background:#eef2ff;color:#4f46e5}.tag-success{background:#d1fae5;color:#065f46}.status-info{display:flex;flex-direction:column;gap:16px}.status-row{display:flex;align-items:center;gap:12px}.status-row label{font-size:14px;color:#6b7280;min-width:80px}.progress-bar-container{position:relative;height:24px;background:#e5e7eb;border-radius:12px;overflow:hidden}.progress-bar-container .progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:12px;transition:width .3s ease}.progress-bar-container .progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:600;color:#374151}.error-message{background:#fee2e2;padding:12px 16px;border-radius:8px}.error-message label{display:block;font-size:12px;color:#991b1b;margin-bottom:4px}.error-message p{margin:0;color:#991b1b;font-size:14px}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;border:none;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}@media(max-width:768px){.detail-container{padding:16px}.detail-header-card{padding:20px}.software-name{font-size:22px}.header-meta{gap:12px}.info-grid{grid-template-columns:1fr}.header-actions{flex-direction:column}.header-actions .btn{width:100%;justify-content:center}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:40px 0 60px}.page-header{text-align:center;margin-bottom:40px}.page-title{font-size:32px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.page-title .highlight{color:var(--primary-color)}.page-subtitle{font-size:16px;color:var(--text-secondary)}.step-card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--shadow-md);padding:32px 40px;margin-bottom:24px}.step-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.step-card-title{font-size:18px;font-weight:600;color:var(--text-primary)}.step-indicator{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.step-indicator .dot{width:8px;height:8px;border-radius:50%;background:var(--primary-color)}.step-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color)}.form-section-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.generate-container{text-align:center;padding:60px 40px}.generate-icon{width:80px;height:80px;margin:0 auto 24px;background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center}.generate-icon svg{width:40px;height:40px;color:var(--primary-color)}.generate-title{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.generate-desc{font-size:14px;color:var(--text-secondary);margin-bottom:32px}.generate-progress{max-width:400px;margin:0 auto 24px}.generate-status{font-size:14px;color:var(--text-secondary);margin-top:12px}.result-list{display:flex;flex-direction:column;gap:16px;margin-top:32px}.result-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-color);border-radius:var(--input-radius)}.result-item-info{display:flex;align-items:center;gap:12px}.result-item-icon{width:40px;height:40px;background:var(--primary-light);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.result-item-name{font-size:14px;font-weight:500;color:var(--text-primary)}.result-item-size{font-size:12px;color:var(--text-muted)}.char-count{float:right;font-size:12px;font-weight:400;color:var(--text-muted)}.char-count.over-limit{color:var(--error-color)}.input-error{border-color:var(--error-color)!important}.ai-auto-section{margin-bottom:24px}.ai-auto-section .form-section-title{display:flex;justify-content:space-between;align-items:center}.btn-ai-fill{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;background:var(--primary-light);color:var(--primary-color);border:1px solid rgba(37,99,235,.2);border-radius:20px;cursor:pointer;transition:all .2s ease;font-weight:500}.btn-ai-fill:hover{background:var(--primary-color);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb33}.btn-ai-fill:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinner-small{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.custom-input-wrapper{margin-top:16px;padding-top:16px;border-top:1px dashed var(--border-color)}.custom-input-wrapper .form-group{margin-bottom:0}.doc-type-selector{display:flex;flex-direction:column;gap:12px}.doc-type-item{display:flex;align-items:flex-start;gap:12px;padding:16px;border:1px solid var(--border-color);border-radius:var(--input-radius);cursor:pointer;transition:all .2s ease}.doc-type-item:hover{border-color:var(--primary-color)}.doc-type-item.active{border-color:var(--primary-color);background:var(--primary-light)}.doc-type-item input[type=radio]{margin-top:2px;accent-color:var(--primary-color)}.doc-type-content{display:flex;flex-direction:column;gap:4px}.doc-type-name{font-size:14px;font-weight:500;color:var(--primary-color)}.doc-type-desc{font-size:12px;color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--card-bg);border-radius:var(--card-radius);padding:32px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-content.modal-lg{max-width:640px}.modal-title{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:24px}.modal-form{display:flex;flex-direction:column;gap:16px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.filter-row{display:flex;gap:16px;align-items:center}code{background:var(--bg-color);padding:2px 6px;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:13px;color:var(--primary-color)}.generate-info{background:var(--primary-light);border-radius:8px;padding:16px 20px;margin:20px 0;text-align:left}.generate-info p{margin:8px 0;font-size:14px;color:var(--text-secondary)}.generate-hint{font-size:13px;color:var(--text-muted);margin-top:20px}.generate-tips{background:#f0fdf4;border-radius:8px;padding:16px 20px;margin:20px 0;text-align:left}.generate-tips p{margin:6px 0;font-size:13px;color:#166534}.error-text{color:var(--error-color)}.error-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}
