.global-message-container[data-v-af487688]{position:fixed;right:24px;bottom:24px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.global-message[data-v-af487688]{min-width:220px;max-width:360px;padding:10px 14px;border-radius:10px;box-shadow:0 4px 10px #0f172a26;font-size:14px;display:flex;align-items:center;pointer-events:auto}.global-message--success[data-v-af487688]{background:#ecfdf3;color:#166534;border:1px solid #bbf7d0}.global-message--error[data-v-af487688]{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.global-message__content[data-v-af487688]{word-break:break-word}.msg-fade-enter-active[data-v-af487688],.msg-fade-leave-active[data-v-af487688]{transition:all .2s ease}.msg-fade-enter-from[data-v-af487688],.msg-fade-leave-to[data-v-af487688]{opacity:0;transform:translateY(10px)}.layout[data-v-7def80cb]{min-height:100vh;display:grid;grid-template-rows:auto 1fr auto}.site-header[data-v-7def80cb]{position:sticky;top:0;z-index:100;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.8);padding:0 32px;height:64px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0f172a0a;transition:box-shadow .3s ease}.brand[data-v-7def80cb]{display:flex;align-items:center;gap:10px;font-family:var(--font-heading, "Poppins", sans-serif);font-weight:700;font-size:18px;color:var(--color-text, #0f172a);text-decoration:none;letter-spacing:-.01em}.brand img[data-v-7def80cb]{width:36px;height:36px;border-radius:10px}.site-nav[data-v-7def80cb]{display:flex;align-items:center;gap:4px}.nav-link[data-v-7def80cb]{color:#475569;text-decoration:none;font-weight:600;font-size:14px;padding:8px 14px;border-radius:var(--radius-md, 10px);transition:all .2s ease;position:relative}.nav-link[data-v-7def80cb]:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%) scaleX(0);width:20px;height:2px;border-radius:1px;background:var(--primary, #2563eb);transition:transform .25s cubic-bezier(.4,0,.2,1)}.nav-link[data-v-7def80cb]:hover{color:var(--primary, #2563eb);background:#2563eb0f}.nav-link.active[data-v-7def80cb]{color:var(--primary, #2563eb);background:#2563eb14;font-weight:700}.nav-link.active[data-v-7def80cb]:after{transform:translate(-50%) scaleX(1)}.nav-actions[data-v-7def80cb]{display:flex;align-items:center;gap:10px;position:relative}.announcement-scroll[data-v-7def80cb]{width:200px;height:36px;overflow:hidden;position:relative;border-radius:var(--radius-md, 10px);background:#2563eb0a;border:1px solid rgba(37,99,235,.08)}.announcement-scroll-wrapper[data-v-7def80cb]{height:100%;cursor:pointer}.announcement-list[data-v-7def80cb]{transition:transform .5s ease-in-out;height:100%}.announcement-item[data-v-7def80cb]{height:36px;line-height:36px;padding:0 12px;color:var(--primary, #2563eb);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;text-decoration:none;font-weight:500}.announcement-item[data-v-7def80cb]:hover{background:#2563eb14;text-decoration:underline}.notification-dropdown[data-v-7def80cb]{position:relative}.notification-trigger[data-v-7def80cb]{display:flex;align-items:center;gap:6px;height:36px;padding:0 12px;border-radius:var(--radius-md, 10px);border:1px solid var(--color-border, #e2e8f0);background:#fff;color:#475569;font-size:14px;cursor:pointer;transition:all .2s;position:relative}.notification-trigger[data-v-7def80cb]:hover{background:#f8fafc;border-color:#cbd5e1}.notification-text[data-v-7def80cb]{color:var(--color-text-muted, #64748b);font-weight:500}.notification-badge[data-v-7def80cb]{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;line-height:1;animation:badge-pulse-7def80cb 2s ease-in-out infinite}@keyframes badge-pulse-7def80cb{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.chevron-icon[data-v-7def80cb]{width:14px;height:14px;color:var(--color-text-light, #94a3b8);transition:transform .2s}.notification-dropdown-menu[data-v-7def80cb]{position:absolute;top:calc(100% + 6px);right:0;width:340px;max-height:420px;overflow-y:auto;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius-lg, 14px);box-shadow:var(--shadow-xl, 0 20px 40px -5px rgba(15, 23, 42, .1));z-index:1000}.notification-dropdown-menu[data-v-7def80cb]:before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px;background:transparent}.notification-dropdown-header[data-v-7def80cb]{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f1f5f9}.notification-dropdown-title[data-v-7def80cb]{color:var(--color-text, #0f172a);font-weight:700;font-size:15px}.notification-empty[data-v-7def80cb]{padding:32px 24px;text-align:center;color:var(--color-text-light, #94a3b8);font-size:14px}.notification-item[data-v-7def80cb]{padding:12px 16px;border-bottom:1px solid #f8fafc;cursor:pointer;transition:background .15s}.notification-item[data-v-7def80cb]:last-child{border-bottom:none}.notification-item[data-v-7def80cb]:hover{background:#f8fafc}.notification-item-title[data-v-7def80cb]{color:#334155;font-size:14px;font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-item-time[data-v-7def80cb]{color:var(--color-text-light, #94a3b8);font-size:12px}.link-btn[data-v-7def80cb]{border:none;background:transparent;color:var(--primary, #2563eb);cursor:pointer;padding:0;font-weight:600;font-size:13px;transition:color .15s}.link-btn[data-v-7def80cb]:hover{color:var(--primary-dark, #1d4ed8)}.language-switcher[data-v-7def80cb]{position:relative}.language-trigger[data-v-7def80cb]{display:flex;align-items:center;gap:5px;height:36px;padding:0 10px;border-radius:var(--radius-md, 10px);border:1px solid var(--color-border, #e2e8f0);background:#fff;color:#475569;font-size:13px;cursor:pointer;transition:all .2s}.language-trigger[data-v-7def80cb]:hover{background:#f8fafc;border-color:#cbd5e1}.language-text[data-v-7def80cb]{color:var(--color-text-muted, #64748b);font-weight:500}.language-dropdown-menu[data-v-7def80cb]{position:absolute;top:calc(100% + 6px);right:0;min-width:130px;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius-lg, 14px);box-shadow:var(--shadow-lg, 0 10px 25px -3px rgba(15, 23, 42, .08));z-index:1000;overflow:hidden}.language-dropdown-menu[data-v-7def80cb]:before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px;background:transparent}.language-option[data-v-7def80cb]{padding:10px 16px;color:#475569;font-size:14px;cursor:pointer;transition:all .15s;font-weight:500}.language-option[data-v-7def80cb]:hover{background:#f8fafc;color:var(--color-text, #0f172a)}.language-option.active[data-v-7def80cb]{background:var(--primary-bg, #eff6ff);color:var(--primary, #2563eb);font-weight:600}.language-option.active[data-v-7def80cb]:after{display:none}.user-dropdown[data-v-7def80cb]{position:relative}.user-dropdown-trigger[data-v-7def80cb]{display:flex;align-items:center;gap:6px;cursor:pointer;padding:3px;border-radius:var(--radius-full, 9999px);transition:all .2s;border:2px solid transparent}.user-dropdown-trigger[data-v-7def80cb]:hover{border-color:#2563eb26;background:#2563eb0a}.user-avatar[data-v-7def80cb]{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid #e2e8f0;transition:border-color .2s}.user-dropdown-trigger:hover .user-avatar[data-v-7def80cb]{border-color:#2563eb4d}.user-dropdown-menu[data-v-7def80cb]{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius-lg, 14px);box-shadow:var(--shadow-xl, 0 20px 40px -5px rgba(15, 23, 42, .1));z-index:1000;overflow:hidden;padding:4px 0}.user-dropdown-menu[data-v-7def80cb]:before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px;background:transparent}.user-dropdown-item[data-v-7def80cb]{padding:10px 16px;color:#475569;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.user-dropdown-item[data-v-7def80cb]:hover{background:#f8fafc;color:var(--color-text, #0f172a)}.user-dropdown-divider[data-v-7def80cb]{height:1px;background:#f1f5f9;margin:4px 0}.btn[data-v-7def80cb]{height:36px;padding:0 16px;border-radius:var(--radius-md, 10px);border:1px solid var(--color-border, #e2e8f0);background:#fff;color:var(--color-text, #0f172a);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;font-size:14px;font-weight:600;transition:all .2s;text-decoration:none}.btn[data-v-7def80cb]:hover{background:#f8fafc;border-color:#cbd5e1}.btn--primary[data-v-7def80cb]{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb);color:#fff;box-shadow:0 2px 8px #2563eb40}.btn--primary[data-v-7def80cb]:hover{background:var(--primary-dark, #1d4ed8);border-color:var(--primary-dark, #1d4ed8);box-shadow:0 4px 12px #2563eb4d}.main[data-v-7def80cb]{min-height:0}.site-footer[data-v-7def80cb]{border-top:1px solid var(--color-border, #e2e8f0);background:#fff}.footer-inner[data-v-7def80cb]{padding:20px 32px;color:var(--color-text-light, #94a3b8);text-align:center;font-size:13px;letter-spacing:.01em}@media (max-width: 768px){.site-header[data-v-7def80cb]{padding:0 16px;height:56px}.brand[data-v-7def80cb]{font-size:16px;gap:8px}.brand img[data-v-7def80cb]{width:30px;height:30px}.site-nav[data-v-7def80cb]{gap:2px}.nav-link[data-v-7def80cb]{font-size:13px;padding:6px 8px}.btn[data-v-7def80cb]{height:34px;padding:0 14px;font-size:13px}.nav-actions[data-v-7def80cb]{gap:6px}.announcement-scroll[data-v-7def80cb]{width:140px;height:32px}.announcement-item[data-v-7def80cb]{height:32px;line-height:32px;font-size:12px}.notification-dropdown-menu[data-v-7def80cb]{width:290px}.notification-trigger[data-v-7def80cb],.language-trigger[data-v-7def80cb]{height:34px;font-size:13px}.footer-inner[data-v-7def80cb]{padding:16px}}.slider-captcha-container[data-v-2b936731]{width:320px;-webkit-user-select:none;user-select:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.captcha-image-wrapper[data-v-2b936731]{position:relative;width:300px;height:150px;overflow:hidden;border-radius:12px;border:1px solid #e5e7eb;background:#fafafa;box-shadow:0 2px 8px #0000000d}.bg-image[data-v-2b936731]{width:100%;height:100%;display:block;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.slider-thumb[data-v-2b936731]{position:absolute;cursor:move;border-radius:4px;box-shadow:0 2px 6px #00000026;pointer-events:none;object-fit:cover}.slider-track[data-v-2b936731]{position:relative;height:48px;margin-top:16px;background:#f1f5f9;border-radius:24px;overflow:hidden;border:1px solid #e5e7eb}.slider-progress[data-v-2b936731]{position:absolute;height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#3b82f6);background-size:200% 100%;border-radius:24px 0 0 24px;transition:width .15s ease-out;animation:shimmer-2b936731 2s infinite}@keyframes shimmer-2b936731{0%{background-position:200% 0}to{background-position:-200% 0}}.slider-handle[data-v-2b936731]{position:absolute;top:0;width:48px;height:48px;margin:1px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026,0 4px 12px #0000001a;display:flex;align-items:center;justify-content:center;cursor:move;transition:all .2s ease;z-index:10;font-size:24px;font-weight:600;color:#64748b}.slider-handle[data-v-2b936731]:hover{transform:scale(1.05);box-shadow:0 4px 16px #00000026,0 6px 20px #0000001f}.slider-handle[data-v-2b936731]:active{transform:scale(.98);box-shadow:0 2px 6px #0000001f}.slider-handle.is-success[data-v-2b936731]{background:#52c41a;color:#fff;box-shadow:0 4px 12px #52c41a4d;animation:success-2b936731 .4s ease}.slider-handle.is-fail[data-v-2b936731]{background:#ff4d4f;color:#fff;box-shadow:0 4px 12px #ff4d4f4d;animation:fail-2b936731 .4s ease}.slider-tip[data-v-2b936731]{position:absolute;width:100%;text-align:center;line-height:48px;color:#94a3b8;font-size:13px;font-weight:500;pointer-events:none;text-shadow:0 1px 2px rgba(255,255,255,.8);letter-spacing:.5px}@keyframes success-2b936731{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes fail-2b936731{0%{transform:scale(1)}50%{transform:scale(.9)}to{transform:scale(1)}}.login-tabs[data-v-5631b342]{display:flex;gap:4px;border-bottom:2px solid var(--color-border);margin-bottom:20px;padding-bottom:0}.tab-btn[data-v-5631b342]{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-muted);font-size:15px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-smooth);margin-bottom:-2px;position:relative;flex:1;text-align:center}.tab-btn[data-v-5631b342]:hover{color:var(--primary);background:#2563eb0a}.tab-btn.active[data-v-5631b342]{color:var(--primary);border-bottom-color:var(--primary);background:transparent;font-weight:600}.form-row--sms[data-v-5631b342]{display:flex;align-items:flex-end;gap:12px}.form-row--sms-input[data-v-5631b342]{flex:1;display:grid;gap:6px}.btn--sms[data-v-5631b342]{min-width:120px;white-space:nowrap;height:42px;border-radius:var(--radius-md);font-weight:600;font-size:13px;background:var(--primary-bg);color:var(--primary);border:1px solid var(--primary);cursor:pointer;transition:all var(--transition-base)}.btn--sms[data-v-5631b342]:hover:not(:disabled){background:var(--primary);color:#fff;box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn--sms[data-v-5631b342]:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.modal-overlay[data-v-5631b342]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0f172a66;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;transition:opacity var(--transition-smooth)}.modal-content[data-v-5631b342]{background:var(--color-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:420px;width:90%;max-height:90vh;overflow-y:auto;border:1px solid var(--color-border)}.modal-header[data-v-5631b342]{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-header h3[data-v-5631b342]{margin:0;font-size:18px;font-weight:700;font-family:var(--font-heading);color:var(--color-text)}.modal-close[data-v-5631b342]{background:none;border:none;font-size:22px;cursor:pointer;color:var(--color-text-muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-base)}.modal-close[data-v-5631b342]:hover{background:var(--color-bg);color:var(--color-text)}.modal-body[data-v-5631b342]{padding:24px}.captcha-section[data-v-5631b342]{text-align:center;padding:8px 0;margin-bottom:16px}.captcha-image[data-v-5631b342]{max-width:100%;height:80px;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;margin-bottom:12px;transition:border-color var(--transition-base)}.captcha-image[data-v-5631b342]:hover{border-color:var(--primary)}.captcha-hint[data-v-5631b342]{font-size:13px;color:var(--color-text-muted);margin:0}.captcha-input[data-v-5631b342]{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:16px;text-align:center;letter-spacing:2px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.captcha-input[data-v-5631b342]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.modal-footer[data-v-5631b342]{display:flex;gap:12px;padding:16px 24px 24px;border-top:1px solid var(--color-border);justify-content:flex-end}.form-row--sms[data-v-27e4c230]{display:flex;align-items:flex-end;gap:12px}.form-row--sms-input[data-v-27e4c230]{flex:1;display:grid;gap:6px}.btn--sms[data-v-27e4c230]{min-width:120px;white-space:nowrap;height:42px;border-radius:var(--radius-md);font-weight:600;font-size:13px;background:var(--primary-bg);color:var(--primary);border:1px solid var(--primary);cursor:pointer;transition:all var(--transition-base)}.btn--sms[data-v-27e4c230]:hover:not(:disabled){background:var(--primary);color:#fff;box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn--sms[data-v-27e4c230]:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.modal-overlay[data-v-27e4c230]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0f172a66;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;transition:opacity var(--transition-smooth)}.modal-content[data-v-27e4c230]{background:var(--color-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:420px;width:90%;max-height:90vh;overflow-y:auto;border:1px solid var(--color-border)}.modal-header[data-v-27e4c230]{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-header h3[data-v-27e4c230]{margin:0;font-size:18px;font-weight:700;font-family:var(--font-heading);color:var(--color-text)}.modal-close[data-v-27e4c230]{background:none;border:none;font-size:22px;cursor:pointer;color:var(--color-text-muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-base)}.modal-close[data-v-27e4c230]:hover{background:var(--color-bg);color:var(--color-text)}.modal-body[data-v-27e4c230]{padding:24px}.captcha-section[data-v-27e4c230]{text-align:center;padding:8px 0;margin-bottom:16px}.captcha-image[data-v-27e4c230]{max-width:100%;height:80px;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;margin-bottom:12px;transition:border-color var(--transition-base)}.captcha-image[data-v-27e4c230]:hover{border-color:var(--primary)}.captcha-hint[data-v-27e4c230]{font-size:13px;color:var(--color-text-muted);margin:0}.captcha-input[data-v-27e4c230]{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:16px;text-align:center;letter-spacing:2px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.captcha-input[data-v-27e4c230]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.modal-footer[data-v-27e4c230]{display:flex;gap:12px;padding:16px 24px 24px;border-top:1px solid var(--color-border);justify-content:flex-end}.home[data-v-6ef54b13]{min-height:100vh;display:grid;grid-template-rows:auto 1fr;background:var(--color-bg)}.banner[data-v-6ef54b13]{overflow:hidden;position:relative;height:420px;background:var(--color-card)}.banner-track[data-v-6ef54b13]{display:flex;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1)}.banner-item[data-v-6ef54b13]{position:relative;flex:0 0 100%;display:grid;place-items:center}.banner-item[data-v-6ef54b13]:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(15,23,42,.45) 0%,rgba(15,23,42,.1) 40%,transparent 70%);pointer-events:none;z-index:1}.banner-image[data-v-6ef54b13]{width:100%;height:420px;object-fit:cover;opacity:0;transition:opacity .4s ease}.banner-image--loaded[data-v-6ef54b13]{opacity:1}.banner-skeleton[data-v-6ef54b13]{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:shimmer-6ef54b13 1.5s infinite}@keyframes shimmer-6ef54b13{0%{background-position:200% 0}to{background-position:-200% 0}}.banner-dots[data-v-6ef54b13]{position:absolute;bottom:24px;left:0;right:0;display:flex;justify-content:center;gap:10px;z-index:3}.dot[data-v-6ef54b13]{width:10px;height:10px;border-radius:var(--radius-full);background:#ffffff73;cursor:pointer;transition:all var(--transition-smooth);border:2px solid transparent}.dot[data-v-6ef54b13]:hover{background:#ffffffb3}.dot.active[data-v-6ef54b13]{background:#fff;width:28px;border-radius:var(--radius-full);box-shadow:0 2px 8px #0003}.home-main[data-v-6ef54b13]{display:grid;gap:56px;padding:56px 24px;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.section[data-v-6ef54b13]{display:grid;gap:24px;width:100%;box-sizing:border-box}.section__header[data-v-6ef54b13]{display:flex;align-items:center;gap:14px;margin-bottom:8px}.section__header[data-v-6ef54b13]:before{content:"";width:4px;height:28px;background:var(--accent-gradient);border-radius:var(--radius-sm);flex-shrink:0}.section__header h3[data-v-6ef54b13]{margin:0;font-family:var(--font-heading);font-size:26px;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.section__header--center[data-v-6ef54b13]{justify-content:center}.section__header--center[data-v-6ef54b13]:before{display:none}.section__subtitle[data-v-6ef54b13]{margin:-16px 0 0;color:var(--color-text-muted);font-size:15px}.section__subtitle--center[data-v-6ef54b13]{text-align:center}.announcement-bar[data-v-6ef54b13]{background:var(--color-card);border-radius:var(--radius-xl);padding:24px 28px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);gap:16px}.announcement-bar-header[data-v-6ef54b13]{display:flex;align-items:center;justify-content:space-between}.announcement-bar-label[data-v-6ef54b13]{display:flex;align-items:center;gap:8px;font-weight:700;font-size:16px;color:var(--color-text)}.announcement-bar-label svg[data-v-6ef54b13]{color:var(--primary)}.announcement-view-all[data-v-6ef54b13]{color:var(--primary);font-size:14px;font-weight:600;text-decoration:none;transition:color var(--transition-fast)}.announcement-view-all[data-v-6ef54b13]:hover{color:var(--primary-dark);text-decoration:underline}.announcement-bar-list[data-v-6ef54b13]{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.announcement-bar-item[data-v-6ef54b13]{flex:0 0 auto;min-width:280px;max-width:360px;display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--color-bg);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);border:1px solid transparent}.announcement-bar-item[data-v-6ef54b13]:hover{background:var(--primary-bg);border-color:#2563eb26}.announcement-pin[data-v-6ef54b13]{flex-shrink:0;padding:2px 8px;background:var(--danger);color:#fff;font-size:11px;font-weight:700;border-radius:var(--radius-sm)}.announcement-bar-title[data-v-6ef54b13]{font-weight:600;font-size:14px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.announcement-bar-summary[data-v-6ef54b13]{display:none}.announcement-bar-time[data-v-6ef54b13]{flex-shrink:0;font-size:12px;color:var(--color-text-light)}.featured-grid[data-v-6ef54b13]{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.featured-card[data-v-6ef54b13]{background:var(--color-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:pointer;transition:transform var(--transition-smooth),box-shadow var(--transition-smooth)}.featured-card[data-v-6ef54b13]:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover)}.featured-card-image[data-v-6ef54b13]{position:relative;overflow:hidden}.featured-card-image img[data-v-6ef54b13]{width:100%;height:200px;object-fit:cover;transition:transform var(--transition-smooth)}.featured-card:hover .featured-card-image img[data-v-6ef54b13]{transform:scale(1.06)}.featured-card-overlay[data-v-6ef54b13]{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-smooth)}.featured-card:hover .featured-card-overlay[data-v-6ef54b13]{opacity:1}.featured-card-body[data-v-6ef54b13]{padding:20px}.featured-card-body h4[data-v-6ef54b13]{margin:0 0 8px;font-family:var(--font-heading);font-size:17px;font-weight:600;color:var(--color-text);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--transition-fast)}.featured-card:hover h4[data-v-6ef54b13]{color:var(--primary)}.featured-card-body p[data-v-6ef54b13]{margin:0;color:var(--color-text-muted);font-size:14px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tab-container[data-v-6ef54b13]{background:var(--color-card);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-sm);width:100%;box-sizing:border-box;overflow:hidden;border:1px solid var(--color-border)}.tab-header[data-v-6ef54b13]{display:flex;gap:4px;border-bottom:2px solid var(--color-border);margin-bottom:28px;padding-bottom:0}.tab-btn[data-v-6ef54b13]{padding:12px 28px;background:transparent;border:none;color:var(--color-text-muted);font-family:var(--font-body);font-size:15px;font-weight:600;cursor:pointer;transition:color var(--transition-base),background var(--transition-base);margin-bottom:-2px;position:relative;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab-btn[data-v-6ef54b13]:after{content:"";position:absolute;left:50%;bottom:0;width:0;height:3px;background:var(--primary-gradient);border-radius:3px 3px 0 0;transition:width var(--transition-smooth),left var(--transition-smooth)}.tab-btn[data-v-6ef54b13]:hover{color:var(--primary);background:#2563eb0a}.tab-btn.active[data-v-6ef54b13]{color:var(--primary);background:transparent}.tab-btn.active[data-v-6ef54b13]:after{width:100%;left:0}.tab-content[data-v-6ef54b13]{min-height:400px;width:100%}.tab-content .grid[data-v-6ef54b13]{animation:fadeIn-6ef54b13 .35s ease-out;width:100%}@keyframes fadeIn-6ef54b13{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.grid[data-v-6ef54b13]{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;width:100%;box-sizing:border-box}.card.course[data-v-6ef54b13]{background:var(--color-card);border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--transition-smooth),box-shadow var(--transition-smooth);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:pointer;display:flex;flex-direction:column}.card.course[data-v-6ef54b13]:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover)}.card-image-wrapper[data-v-6ef54b13]{position:relative;width:100%;overflow:hidden;background:var(--color-bg)}.card.course .cover[data-v-6ef54b13]{width:100%;height:200px;object-fit:cover;transition:transform var(--transition-smooth)}.card.course:hover .cover[data-v-6ef54b13]{transform:scale(1.06)}.card-overlay[data-v-6ef54b13]{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-smooth)}.card.course:hover .card-overlay[data-v-6ef54b13]{opacity:1}.view-btn[data-v-6ef54b13]{background:#fff;color:var(--color-text);padding:10px 24px;border-radius:var(--radius-md);font-family:var(--font-body);font-weight:600;font-size:14px;transform:translateY(10px);transition:transform var(--transition-smooth),box-shadow var(--transition-base);box-shadow:var(--shadow-md)}.card.course:hover .view-btn[data-v-6ef54b13],.featured-card:hover .view-btn[data-v-6ef54b13]{transform:translateY(0)}.card-content[data-v-6ef54b13]{padding:20px;display:flex;flex-direction:column;flex:1;gap:8px}.card.course h4[data-v-6ef54b13]{margin:0;font-family:var(--font-heading);font-size:17px;font-weight:600;color:var(--color-text);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--transition-fast)}.card.course:hover h4[data-v-6ef54b13]{color:var(--primary)}.muted[data-v-6ef54b13]{color:var(--color-text-muted);font-size:14px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.features-section[data-v-6ef54b13]{padding:40px 0 20px}.features-grid[data-v-6ef54b13]{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.feature-card[data-v-6ef54b13]{background:var(--color-card);border-radius:var(--radius-xl);padding:32px 24px;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:transform var(--transition-smooth),box-shadow var(--transition-smooth)}.feature-card[data-v-6ef54b13]:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}.feature-icon[data-v-6ef54b13]{width:64px;height:64px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:var(--primary-bg);color:var(--primary);transition:background var(--transition-base)}.feature-card:hover .feature-icon[data-v-6ef54b13]{background:#2563eb1f}.feature-card h4[data-v-6ef54b13]{margin:0 0 10px;font-family:var(--font-heading);font-size:17px;font-weight:700;color:var(--color-text)}.feature-card p[data-v-6ef54b13]{margin:0;font-size:14px;line-height:1.7;color:var(--color-text-muted)}@media (max-width: 1200px){.grid[data-v-6ef54b13],.featured-grid[data-v-6ef54b13],.features-grid[data-v-6ef54b13]{grid-template-columns:repeat(2,1fr)}.home-main[data-v-6ef54b13]{padding:40px 20px;gap:48px}}@media (max-width: 768px){.banner[data-v-6ef54b13]{height:280px}.banner-item[data-v-6ef54b13]:after{background:linear-gradient(to top,rgba(15,23,42,.5) 0%,transparent 60%)}.banner-image[data-v-6ef54b13]{height:280px}.home-main[data-v-6ef54b13]{padding:24px 16px;gap:36px}.grid[data-v-6ef54b13]{grid-template-columns:1fr;gap:20px}.featured-grid[data-v-6ef54b13],.features-grid[data-v-6ef54b13]{grid-template-columns:1fr}.section__header h3[data-v-6ef54b13]{font-size:20px}.section__header[data-v-6ef54b13]:before{height:22px}.card.course .cover[data-v-6ef54b13],.featured-card-image img[data-v-6ef54b13]{height:180px}.card-content[data-v-6ef54b13]{padding:16px}.card.course h4[data-v-6ef54b13]{font-size:16px}.tab-container[data-v-6ef54b13]{padding:16px;border-radius:var(--radius-lg)}.tab-header[data-v-6ef54b13]{gap:0}.tab-btn[data-v-6ef54b13]{padding:10px 16px;font-size:14px}.stat-card[data-v-6ef54b13]{padding:24px 16px}.stat-number[data-v-6ef54b13]{font-size:32px}.announcement-bar[data-v-6ef54b13]{padding:16px}.announcement-bar-list[data-v-6ef54b13]{gap:8px}.announcement-bar-item[data-v-6ef54b13]{min-width:240px;padding:10px 12px}}.page[data-v-418de07e]{min-height:calc(100vh - 200px);background:var(--color-bg);padding:32px 16px}.page-content[data-v-418de07e]{max-width:1400px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:24px}.search-section[data-v-418de07e]{padding:20px 24px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.search-box[data-v-418de07e]{display:flex;gap:12px;align-items:center}.search-input[data-v-418de07e]{flex:1;height:48px;padding:0 18px;border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:15px;font-family:var(--font-body);color:var(--color-text);background:var(--color-card);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.search-input[data-v-418de07e]::placeholder{color:var(--color-text-light)}.search-input[data-v-418de07e]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1f}.btn[data-v-418de07e]{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 20px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base)}.btn[data-v-418de07e]:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn[data-v-418de07e]:active:not(:disabled){transform:translateY(0)}.btn[data-v-418de07e]:disabled{opacity:.5;cursor:not-allowed}.btn--primary[data-v-418de07e]{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.btn--primary[data-v-418de07e]:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 6px 20px #2563eb4d}.search-btn[data-v-418de07e]{height:48px;border-radius:var(--radius-lg);padding:0 24px}.search-icon[data-v-418de07e]{width:18px;height:18px}.empty-state[data-v-418de07e],.error-state[data-v-418de07e]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 24px;text-align:center;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);grid-column:1 / -1;color:var(--color-text-muted)}.empty-icon[data-v-418de07e]{width:64px;height:64px;color:var(--color-text-light);margin-bottom:16px}.error-message[data-v-418de07e]{padding:14px 20px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:#b91c1c;font-size:14px}.skeleton-grid[data-v-418de07e]{width:100%}.skeleton-card[data-v-418de07e]{pointer-events:none}.skeleton-block[data-v-418de07e]{height:200px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:skeleton-shimmer-418de07e 1.8s ease-in-out infinite}.skeleton-line[data-v-418de07e]{height:12px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:skeleton-shimmer-418de07e 1.8s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-line.title[data-v-418de07e]{height:18px;width:80%}.skeleton-line.subtitle[data-v-418de07e]{width:95%}.skeleton-line.subtitle.short[data-v-418de07e]{width:70%}.skeleton-line.small[data-v-418de07e]{width:45%;height:10px}.skeleton-line.tiny[data-v-418de07e]{width:60px;height:10px}.skeleton-stats[data-v-418de07e]{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.skeleton-meta[data-v-418de07e]{padding-top:12px;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.skeleton-pill[data-v-418de07e]{width:90px;height:22px;border-radius:var(--radius-full);background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:skeleton-shimmer-418de07e 1.8s ease-in-out infinite}@keyframes skeleton-shimmer-418de07e{0%{background-position:200% 0}to{background-position:-200% 0}}.grid[data-v-418de07e]{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%}.card.course[data-v-418de07e]{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--transition-smooth),box-shadow var(--transition-smooth),border-color var(--transition-smooth);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column}.card.course[data-v-418de07e]:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover);border-color:var(--primary-light)}.card-image-wrapper[data-v-418de07e]{position:relative;width:100%;overflow:hidden;background:var(--color-border)}.card.course .cover[data-v-418de07e]{width:100%;height:200px;object-fit:cover;transition:transform var(--transition-smooth)}.card.course:hover .cover[data-v-418de07e]{transform:scale(1.06)}.card-overlay[data-v-418de07e]{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f172a1a,#0f172a80);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-smooth)}.card.course:hover .card-overlay[data-v-418de07e]{opacity:1}.view-btn[data-v-418de07e]{background:var(--color-card);border-color:var(--color-border);color:var(--color-text);padding:10px 20px;border-radius:var(--radius-md);font-weight:600;transform:translateY(8px);transition:transform var(--transition-smooth),box-shadow var(--transition-smooth);box-shadow:var(--shadow-md)}.card.course:hover .view-btn[data-v-418de07e]{transform:translateY(0)}.card-content[data-v-418de07e]{padding:20px;display:flex;flex-direction:column;flex:1;gap:8px}.card.course h4[data-v-418de07e]{margin:0;font-size:18px;font-weight:700;font-family:var(--font-heading);color:var(--color-text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--transition-base)}.card.course:hover h4[data-v-418de07e]{color:var(--primary)}.subtitle[data-v-418de07e]{color:var(--color-text-muted);font-size:14px;line-height:1.5;margin:0}.description[data-v-418de07e]{color:var(--color-text-muted);font-size:13px;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.stats[data-v-418de07e]{display:flex;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.stat-item[data-v-418de07e]{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-muted)}.stat-icon[data-v-418de07e]{width:16px;height:16px;color:var(--color-text-light);flex-shrink:0}.stat-label[data-v-418de07e]{color:var(--color-text-muted)}.stat-value[data-v-418de07e]{color:var(--color-text);font-weight:700}.meta[data-v-418de07e]{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:12px;border-top:1px solid var(--color-border);font-size:12px}.status[data-v-418de07e]{padding:4px 12px;border-radius:var(--radius-full);font-weight:600;font-size:12px;transition:opacity var(--transition-base)}.status-updating[data-v-418de07e]{background:var(--color-warning-bg);color:#92400e}.status-completed[data-v-418de07e]{background:var(--color-success-bg);color:#065f46}.status-normal[data-v-418de07e]{background:var(--color-bg);color:var(--color-text-muted)}.date[data-v-418de07e]{color:var(--color-text-muted);font-size:12px;display:flex;align-items:center;gap:4px}.date-icon[data-v-418de07e]{width:14px;height:14px}.pagination[data-v-418de07e]{display:flex;align-items:center;justify-content:center;gap:12px;margin:32px 0 8px;padding-top:24px}.pagination-btn[data-v-418de07e]{height:38px;padding:0 18px;border:1px solid var(--color-border);background:var(--color-card);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all var(--transition-base);font-size:14px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.pagination-btn[data-v-418de07e]:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary-light);color:var(--primary)}.pagination-btn[data-v-418de07e]:disabled{opacity:.4;cursor:not-allowed}.pagination-icon[data-v-418de07e]{width:18px;height:18px}.pagination-info[data-v-418de07e]{color:var(--color-text-muted);font-size:14px;font-weight:500;line-height:1.4;min-height:38px;display:flex;align-items:center}@media (max-width: 1024px){.page-content[data-v-418de07e]{padding:0 4px}.grid[data-v-418de07e]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.page[data-v-418de07e]{padding:16px 12px}.page-header[data-v-418de07e]{padding:16px}.page-header h2[data-v-418de07e]{font-size:20px}.search-section[data-v-418de07e]{padding:16px}.search-input[data-v-418de07e],.search-btn[data-v-418de07e]{height:44px}.search-box[data-v-418de07e]{flex-direction:column;align-items:stretch}.search-btn[data-v-418de07e]{width:100%}.grid[data-v-418de07e]{grid-template-columns:1fr;gap:14px}.card.course .cover[data-v-418de07e]{height:180px}.card-content[data-v-418de07e]{padding:16px}.pagination[data-v-418de07e]{flex-direction:column;gap:10px}}.page[data-v-e9ef328c]{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 200px);padding:48px 24px;background:var(--color-bg)}.card[data-v-e9ef328c]{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:center;padding:60px 48px;max-width:520px;width:100%}.card__header h3[data-v-e9ef328c]{margin:0 0 16px;font-size:28px;font-weight:700;font-family:var(--font-heading);background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card__body p[data-v-e9ef328c]{margin:0;color:var(--color-text-muted);font-size:16px;line-height:1.6}.card__body[data-v-e9ef328c]:before{content:"";display:block;width:64px;height:64px;margin:0 auto 24px;border-radius:var(--radius-lg);background:var(--accent-gradient);opacity:.15}.user-center[data-v-591c22e6]{max-width:960px;margin:32px auto;padding:0 20px}.profile-grid[data-v-591c22e6]{display:grid;grid-template-columns:180px 1fr;gap:32px;align-items:flex-start}.avatar-box[data-v-591c22e6]{display:grid;gap:12px;justify-items:center;cursor:pointer;position:relative}.avatar-box img[data-v-591c22e6]{width:128px;height:128px;border-radius:var(--radius-full);object-fit:cover;border:3px solid var(--primary-light);box-shadow:0 0 0 4px var(--primary-bg),var(--shadow-md);transition:transform var(--transition-smooth),box-shadow var(--transition-smooth)}.avatar-box:hover img[data-v-591c22e6]{transform:scale(1.04);box-shadow:0 0 0 4px var(--primary-bg),var(--shadow-lg)}.avatar-tip[data-v-591c22e6]{font-size:12px;color:var(--color-text-muted);transition:color var(--transition-base)}.avatar-box:hover .avatar-tip[data-v-591c22e6]{color:var(--primary)}.profile-form[data-v-591c22e6]{display:grid;gap:16px}.grid2[data-v-591c22e6]{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:20px;align-items:start}.grid2 .full[data-v-591c22e6]{grid-column:1 / -1}.profile-form label[data-v-591c22e6]{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--color-text-muted)}.profile-form input[data-v-591c22e6]{width:100%;height:42px;padding:0 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);font-family:var(--font-body);font-size:14px;box-sizing:border-box;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.profile-form input[data-v-591c22e6]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.actions[data-v-591c22e6]{margin-top:12px;display:flex;gap:12px}.user-alert[data-v-591c22e6]{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;padding:12px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500}.hidden[data-v-591c22e6]{display:none}.modal[data-v-591c22e6]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100}.modal__dialog[data-v-591c22e6]{width:440px;max-width:90vw;background:var(--color-card);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-xl)}.modal__header[data-v-591c22e6]{padding:20px 24px;border-bottom:1px solid var(--color-border)}.modal__header h4[data-v-591c22e6]{margin:0;font-family:var(--font-heading);color:var(--color-text)}.modal__body[data-v-591c22e6]{padding:24px}.modal__footer[data-v-591c22e6]{padding:16px 24px;display:flex;justify-content:flex-end;gap:12px;border-top:1px solid var(--color-border)}.form-vertical[data-v-591c22e6]{display:grid;gap:16px}.form-vertical label[data-v-591c22e6]{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--color-text-muted)}.form-vertical input[data-v-591c22e6]{width:100%;height:42px;padding:0 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);font-family:var(--font-body);font-size:14px;box-sizing:border-box;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.form-vertical input[data-v-591c22e6]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}@media (max-width: 640px){.profile-grid[data-v-591c22e6]{grid-template-columns:1fr;justify-items:center}.profile-form[data-v-591c22e6]{width:100%}.grid2[data-v-591c22e6]{grid-template-columns:1fr}.actions[data-v-591c22e6]{justify-content:center}}.page[data-v-c5ec7b60]{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:var(--color-bg)}.card[data-v-c5ec7b60]{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:center;padding:48px 40px;max-width:420px;width:100%}.card__header h3[data-v-c5ec7b60]{margin:0 0 8px;font-size:20px;font-weight:700;font-family:var(--font-heading);color:var(--color-text)}.card__body[data-v-c5ec7b60]{color:var(--color-text-muted);font-size:15px}.card__body p[data-v-c5ec7b60]{margin:0}.card__body[data-v-c5ec7b60]:before{content:"";display:block;width:44px;height:44px;margin:0 auto 20px;border-radius:50%;border:3px solid var(--color-border);border-top-color:var(--primary);animation:spin-c5ec7b60 .8s linear infinite}@keyframes spin-c5ec7b60{to{transform:rotate(360deg)}}.error-text[data-v-c5ec7b60]{color:var(--danger);font-size:14px}.certificate-query[data-v-11422f99]{min-height:calc(100vh - 200px);padding:24px;background:var(--color-bg)}.query-container[data-v-11422f99]{max-width:800px;margin:0 auto;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-lg)}h2[data-v-11422f99]{margin:0 0 8px;font-size:26px;color:var(--color-text);font-family:var(--font-heading);font-weight:700}.description[data-v-11422f99]{margin:0 0 28px;color:var(--color-text-muted);font-size:15px;line-height:1.5}.query-form[data-v-11422f99]{margin-bottom:24px}.query-tabs[data-v-11422f99]{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:24px;padding-bottom:0}.tab-btn[data-v-11422f99]{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-muted);font-size:15px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);margin-bottom:-2px;position:relative;flex:1;text-align:center}.tab-btn[data-v-11422f99]:hover{color:var(--primary);background:#2563eb0a}.tab-btn.active[data-v-11422f99]{color:var(--primary);border-bottom-color:var(--primary);background:transparent;font-weight:700}.form-group[data-v-11422f99]{margin-bottom:22px}.form-group label[data-v-11422f99]{display:block;margin-bottom:8px;font-weight:600;color:var(--color-text);font-size:14px}.required[data-v-11422f99]{color:var(--danger);font-size:12px}.input[data-v-11422f99]{width:100%;padding:11px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-body);color:var(--color-text);background:var(--color-card);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.input[data-v-11422f99]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.slider-captcha-wrapper[data-v-11422f99]{display:flex;flex-direction:column;align-items:center;gap:12px}.captcha-error[data-v-11422f99]{color:var(--danger);font-size:13px;padding:8px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm)}.captcha-section[data-v-11422f99]{margin-top:24px;padding-top:20px;border-top:1px dashed var(--color-border)}.form-actions[data-v-11422f99]{display:flex;gap:12px;margin-top:28px}.btn[data-v-11422f99]{padding:0 20px;height:42px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center}.btn[data-v-11422f99]:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary-light);color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn[data-v-11422f99]:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--primary[data-v-11422f99]{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.btn--primary[data-v-11422f99]:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);color:#fff;box-shadow:0 6px 20px #2563eb4d}.btn--small[data-v-11422f99]{padding:0 14px;height:34px;font-size:13px;border-radius:var(--radius-sm)}.error-message[data-v-11422f99]{padding:14px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--danger);font-size:14px;margin-bottom:24px}.results[data-v-11422f99]{margin-top:36px}.results h3[data-v-11422f99]{margin:0 0 20px;font-size:18px;font-weight:700;color:var(--color-text);font-family:var(--font-heading)}.certificate-list[data-v-11422f99]{display:flex;flex-direction:column;gap:16px}.certificate-card[data-v-11422f99]{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;background:var(--color-card);transition:all var(--transition-smooth)}.certificate-card[data-v-11422f99]:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.certificate-header[data-v-11422f99]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--color-border)}.certificate-header h4[data-v-11422f99]{margin:0;font-size:18px;font-weight:700;color:var(--color-text);font-family:var(--font-heading)}.status[data-v-11422f99]{padding:4px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:700;letter-spacing:.3px}.status--valid[data-v-11422f99]{background:var(--color-success-bg);color:#065f46}.status--expired[data-v-11422f99]{background:#fee2e2;color:#991b1b}.status--revoked[data-v-11422f99]{background:var(--color-bg);color:var(--color-text-muted)}.certificate-info[data-v-11422f99]{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}.info-row[data-v-11422f99]{display:flex;font-size:14px;line-height:1.5}.info-row .label[data-v-11422f99]{color:var(--color-text-muted);min-width:110px;flex-shrink:0}.info-row .value[data-v-11422f99]{color:var(--color-text);font-weight:500}.certificate-actions[data-v-11422f99]{display:flex;gap:12px;padding-top:18px;border-top:1px solid var(--color-border)}.empty-result[data-v-11422f99]{text-align:center;padding:48px 24px;color:var(--color-text-muted);font-size:15px}@media (max-width: 768px){.certificate-query[data-v-11422f99]{padding:16px}.query-container[data-v-11422f99]{padding:24px}.certificate-header[data-v-11422f99]{flex-direction:column;align-items:flex-start;gap:10px}}.page[data-v-5d26e430]{padding:24px;background:var(--color-bg);min-height:calc(100vh - 180px)}.card[data-v-5d26e430]{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card__body[data-v-5d26e430]{padding:20px}.loading-state[data-v-5d26e430],.empty-state[data-v-5d26e430]{padding:48px 32px;text-align:center;color:var(--color-text-muted)}.loading-spinner[data-v-5d26e430]{width:36px;height:36px;border-radius:50%;border:3px solid var(--color-border);border-top-color:var(--primary);margin:0 auto 16px;animation:spin-5d26e430 .8s linear infinite}@keyframes spin-5d26e430{to{transform:rotate(360deg)}}.user-alert[data-v-5d26e430]{padding:12px 16px;border-radius:var(--radius-sm);background:#fef2f2;color:var(--danger);border:1px solid #fecaca;margin-bottom:16px;font-size:14px}.announcement-list[data-v-5d26e430]{display:flex;flex-direction:column;gap:12px}.announcement-card[data-v-5d26e430]{padding:18px 20px;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-smooth);background:var(--color-card);position:relative}.announcement-card--top[data-v-5d26e430]{border-color:var(--color-warning);background:var(--color-warning-bg);box-shadow:inset 0 0 0 1px #f59e0b1a}.announcement-card[data-v-5d26e430]:hover{border-color:var(--primary-light);transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.announcement-card--top[data-v-5d26e430]:hover{border-color:var(--color-warning);box-shadow:var(--shadow-card-hover)}.announcement-card__header[data-v-5d26e430]{display:flex;align-items:center;justify-content:space-between;gap:16px}.announcement-card__title[data-v-5d26e430]{margin:0;font-size:16px;font-weight:600;color:var(--color-text);font-family:var(--font-heading);display:flex;align-items:center;gap:10px;flex:1}.announcement-card__date[data-v-5d26e430]{color:var(--color-text-light);font-size:13px;flex-shrink:0;background:var(--color-bg);padding:4px 12px;border-radius:var(--radius-full);font-weight:500}.top-flag[data-v-5d26e430]{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;color:#92400e;background:#fef3c7;border:1px solid rgba(252,211,77,.6);letter-spacing:.3px}.announcement-card__meta[data-v-5d26e430]{display:flex;gap:12px;color:var(--color-text-light);font-size:13px;margin-top:8px}.tag[data-v-5d26e430]{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;color:var(--color-text-muted);background:var(--color-bg)}.tag--warning[data-v-5d26e430]{background:var(--color-warning-bg);color:#92400e}.pagination[data-v-5d26e430]{margin-top:24px;padding-top:20px;border-top:1px solid var(--color-border);display:flex;justify-content:center;align-items:center;gap:12px}.pagination__info[data-v-5d26e430]{color:var(--color-text-muted);font-size:14px;font-weight:500}.btn[data-v-5d26e430]{border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);border-radius:var(--radius-md);padding:8px 16px;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-body);transition:all var(--transition-base)}.btn[data-v-5d26e430]:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary-light);color:var(--primary)}.btn--ghost[data-v-5d26e430]{background:var(--color-card)}.btn[data-v-5d26e430]:disabled{opacity:.4;cursor:not-allowed}.exam-center-page[data-v-1d61ab01]{max-width:1400px;margin:0 auto;padding:32px 24px;min-height:calc(100vh - 180px)}.page-header[data-v-1d61ab01]{position:relative;padding-left:16px;margin-bottom:32px}.page-header[data-v-1d61ab01]:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:2px;background:var(--primary-gradient)}.page-header h1[data-v-1d61ab01]{margin:0 0 8px;font-size:32px;font-weight:700;font-family:var(--font-heading);color:var(--color-text)}.page-header p[data-v-1d61ab01]{margin:4px 0 0;color:var(--color-text-muted);font-size:15px}.tab-container[data-v-1d61ab01]{background:var(--color-card);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden}.tab-header[data-v-1d61ab01]{display:flex;gap:4px;border-bottom:2px solid var(--color-border);padding:0 24px}.tab-btn[data-v-1d61ab01]{padding:16px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-muted);font-size:15px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);margin-bottom:-2px;position:relative}.tab-btn[data-v-1d61ab01]:after{content:"";position:absolute;bottom:-2px;left:50%;width:0;height:3px;background:var(--primary);border-radius:2px;transition:all var(--transition-smooth);transform:translate(-50%)}.tab-btn[data-v-1d61ab01]:hover{color:var(--primary);background:#2563eb0a}.tab-btn[data-v-1d61ab01]:hover:after{width:50%}.tab-btn.active[data-v-1d61ab01]{color:var(--primary);border-bottom-color:transparent}.tab-btn.active[data-v-1d61ab01]:after{width:100%}.tab-content[data-v-1d61ab01]{padding:24px;min-height:400px}.loading-state[data-v-1d61ab01]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-text-muted)}.loading-spinner[data-v-1d61ab01]{width:40px;height:40px;border:4px solid var(--color-border);border-top:4px solid var(--primary);border-radius:50%;animation:spin-1d61ab01 1s linear infinite;margin-bottom:16px}@keyframes spin-1d61ab01{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-state[data-v-1d61ab01]{display:flex;align-items:center;justify-content:center;min-height:400px}.error-message[data-v-1d61ab01]{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:40px;max-width:600px;width:100%;text-align:center;color:var(--color-text);box-shadow:var(--shadow-md)}.error-icon[data-v-1d61ab01]{width:64px;height:64px;margin:0 auto 20px}.error-message h3[data-v-1d61ab01]{margin:0 0 12px;font-size:20px;font-weight:600;font-family:var(--font-heading);color:var(--color-text)}.error-message p[data-v-1d61ab01]{margin:0 0 24px;color:var(--color-text-muted);font-size:15px;line-height:1.5}.error-message .btn[data-v-1d61ab01]{padding:10px 24px}.empty-state[data-v-1d61ab01]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:var(--color-text-muted)}.empty-icon[data-v-1d61ab01]{width:64px;height:64px;margin-bottom:16px;color:var(--color-text-light)}.empty-state h3[data-v-1d61ab01]{margin:0 0 8px;font-size:20px;font-weight:600;font-family:var(--font-heading);color:var(--color-text)}.empty-state p[data-v-1d61ab01]{margin:0;font-size:14px}.exam-grid[data-v-1d61ab01]{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}.exam-card[data-v-1d61ab01]{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-smooth);display:flex;flex-direction:column;height:100%;box-shadow:var(--shadow-sm)}.exam-card[data-v-1d61ab01]:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:var(--primary-light)}.exam-card-header[data-v-1d61ab01]{padding:12px 16px;background:var(--primary-bg);border-bottom:1px solid rgba(37,99,235,.1)}.exam-badge[data-v-1d61ab01]{display:inline-flex;align-items:center;padding:4px 12px;background:var(--primary-gradient);color:#fff;border-radius:var(--radius-full);font-size:12px;font-weight:600;letter-spacing:.02em}.exam-badge--standalone[data-v-1d61ab01]{background:var(--accent-gradient)}.exam-card-content[data-v-1d61ab01]{padding:20px;display:flex;flex-direction:column;gap:16px;flex:1}.exam-title[data-v-1d61ab01]{margin:0;font-size:18px;font-weight:600;font-family:var(--font-heading);color:var(--color-text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.exam-description[data-v-1d61ab01]{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.exam-meta[data-v-1d61ab01]{display:flex;flex-wrap:wrap;gap:16px}.meta-item[data-v-1d61ab01]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-muted)}.meta-icon[data-v-1d61ab01]{width:16px;height:16px;color:var(--color-text-light);flex-shrink:0}.exam-time[data-v-1d61ab01]{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--color-text-muted)}.exam-card-footer[data-v-1d61ab01]{padding:16px;border-top:1px solid var(--color-border)}.history-list[data-v-1d61ab01]{display:flex;flex-direction:column;gap:16px}.history-item[data-v-1d61ab01]{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition-smooth);box-shadow:var(--shadow-xs)}.history-item[data-v-1d61ab01]:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.history-header[data-v-1d61ab01]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.history-info[data-v-1d61ab01]{flex:1}.history-title[data-v-1d61ab01]{margin:0 0 4px;font-size:18px;font-weight:600;font-family:var(--font-heading);color:var(--color-text)}.history-course[data-v-1d61ab01]{margin:0;font-size:14px;color:var(--color-text-muted)}.history-score[data-v-1d61ab01]{display:flex;align-items:baseline;gap:4px;padding:10px 18px;border-radius:var(--radius-md);background:var(--color-bg)}.history-score.pass[data-v-1d61ab01]{background:var(--color-success-bg)}.history-score.fail[data-v-1d61ab01]{background:#fee2e2}.score-value[data-v-1d61ab01]{font-size:28px;font-weight:700;font-family:var(--font-heading)}.history-score.pass .score-value[data-v-1d61ab01]{color:var(--color-success)}.history-score.fail .score-value[data-v-1d61ab01]{color:var(--danger)}.score-label[data-v-1d61ab01]{font-size:14px;font-weight:500;color:var(--color-text-muted)}.history-meta[data-v-1d61ab01]{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.meta-row[data-v-1d61ab01]{display:flex;flex-direction:column;gap:4px}.meta-label[data-v-1d61ab01]{font-size:12px;color:var(--color-text-light);font-weight:500}.meta-value[data-v-1d61ab01]{font-size:14px;color:var(--color-text);font-weight:600}.result-badge[data-v-1d61ab01]{display:inline-block;padding:3px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:600}.result-badge.pass[data-v-1d61ab01]{background:var(--color-success-bg);color:var(--color-success)}.result-badge.fail[data-v-1d61ab01]{background:#fee2e2;color:var(--danger)}.history-actions[data-v-1d61ab01]{display:flex;gap:12px}.btn[data-v-1d61ab01]{height:40px;padding:0 20px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;font-size:14px;font-weight:600;font-family:var(--font-body);transition:all var(--transition-base);gap:6px}.btn[data-v-1d61ab01]:hover{background:var(--color-bg);border-color:var(--color-text-light);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn--primary[data-v-1d61ab01]{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.btn--primary[data-v-1d61ab01]:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 6px 20px #2563eb4d}.btn-full[data-v-1d61ab01]{width:100%}.btn-sm[data-v-1d61ab01]{height:32px;padding:0 16px;font-size:13px;border-radius:var(--radius-sm)}@media (max-width: 1200px){.exam-grid[data-v-1d61ab01]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.exam-center-page[data-v-1d61ab01]{padding:24px 16px}.page-header h1[data-v-1d61ab01]{font-size:24px}.tab-header[data-v-1d61ab01]{padding:0 16px}.tab-btn[data-v-1d61ab01]{padding:12px 16px;font-size:14px}.tab-content[data-v-1d61ab01]{padding:16px}.exam-grid[data-v-1d61ab01]{grid-template-columns:1fr}.history-meta[data-v-1d61ab01]{grid-template-columns:1fr;gap:12px}.history-header[data-v-1d61ab01]{flex-direction:column;gap:12px}}:root{--color-bg: #f0f2f5;--color-card: #ffffff;--color-border: #e2e8f0;--color-text: #0f172a;--color-text-muted: #64748b;--color-text-light: #94a3b8;--primary: #2563eb;--primary-light: #3b82f6;--primary-dark: #1d4ed8;--primary-bg: #eff6ff;--danger: #ef4444;--color-success: #10b981;--color-success-bg: #ecfdf5;--color-warning: #f59e0b;--color-warning-bg: #fffbeb;--color-info: #6366f1;--color-info-bg: #eef2ff;--primary-gradient: linear-gradient(135deg, #2563eb 0%, #6366f1 100%);--header-gradient: linear-gradient(135deg, #1e40af 0%, #4f46e5 100%);--accent-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 6px -1px rgba(15, 23, 42, .08), 0 2px 4px -1px rgba(15, 23, 42, .04);--shadow-lg: 0 10px 25px -3px rgba(15, 23, 42, .08), 0 4px 6px -2px rgba(15, 23, 42, .04);--shadow-xl: 0 20px 40px -5px rgba(15, 23, 42, .1), 0 8px 16px -4px rgba(15, 23, 42, .06);--shadow-card-hover: 0 12px 28px -4px rgba(15, 23, 42, .12), 0 4px 8px -2px rgba(15, 23, 42, .06);--shadow-primary: 0 4px 14px rgba(37, 99, 235, .25);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--font-heading: "Poppins", ui-sans-serif, system-ui, -apple-system, sans-serif;--font-body: "Open Sans", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1)}html,body,#app{height:100%}html{overflow-y:scroll}body{margin:0;font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading)}.card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-smooth),transform var(--transition-smooth)}.card:hover{box-shadow:var(--shadow-md)}.card__header,.card__body{padding:20px}.btn{height:40px;padding:0 18px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:#fff;color:var(--color-text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:14px;font-weight:600;font-family:var(--font-body);transition:all var(--transition-base);gap:6px}.btn:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn--primary{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:var(--shadow-primary)}.btn--primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 6px 20px #2563eb4d}.btn--danger{border-color:var(--danger);background:var(--danger);color:#fff}.btn--sm{height:32px;padding:0 12px;border-radius:var(--radius-sm);font-size:13px}.form-grid{display:grid;grid-template-columns:1fr;gap:14px}.form-row{display:grid;gap:6px}label{font-size:13px;color:var(--color-text-muted);font-weight:500}input,select,textarea{height:42px;padding:0 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;color:var(--color-text);font-family:var(--font-body);font-size:14px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}textarea{height:auto;padding:12px 14px;resize:vertical}.error-text{color:#dc2626;font-size:13px}.spacer{height:1px;background-color:var(--color-border)}.link{color:var(--primary);font-weight:600;text-decoration:none;transition:color var(--transition-fast)}.link:hover{color:var(--primary-dark);text-decoration:underline}.page{display:flex;flex-direction:column;gap:16px;padding:24px}.login-container{display:grid;place-items:center;min-height:100vh;padding:24px;background:var(--color-bg)}.login-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:440px;display:grid;gap:20px;box-shadow:var(--shadow-xl)}.page-header{position:relative;padding-left:16px;margin-bottom:24px}.page-header:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:2px;background:var(--primary-gradient)}.page-header h1,.page-header h2,.page-header h3{margin:0;font-family:var(--font-heading);font-weight:700;color:var(--color-text)}.page-header p{margin:4px 0 0;color:var(--color-text-muted);font-size:15px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;color:var(--color-text-muted)}.empty-state svg{width:64px;height:64px;color:var(--color-text-light);margin-bottom:16px}.empty-state h3{margin:0 0 8px;font-size:18px;color:var(--color-text)}.empty-state p{margin:0;font-size:14px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.8s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-text.lg{height:20px;width:60%}.skeleton-text.sm{height:12px;width:40%}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-card{height:200px}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:32px;padding-top:24px}.pagination .page-btn,.pagination .pagination-btn{height:38px;padding:0 18px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:6px}.pagination .page-btn:hover:not(:disabled),.pagination .pagination-btn:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary-light);color:var(--primary)}.pagination .page-btn:disabled,.pagination .pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination .page-info,.pagination .pagination-info{color:var(--color-text-muted);font-size:14px;font-weight:500}.modern-tabs{display:flex;gap:4px;border-bottom:2px solid var(--color-border);padding-bottom:0}.modern-tabs .tab-btn{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-muted);font-size:15px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);margin-bottom:-2px;position:relative}.modern-tabs .tab-btn:hover{color:var(--primary);background:#2563eb0a}.modern-tabs .tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}input[type=radio],input[type=checkbox]{vertical-align:middle;margin:0;height:auto}
