@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+TC:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0";.login-container[data-v-a8d378ca]{display:flex;justify-content:center;align-items:flex-start;min-height:100vh;min-height:100dvh;padding:40px 16px;background-color:#f5f5f5;background-image:linear-gradient(135deg,#fff8e1,#ffe0b2);box-sizing:border-box}.login-card[data-v-a8d378ca]{background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:560px;text-align:center}h2[data-v-a8d378ca]{color:#e65100;margin-bottom:8px}.subtitle[data-v-a8d378ca]{color:#666;margin-bottom:24px;font-size:.9em}.form-group[data-v-a8d378ca]{margin-bottom:16px;text-align:left}.form-group label[data-v-a8d378ca]{display:block;margin-bottom:6px;font-weight:700;color:#333}.field-hint[data-v-a8d378ca]{margin:0 0 8px;font-size:.85rem;color:#666;font-weight:400;line-height:1.4}.form-group input[data-v-a8d378ca],.form-group select[data-v-a8d378ca]{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:1em}.chip-wrap[data-v-a8d378ca]{display:flex;flex-wrap:wrap;gap:8px}.chip[data-v-a8d378ca]{display:inline-flex;align-items:center;gap:6px;border:1px solid #ddd;border-radius:999px;padding:6px 10px;background:#fafafa;font-size:.9rem}.chip.selected[data-v-a8d378ca]{border-color:#e65100;background:#fff3e0}.chip.disabled[data-v-a8d378ca]{opacity:.6}.scope-table[data-v-a8d378ca]{width:100%;border-collapse:collapse}.scope-table th[data-v-a8d378ca],.scope-table td[data-v-a8d378ca]{border:1px solid #eee;padding:8px;text-align:center}.scope-table th[data-v-a8d378ca]:first-child,.scope-table td[data-v-a8d378ca]:first-child{text-align:left}.error-msg[data-v-a8d378ca]{background:#ffebee;color:#c62828;padding:10px;border-radius:6px;margin-bottom:16px}.success-msg[data-v-a8d378ca]{background:#e8f5e9;color:#2e7d32;padding:16px;border-radius:6px;margin-bottom:16px}.full-width[data-v-a8d378ca]{width:100%;padding:12px;font-size:1.1em;margin-top:8px}.footer-links[data-v-a8d378ca]{margin-top:16px;font-size:.9em}.footer-links a[data-v-a8d378ca]{color:#666;text-decoration:none}.login-container[data-v-516cac04]{display:flex;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;background-color:#f5f5f5;background-image:linear-gradient(135deg,#fff8e1,#ffe0b2)}.login-card[data-v-516cac04]{background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:400px}h2[data-v-516cac04]{color:#e65100;margin-bottom:8px}.subtitle[data-v-516cac04]{color:#666;margin-bottom:24px;font-size:.9em}.form-group[data-v-516cac04]{margin-bottom:16px;text-align:left}.form-group label[data-v-516cac04]{display:block;margin-bottom:6px;font-weight:700;color:#333}.form-group input[data-v-516cac04],.form-group select[data-v-516cac04]{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:16px}.form-group select[data-v-516cac04]{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:32px}.error-msg[data-v-516cac04]{background:#ffebee;color:#c62828;padding:10px;border-radius:6px;margin-bottom:16px;font-size:.9em}.success-msg[data-v-516cac04]{background:#e8f5e9;color:#2e7d32;padding:16px;border-radius:6px;margin-bottom:16px}.success-msg a[data-v-516cac04]{color:#2e7d32;font-weight:600}.full-width[data-v-516cac04]{width:100%;padding:12px;font-size:1.1em;margin-top:8px}.footer-links[data-v-516cac04]{margin-top:16px;font-size:.9em}.footer-links a[data-v-516cac04]{color:#666;text-decoration:none}.login-wrap[data-v-85659b05]{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:32px 24px;background:linear-gradient(-45deg,#ffd54f,#ffb300,#f57c00,#ef6c00);background-size:400% 400%;animation:gradientBG-85659b05 15s ease infinite}@media (pointer: coarse){.login-wrap[data-v-85659b05]{animation:none;background-size:100% 100%}}@keyframes gradientBG-85659b05{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.login-card[data-v-85659b05]{background:#fffffff2;border:1px solid rgba(255,255,255,.4);border-radius:20px;box-shadow:0 12px 40px #00000040,0 0 0 1px #fff3 inset;width:100%;max-width:420px;overflow:hidden;animation:floatUp-85659b05 .6s cubic-bezier(.16,1,.3,1)}@media (min-width: 641px){.login-card[data-v-85659b05]{background:#ffffffe6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}}@keyframes floatUp-85659b05{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.login-header[data-v-85659b05]{padding:36px 32px 24px;text-align:center;background:transparent;display:flex;flex-direction:column;align-items:center}.logo-wrapper[data-v-85659b05]{width:140px;height:140px;margin-bottom:20px;border-radius:50%;background:#fff;padding:0;box-shadow:0 6px 16px #f57c0040;display:flex;align-items:center;justify-content:center;overflow:hidden}.login-logo[data-v-85659b05]{width:100%;height:100%;object-fit:cover;transform:scale(1.15)}.login-title[data-v-85659b05]{font-size:1.5rem;font-weight:800;color:#37474f;margin:0 0 6px;letter-spacing:.03em}.login-subtitle[data-v-85659b05]{font-size:.85rem;font-weight:500;color:#78909c;margin:0;letter-spacing:.01em}.login-error[data-v-85659b05]{margin:0 24px;padding:12px 16px;background:#ffebeee6;color:#d32f2f;border-radius:12px;border-left:4px solid #d32f2f;font-size:.875rem;line-height:1.4;font-weight:500}.login-error-hint[data-v-85659b05]{display:block;margin-top:8px}.login-error-hint a[data-v-85659b05]{color:#b71c1c;text-decoration:underline;font-weight:600}.login-first-time[data-v-85659b05]{margin:16px 24px 0;padding:12px 16px;background:#fff3e0e6;border-radius:12px;border-left:4px solid #ff9800;font-size:.8125rem;text-align:center;font-weight:600}.login-first-time a[data-v-85659b05]{color:#e65100;text-decoration:none}.login-first-time a[data-v-85659b05]:hover{text-decoration:underline}.login-form[data-v-85659b05]{padding:24px 28px 32px}.login-form .form-group[data-v-85659b05]{margin-bottom:22px}.login-role-switch[data-v-85659b05]{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.role-btn[data-v-85659b05]{border:2px solid rgba(120,144,156,.25);background:#ffffffd9;border-radius:14px;padding:12px 10px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .22s ease}.role-btn[data-v-85659b05]:hover{transform:translateY(-1px);border-color:#f57c008c;box-shadow:0 8px 16px #00000014}.role-btn.active[data-v-85659b05]{border-color:#f57c00;background:linear-gradient(180deg,#fff8e1,#fff);box-shadow:0 0 0 4px #f57c0024}.role-btn[data-v-85659b05]:focus-visible{outline:none;box-shadow:0 0 0 4px #f57c0033}.role-icon[data-v-85659b05]{font-size:1.35rem;line-height:1}.role-icon-dual[data-v-85659b05]{display:inline-flex;align-items:center;justify-content:center;gap:2px}.role-icon-dual .role-icon-part[data-v-85659b05]{font-size:1.1rem;line-height:1}.role-title[data-v-85659b05]{font-size:.95rem;font-weight:800;color:#37474f}.role-subtitle[data-v-85659b05]{font-size:.74rem;color:#78909c}.login-form .form-group label[data-v-85659b05]{display:block;font-size:.85rem;font-weight:600;color:#455a64;margin-bottom:8px;margin-left:4px}.login-form .form-group input[data-v-85659b05],.login-form .form-group select[data-v-85659b05],.login-form .form-group textarea[data-v-85659b05]{width:100%;padding:14px 16px;border:2px solid transparent;border-radius:12px;font-size:1rem;background:#37474f0a;color:#263238;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1)}.login-form .form-group input[data-v-85659b05]::placeholder,.login-form .form-group textarea[data-v-85659b05]::placeholder{color:#90a4ae;font-weight:400}.login-form .form-group input[data-v-85659b05]:hover,.login-form .form-group select[data-v-85659b05]:hover,.login-form .form-group textarea[data-v-85659b05]:hover{background:#37474f14}.login-form .form-group input[data-v-85659b05]:focus,.login-form .form-group select[data-v-85659b05]:focus,.login-form .form-group textarea[data-v-85659b05]:focus{outline:none;background:#fff;border-color:#f57c00;box-shadow:0 0 0 4px #f57c0026}.login-form .form-group textarea[data-v-85659b05]{resize:vertical;min-height:88px}.login-btn[data-v-85659b05]{width:100%;margin-top:12px;padding:14px;font-size:1.05rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#ffb300,#f57c00);border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px #f57c004d;transition:all .3s cubic-bezier(.4,0,.2,1);letter-spacing:.02em}.login-btn[data-v-85659b05]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f57c0066;background:linear-gradient(135deg,#ffca28,#ef6c00)}.login-btn[data-v-85659b05]:active:not(:disabled){transform:translateY(1px);box-shadow:0 2px 10px #f57c004d}.login-btn[data-v-85659b05]:disabled{background:#cfd8dc;color:#90a4ae;box-shadow:none;cursor:not-allowed;transform:none}.login-footer[data-v-85659b05]{padding:20px 28px 28px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;border-top:1px solid rgba(0,0,0,.06);background:#fff6}.login-parent-hint[data-v-85659b05]{width:100%;margin:0;font-size:.85rem;color:#546e7a;text-align:center}.login-footer-btn[data-v-85659b05]{padding:10px 20px;font-size:.85rem;font-weight:600;color:#f57c00;background:#fff;border:1px solid rgba(245,124,0,.3);border-radius:10px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #00000005}.login-footer-btn[data-v-85659b05]:hover{background:#fff8e1;border-color:#ffb300;color:#ef6c00;transform:translateY(-1px);box-shadow:0 4px 10px #f57c001a}@media (max-width: 560px){.login-role-switch[data-v-85659b05]{grid-template-columns:1fr}}.pp[data-v-a214650b]{max-width:520px;margin:0 auto;padding:12px;font-family:Inter,Noto Sans TC,-apple-system,sans-serif;color:#37474f;min-height:100vh;min-height:100dvh;background:#f5f5f5}.pp-card[data-v-a214650b]{background:#fff;border-radius:12px;padding:16px 18px;margin-bottom:12px;box-shadow:0 1px 4px #0000000f,0 0 1px #00000014}.pp-hint[data-v-a214650b]{color:#78909c;font-size:.85em;margin:4px 0 0}.pp-error[data-v-a214650b]{color:#dc2626;font-size:.875em;margin:12px 0 0;padding:10px 14px;background:#fee2e2;border-radius:8px;line-height:1.5;word-break:break-word}.pp-loading-card[data-v-a214650b]{text-align:center;padding:40px 20px}.pp-spinner[data-v-a214650b]{width:36px;height:36px;margin:0 auto 12px;border:3px solid #e0e0e0;border-top-color:#06c755;border-radius:50%;animation:pp-spin-a214650b .8s linear infinite}@keyframes pp-spin-a214650b{to{transform:rotate(360deg)}}.pp-loading-text[data-v-a214650b]{color:#06c755;font-weight:600;font-size:.95em}.pp-login-card[data-v-a214650b]{padding:24px 20px}.pp-login-header[data-v-a214650b]{text-align:center;margin-bottom:20px}.pp-login-icon[data-v-a214650b]{margin-bottom:8px}.pp-login-icon .material-symbols-outlined[data-v-a214650b]{font-size:40px;color:var(--primary, #E65100)}.pp-login-header h2[data-v-a214650b]{margin:0;font-size:1.3em;color:#263238}.pp-login-form[data-v-a214650b]{display:flex;flex-direction:column;gap:14px}.pp-field label[data-v-a214650b]{display:flex;align-items:center;gap:4px;font-weight:600;font-size:.88em;margin-bottom:5px;color:#455a64}.pp-field-icon[data-v-a214650b]{font-size:18px;color:#90a4ae}.pp-field input[data-v-a214650b]{width:100%;padding:10px 12px;border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:16px;transition:border-color .2s}.pp-field input[data-v-a214650b]:focus{border-color:var(--primary, #E65100);outline:none}.pp-login-actions[data-v-a214650b]{display:flex;gap:8px;margin-top:18px}.pp-btn[data-v-a214650b]{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:.95em;font-weight:600;cursor:pointer;min-height:44px;transition:opacity .2s;-webkit-tap-highlight-color:transparent}.pp-btn[data-v-a214650b]:active{opacity:.8}.pp-btn-primary[data-v-a214650b]{background:var(--primary, #E65100);color:#fff;flex:1;justify-content:center}.pp-btn-primary[data-v-a214650b]:disabled{opacity:.7;cursor:not-allowed}.pp-btn-primary .material-symbols-outlined[data-v-a214650b]{font-size:20px}.pp-btn-line[data-v-a214650b]{background:#06c755;color:#fff;flex:1;justify-content:center}.pp-btn-small[data-v-a214650b]{padding:4px 12px;font-size:.8em;font-weight:600;background:#e3f2fd;color:#1565c0;border:none;border-radius:6px;cursor:pointer;min-height:32px}.pp-btn-logout[data-v-a214650b]{background:none;border:1px solid #e0e0e0;border-radius:8px;padding:6px;cursor:pointer;color:#90a4ae;display:flex;align-items:center}.pp-btn-logout[data-v-a214650b]:hover{background:#fafafa}.pp-btn-more[data-v-a214650b]{display:flex;align-items:center;justify-content:center;gap:4px;width:100%;padding:8px;margin-top:8px;background:#fafafa;border:1px solid #e8e8e8;border-radius:8px;font-size:.85em;color:#607d8b;cursor:pointer}.pp-profile-card[data-v-a214650b]{padding:18px}.pp-profile-top[data-v-a214650b]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.pp-avatar[data-v-a214650b]{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#e65100,#ff8a65);color:#fff;font-size:22px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pp-profile-info[data-v-a214650b]{flex:1;min-width:0}.pp-student-name[data-v-a214650b]{margin:0;font-size:1.2em;color:#263238}.pp-meta-row[data-v-a214650b]{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.pp-tag[data-v-a214650b]{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75em;font-weight:600}.pp-tag-grade[data-v-a214650b]{background:#e3f2fd;color:#1565c0}.pp-tag-school[data-v-a214650b]{background:#f3e5f5;color:#7b1fa2}.pp-tag-campus[data-v-a214650b]{background:#e8f5e9;color:#2e7d32}.pp-student-switcher[data-v-a214650b]{padding:10px 0 4px;border-top:1px solid #f0f0f0;margin-top:4px}.pp-switcher-label[data-v-a214650b]{display:flex;align-items:center;gap:4px;font-size:.82em;color:#78909c;margin-bottom:8px}.pp-switcher-chips[data-v-a214650b]{display:flex;gap:8px;flex-wrap:wrap}.pp-chip[data-v-a214650b]{padding:6px 14px;border-radius:20px;border:1.5px solid #cfd8dc;background:#fff;font-size:.88em;cursor:pointer;transition:all .2s;color:#455a64;font-weight:500}.pp-chip[data-v-a214650b]:hover:not(.active):not(:disabled){border-color:#e65100;color:#e65100;background:#fff3e0}.pp-chip.active[data-v-a214650b]{background:#e65100;color:#fff;border-color:#e65100;cursor:default}.pp-chip[data-v-a214650b]:disabled{opacity:.6;cursor:wait}.pp-sessions-summary[data-v-a214650b]{display:flex;align-items:center;gap:16px;padding:12px 0 4px}.pp-ring-container[data-v-a214650b]{position:relative;width:80px;height:80px;flex-shrink:0}.pp-ring[data-v-a214650b]{width:100%;height:100%}.pp-ring-value[data-v-a214650b]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.pp-ring-number[data-v-a214650b]{font-size:22px;font-weight:800;display:block;line-height:1}.pp-ring-label[data-v-a214650b]{font-size:11px;color:#90a4ae}.pp-sessions-detail[data-v-a214650b]{flex:1}.pp-sessions-title[data-v-a214650b]{font-weight:700;font-size:1em}.pp-sessions-sub[data-v-a214650b]{font-size:.82em;color:#90a4ae}.pp-line-status[data-v-a214650b]{display:flex;align-items:center;gap:4px;margin-top:4px;font-size:.82em;color:#06c755}.pp-subject-breakdown[data-v-a214650b]{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #eee}.pp-subject-pill[data-v-a214650b]{display:flex;align-items:center;gap:6px;background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;padding:5px 14px;font-size:.85em}.pp-pill-subject[data-v-a214650b]{color:#37474f;font-weight:600}.pp-pill-count[data-v-a214650b]{font-weight:800}.pp-section-header[data-v-a214650b]{display:flex;align-items:center;gap:8px;margin-bottom:12px}.pp-section-icon[data-v-a214650b]{font-size:22px}.pp-section-header h3[data-v-a214650b]{margin:0;font-size:1.05em;color:#263238}.pp-tab-bar[data-v-a214650b]{display:flex;gap:0;background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000014;overflow:hidden;margin-bottom:4px}.pp-tab[data-v-a214650b]{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px;background:none;border:none;cursor:pointer;font-size:.8em;color:#90a4ae;transition:color .2s,background .2s;position:relative}.pp-tab .material-symbols-outlined[data-v-a214650b]{font-size:20px}.pp-tab.active[data-v-a214650b]{color:#1565c0;background:#e8f2ff;font-weight:600}.pp-tab[data-v-a214650b]:not(.active):hover{background:#f5f8ff;color:#5c6bc0}.pp-tab-badge[data-v-a214650b]{position:absolute;top:6px;right:calc(50% - 18px);background:#e53935;color:#fff;border-radius:10px;font-size:.7em;padding:1px 5px;font-weight:700;min-width:16px;text-align:center}.pp-info-card[data-v-a214650b]{border-left:4px solid #90caf9}.pp-info-hint[data-v-a214650b]{font-size:.82em;color:#78909c;margin:10px 0 0}.pp-alert-card[data-v-a214650b]{border-left:4px solid #ff9800}.pp-alert-item[data-v-a214650b]{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f5f5f5;flex-wrap:wrap;gap:6px}.pp-alert-item[data-v-a214650b]:last-child{border-bottom:none}.pp-subject-chip[data-v-a214650b]{background:#e3f2fd;color:#1565c0;padding:3px 10px;border-radius:6px;font-size:.85em;font-weight:600}.pp-alert-badges[data-v-a214650b]{display:flex;gap:4px;flex-wrap:wrap}.pp-badge[data-v-a214650b]{display:inline-block;padding:2px 10px;border-radius:10px;font-size:.78em;font-weight:600;white-space:nowrap}.pp-badge-success[data-v-a214650b]{background:#e8f5e9;color:#2e7d32}.pp-badge-warning[data-v-a214650b]{background:#fff3e0;color:#e65100}.pp-badge-danger[data-v-a214650b]{background:#ffebee;color:#c62828}.pp-badge-info[data-v-a214650b]{background:#e3f2fd;color:#1565c0}.pp-badge-neutral[data-v-a214650b]{background:#eceff1;color:#546e7a}.pp-badge-info-soft[data-v-a214650b]{background:#e8eaf6;color:#3949ab}.pp-badge-info-warn[data-v-a214650b]{background:#fff8e1;color:#f57f17}.pp-voice-card[data-v-a214650b]{background:linear-gradient(135deg,#f0f7ff,#e8f4fd);border:1px solid #bbdefb}.pp-voice-brand[data-v-a214650b]{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #c5dff8}.pp-voice-logo[data-v-a214650b]{font-size:28px;color:#1565c0;flex-shrink:0}.pp-voice-brand-name[data-v-a214650b]{font-size:.95em;font-weight:700;color:#1565c0;line-height:1.3}.pp-voice-brand-sub[data-v-a214650b]{font-size:.75em;color:#5c8fb5;margin-top:2px}.pp-voice-label[data-v-a214650b]{font-size:.82em;font-weight:600;color:#37474f;margin:12px 0 6px}.pp-voice-optional[data-v-a214650b]{font-weight:400;color:#90a4ae}.pp-voice-required[data-v-a214650b]{font-weight:400;color:#ef9a9a}.pp-voice-chips[data-v-a214650b]{display:flex;flex-wrap:wrap;gap:8px}.pp-voice-chip[data-v-a214650b]{padding:9px 16px;border-radius:20px;border:1.5px solid #90caf9;background:#fff;color:#1565c0;font-size:.88em;cursor:pointer;transition:all .15s;min-height:40px}.pp-voice-chip.active[data-v-a214650b]{background:#1565c0;color:#fff;border-color:#1565c0;font-weight:600}.pp-voice-chip[data-v-a214650b]:not(.active):active{background:#e3f2fd}.pp-voice-stars[data-v-a214650b]{display:flex;gap:4px;align-items:center;padding:4px 0}.pp-star-btn[data-v-a214650b]{background:none;border:none;cursor:pointer;padding:4px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.pp-voice-textarea[data-v-a214650b]{width:100%;border:1.5px solid #90caf9;border-radius:10px;padding:12px;font-size:.92em;line-height:1.6;resize:vertical;background:#fff;outline:none;box-sizing:border-box;font-family:inherit;transition:border-color .2s}.pp-voice-textarea[data-v-a214650b]:focus{border-color:#1565c0}.pp-voice-count[data-v-a214650b]{text-align:right;font-size:.75em;color:#90a4ae;margin-top:4px}.pp-voice-count.warn[data-v-a214650b]{color:#e53935}.pp-voice-submit[data-v-a214650b]{margin-top:14px;width:100%;padding:14px;background:#1565c0;color:#fff;border:none;border-radius:12px;font-size:1em;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s;min-height:50px}.pp-voice-submit[data-v-a214650b]:disabled{background:#b0bec5;cursor:not-allowed}.pp-voice-submit[data-v-a214650b]:not(:disabled):active{background:#0d47a1}.pp-voice-submit .material-symbols-outlined[data-v-a214650b]{font-size:20px}.pp-voice-success[data-v-a214650b]{display:flex;align-items:center;gap:10px;background:#e8f5e9;color:#2e7d32;border-radius:10px;padding:14px 16px;font-weight:600;font-size:.95em}.pp-voice-success .material-symbols-outlined[data-v-a214650b]{font-size:24px;flex-shrink:0}.pp-session-list[data-v-a214650b]{display:flex;flex-direction:column;gap:0}.pp-session-item[data-v-a214650b]{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f5f5f5}.pp-session-item[data-v-a214650b]:last-child{border-bottom:none}.pp-session-date-col[data-v-a214650b]{text-align:center;min-width:44px}.pp-session-day[data-v-a214650b]{font-size:1em;font-weight:700;color:#263238}.pp-session-weekday[data-v-a214650b]{font-size:.75em;color:#90a4ae}.pp-session-info[data-v-a214650b]{flex:1;min-width:0}.pp-session-subject[data-v-a214650b]{font-weight:600;font-size:.92em}.pp-session-time[data-v-a214650b]{font-size:.82em;color:#78909c}.pp-session-action[data-v-a214650b]{display:flex;align-items:center;gap:6px;flex-shrink:0}.pp-status-dot[data-v-a214650b]{width:8px;height:8px;border-radius:50%;background:#90a4ae;flex-shrink:0}.pp-status-dot.scheduled[data-v-a214650b]{background:#1565c0}.pp-status-dot.rescheduled[data-v-a214650b]{background:#f57c00}.pp-status-dot.leave_requested[data-v-a214650b]{background:#7b1fa2}.pp-status-text[data-v-a214650b]{font-size:.78em;color:#78909c}.pp-course-grid[data-v-a214650b]{display:flex;flex-direction:column;gap:10px}.pp-course-card[data-v-a214650b]{background:#fafafa;border-radius:10px;padding:14px;border:1px solid #eee;transition:border-color .2s}.pp-course-card.warning[data-v-a214650b]{border-color:#ffcc80}.pp-course-card.danger[data-v-a214650b]{border-color:#ef9a9a}.pp-course-card.stopped[data-v-a214650b]{opacity:.6}.pp-course-top[data-v-a214650b]{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.pp-course-subject[data-v-a214650b]{font-weight:700;font-size:.95em}.pp-course-progress[data-v-a214650b]{margin-bottom:8px}.pp-progress-bar[data-v-a214650b]{height:6px;background:#e8e8e8;border-radius:3px;overflow:hidden}.pp-progress-fill[data-v-a214650b]{height:100%;border-radius:3px;transition:width .4s ease}.pp-progress-labels[data-v-a214650b]{display:flex;justify-content:space-between;font-size:.75em;color:#90a4ae;margin-top:4px}.pp-course-remaining[data-v-a214650b]{text-align:right}.pp-remaining-number[data-v-a214650b]{font-size:1.6em;font-weight:800}.pp-remaining-label[data-v-a214650b]{font-size:.78em;color:#90a4ae;margin-left:2px}.pp-monthly-stats[data-v-a214650b]{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-top:6px}.pp-monthly-attended[data-v-a214650b]{text-align:left;display:flex;align-items:baseline;gap:4px}.pp-monthly-fee[data-v-a214650b]{text-align:right;display:flex;flex-direction:column;align-items:flex-end}.pp-monthly-fee-amount[data-v-a214650b]{font-size:1.15em;font-weight:700;color:#37474f}.pp-monthly-fee-label[data-v-a214650b]{font-size:.72em;color:#90a4ae;margin-top:2px}.pp-record-card[data-v-a214650b]{background:#fafafa;border-radius:10px;padding:12px 14px;margin-bottom:8px;cursor:pointer;border:1px solid #eee;transition:background .15s}.pp-record-card[data-v-a214650b]:active{background:#f0f0f0}.pp-record-header[data-v-a214650b]{display:flex;align-items:center;gap:8px}.pp-record-main[data-v-a214650b]{flex:1;min-width:0}.pp-record-date[data-v-a214650b]{font-size:.82em;color:#90a4ae;display:block}.pp-record-subject[data-v-a214650b]{font-weight:600;font-size:.95em}.pp-record-score[data-v-a214650b]{text-align:center;flex-shrink:0}.pp-score-value[data-v-a214650b]{font-size:1.4em;font-weight:800;color:#1565c0}.pp-score-label[data-v-a214650b]{font-size:.7em;color:#90a4ae}.pp-expand-icon[data-v-a214650b]{color:#bdbdbd;transition:transform .2s;font-size:20px}.pp-expand-icon.expanded[data-v-a214650b]{transform:rotate(180deg)}.pp-record-detail[data-v-a214650b]{margin-top:10px;padding-top:10px;border-top:1px solid #e8e8e8;display:flex;flex-direction:column;gap:8px}.pp-detail-row[data-v-a214650b]{display:flex;align-items:flex-start;gap:6px;font-size:.88em}.pp-detail-icon[data-v-a214650b]{font-size:16px;color:#90a4ae;flex-shrink:0;margin-top:1px}.pp-detail-label[data-v-a214650b]{font-weight:600;color:#607d8b;white-space:nowrap;margin-right:4px}.pp-feedback-box[data-v-a214650b]{margin-top:12px;padding:12px;border:1px solid #e0e7ff;border-radius:12px;background:#5c6bc00f}.pp-feedback-title[data-v-a214650b]{display:flex;align-items:center;gap:6px;font-weight:700;color:#3949ab}.pp-feedback-hint[data-v-a214650b],.pp-feedback-time[data-v-a214650b]{margin:6px 0;font-size:.86em;color:#607d8b}.pp-feedback-textarea[data-v-a214650b]{width:100%;min-height:96px;resize:vertical;border:1px solid #c5cae9;border-radius:10px;padding:10px;font:inherit;box-sizing:border-box}.pp-feedback-actions[data-v-a214650b]{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:8px}.pp-feedback-count[data-v-a214650b]{font-size:.8em;color:#78909c}.pp-feedback-count.warn[data-v-a214650b]{color:#e65100}.pp-feedback-submit[data-v-a214650b]{min-height:44px}.pp-feedback-error[data-v-a214650b]{margin-top:6px}.pp-lr-filter-row[data-v-a214650b]{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 14px;padding:0 4px}.pp-lr-chip[data-v-a214650b]{border:1px solid #cfd8dc;background:#fff;color:#455a64;font-size:13px;font-weight:600;padding:8px 14px;border-radius:999px;cursor:pointer;-webkit-tap-highlight-color:transparent}.pp-lr-chip.active[data-v-a214650b]{background:#5c6bc0;border-color:#5c6bc0;color:#fff}.pp-lr-subject-block[data-v-a214650b]{margin-bottom:8px}.pp-lr-subject-heading[data-v-a214650b]{margin:16px 0 8px;font-size:15px;font-weight:700;color:#37474f;padding-bottom:6px;border-bottom:1px solid #eceff1}.pp-lr-subject-block:first-of-type .pp-lr-subject-heading[data-v-a214650b]{margin-top:0}.pp-report[data-v-a214650b]{background:#fafafa;border-radius:10px;padding:14px;margin-bottom:10px;cursor:pointer;border:1px solid #eee;transition:background .15s,box-shadow .2s}.pp-report[data-v-a214650b]:active{background:#f0f0f0}.pp-report-head[data-v-a214650b]{display:flex;align-items:center;gap:10px}.pp-report-head-left[data-v-a214650b]{flex:1;min-width:0}.pp-report-subject[data-v-a214650b]{font-weight:700;font-size:1em;color:#263238;margin-bottom:2px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.pp-session-num[data-v-a214650b]{font-size:.75em;font-weight:600;color:#1e40af;background:#dbeafe;padding:1px 7px;border-radius:8px;white-space:nowrap}.pp-report-meta[data-v-a214650b]{display:flex;align-items:center;gap:4px;flex-wrap:wrap;font-size:.8em;color:#90a4ae}.pp-report-score-ring[data-v-a214650b]{width:48px;height:48px;flex-shrink:0;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}.pp-report-score-val[data-v-a214650b]{font-size:1.1em;font-weight:800;color:#1565c0;line-height:1}.pp-report-score-unit[data-v-a214650b]{font-size:.6em;color:#64b5f6}.pp-report-indicators[data-v-a214650b]{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;padding-top:8px;border-top:1px dashed #e8e8e8}.pp-indicator[data-v-a214650b]{display:flex;align-items:center;gap:4px;background:#fff;border:1px solid #eee;border-radius:6px;padding:4px 10px;font-size:.82em}.pp-indicator-icon[data-v-a214650b]{font-size:16px}.pp-indicator-text[data-v-a214650b]{color:#546e7a;font-weight:500}.pp-report-body[data-v-a214650b]{margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:12px}.pp-report-field[data-v-a214650b]{background:#fff;border-radius:8px;padding:10px 12px;border:1px solid #f0f0f0}.pp-report-field-label[data-v-a214650b]{display:flex;align-items:center;gap:6px;font-size:.8em;font-weight:700;color:#78909c;margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.pp-report-field-label .material-symbols-outlined[data-v-a214650b]{font-size:16px}.pp-report-field-value[data-v-a214650b]{font-size:.92em;color:#37474f;line-height:1.6;white-space:pre-line}.pp-report-comment[data-v-a214650b]{background:#fffde7;padding:10px 12px;border-radius:6px;border-left:3px solid #ffd54f;font-style:italic}.pp-timeline[data-v-a214650b]{position:relative;padding-left:28px}.pp-timeline[data-v-a214650b]:before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:#e0e0e0}.pp-timeline-item[data-v-a214650b]{display:flex;align-items:flex-start;gap:10px;padding:10px 0;position:relative;min-height:44px}.pp-timeline-item.absent[data-v-a214650b]{background:linear-gradient(90deg,rgba(229,57,53,.06) 0%,transparent 50%);border-radius:6px;padding-left:4px;margin-left:-4px}.pp-timeline-dot[data-v-a214650b]{position:absolute;left:-28px;top:10px;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:1;background:#90a4ae}.pp-timeline-dot .material-symbols-outlined[data-v-a214650b]{font-size:14px;color:#fff}.pp-timeline-dot.present[data-v-a214650b]{background:#43a047}.pp-timeline-dot.late[data-v-a214650b]{background:#fb8c00}.pp-timeline-dot.absent[data-v-a214650b]{background:#e53935}.pp-timeline-dot.leave[data-v-a214650b]{background:#757575}.pp-timeline-content[data-v-a214650b]{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.pp-timeline-head[data-v-a214650b]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pp-timeline-date[data-v-a214650b]{font-size:.88em;color:#455a64;font-weight:600}.pp-timeline-status[data-v-a214650b]{font-size:.82em;font-weight:700;padding:2px 8px;border-radius:999px}.pp-timeline-status.present[data-v-a214650b]{color:#2e7d32;background:#e8f5e9}.pp-timeline-status.late[data-v-a214650b]{color:#e65100;background:#fff3e0}.pp-timeline-status.absent[data-v-a214650b]{color:#c62828;background:#ffebee}.pp-timeline-status.leave[data-v-a214650b]{color:#424242;background:#eee}.pp-timeline-sub[data-v-a214650b]{display:flex;flex-wrap:wrap;gap:10px;font-size:.8em;color:#607d8b}.pp-timeline-sub span[data-v-a214650b]{display:inline-flex;align-items:center;gap:3px}.pp-mini-icon[data-v-a214650b]{font-size:13px!important;vertical-align:middle}.pp-empty-hint[data-v-a214650b]{font-size:.78em!important;color:#b0bec5;margin-top:4px}.pp-skeleton-card[data-v-a214650b]{padding:18px}.pp-skel[data-v-a214650b]{background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0);background-size:200% 100%;animation:pp-skel-shimmer-a214650b 1.4s ease-in-out infinite;border-radius:4px}.pp-skel--circle[data-v-a214650b]{width:48px;height:48px;border-radius:50%}.pp-skel-row[data-v-a214650b]{display:flex;align-items:center;gap:12px}@keyframes pp-skel-shimmer-a214650b{0%{background-position:200% 0}to{background-position:-200% 0}}.pp-profile-card[data-v-a214650b],.pp-alert-card[data-v-a214650b]{animation:pp-card-fade-in-a214650b .25s ease-out}@keyframes pp-card-fade-in-a214650b{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.pp-announcement[data-v-a214650b]{padding:10px 0;border-bottom:1px solid #f0f0f0}.pp-announcement[data-v-a214650b]:last-child{border-bottom:none}.pp-ann-title[data-v-a214650b]{font-weight:700;font-size:.95em;color:#263238}.pp-ann-body[data-v-a214650b]{font-size:.88em;color:#546e7a;margin-top:4px;white-space:pre-line}.pp-ann-date[data-v-a214650b]{font-size:.78em;color:#b0bec5;margin-top:4px}.pp-invoice-item[data-v-a214650b]{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f5f5f5}.pp-invoice-item[data-v-a214650b]:last-child{border-bottom:none}.pp-invoice-date[data-v-a214650b]{font-size:.85em;color:#607d8b}.pp-invoice-amount[data-v-a214650b]{font-weight:700;font-size:1.05em}.pp-invoice-badges[data-v-a214650b]{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.pp-badge-reconciled[data-v-a214650b]{background:#e8f5e9;color:#2e7d32;display:inline-flex;align-items:center;gap:2px}.pp-line-bound[data-v-a214650b]{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#e8f5e9;border-radius:8px;font-size:.9em;color:#2e7d32}.pp-line-unbound[data-v-a214650b]{font-size:.9em}.pp-bind-code[data-v-a214650b]{display:block;background:#f5f5f5;padding:10px 14px;border-radius:8px;margin:8px 0;font-family:monospace;font-size:.92em;color:#37474f;border:1px solid #e0e0e0}.pp-empty[data-v-a214650b]{text-align:center;padding:20px;color:#b0bec5}.pp-empty .material-symbols-outlined[data-v-a214650b]{font-size:36px;margin-bottom:4px}.pp-empty p[data-v-a214650b]{margin:0;font-size:.88em}.pp-section-count[data-v-a214650b]{margin-left:auto;font-size:.78em;color:#90a4ae;font-weight:500}.pp-spinner-inline[data-v-a214650b]{width:16px;height:16px;border:2px solid #e0e0e0;border-top-color:#5c6bc0;border-radius:50%;animation:pp-spin-a214650b .8s linear infinite;flex-shrink:0}.pp-btn-more[data-v-a214650b]:disabled{opacity:.7;cursor:default}@media (max-width: 640px){.pp[data-v-a214650b]{padding:8px}.pp-card[data-v-a214650b]{padding:14px;border-radius:10px}.pp-login-card[data-v-a214650b]{padding:20px 16px}.pp-sessions-summary[data-v-a214650b]{flex-direction:column;text-align:center;gap:8px}}@media (min-width: 521px){.pp[data-v-a214650b]{padding:20px}.pp-card[data-v-a214650b]{padding:20px 24px}.pp-course-grid[data-v-a214650b]{display:grid;grid-template-columns:repeat(2,1fr)}}.fab[data-v-9df696bb]{position:fixed;z-index:900;width:52px;height:52px;border-radius:50%;background:var(--primary);color:#fff;border:none;box-shadow:0 4px 12px #0003;cursor:grab;touch-action:none;display:flex;align-items:center;justify-content:center;will-change:transform;transition:left .35s cubic-bezier(.22,1,.36,1),top .35s cubic-bezier(.22,1,.36,1),box-shadow .2s}.fab[data-v-9df696bb]:hover{transform:scale(1.08);box-shadow:0 6px 20px #00000040}.fab.dragging[data-v-9df696bb]{cursor:grabbing;transform:none;transition:none}.fab .material-symbols-outlined[data-v-9df696bb]{font-size:26px}.modal-overlay[data-v-9df696bb]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card[data-v-9df696bb]{background:var(--card-bg);border-radius:var(--radius);padding:24px;width:480px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-hover)}.modal-card h3[data-v-9df696bb]{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:18px}label[data-v-9df696bb]{display:block;font-size:13px;font-weight:600;margin-bottom:4px;margin-top:12px}.required[data-v-9df696bb]{color:var(--danger)}.form-input[data-v-9df696bb],.form-select[data-v-9df696bb],.form-textarea[data-v-9df696bb]{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit}.form-textarea[data-v-9df696bb]{resize:vertical}.file-input[data-v-9df696bb]{width:100%;padding:8px 0;font-size:13px}.attachment-previews[data-v-9df696bb]{margin-top:6px;font-size:13px}.att-row[data-v-9df696bb]{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 0;border-bottom:1px solid var(--border)}.att-name[data-v-9df696bb]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-light)}.att-remove[data-v-9df696bb]{flex-shrink:0;padding:2px 8px;font-size:12px;border:1px solid var(--border);border-radius:6px;background:var(--card-bg);cursor:pointer}.context-info[data-v-9df696bb]{display:flex;align-items:center;gap:6px;margin-top:14px;padding:8px 12px;background:#f0f4f8;border-radius:8px;font-size:13px;color:var(--text-light)}.context-info .material-symbols-outlined[data-v-9df696bb]{font-size:18px}.form-actions[data-v-9df696bb]{display:flex;gap:8px;margin-top:20px;justify-content:flex-end}.btn-cancel[data-v-9df696bb]{padding:8px 20px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);font-size:14px;cursor:pointer}.btn-submit[data-v-9df696bb]{padding:8px 20px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:14px;cursor:pointer}.btn-submit[data-v-9df696bb]:disabled{opacity:.4;cursor:not-allowed}.success-msg[data-v-9df696bb]{display:flex;align-items:center;gap:6px;margin-top:12px;color:var(--success);font-size:14px;font-weight:600}.error-msg[data-v-9df696bb]{margin-top:12px;color:var(--danger);font-size:13px}@media (max-width: 768px){.fab[data-v-9df696bb]{width:48px;height:48px}}.build-stamp-bar[data-v-bd02427e]{flex-shrink:0;align-self:center;max-width:min(200px,38vw);font-size:10px;line-height:1.3;color:#94a3b8;letter-spacing:.02em;-webkit-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role-hint[data-v-bd02427e]{font-size:.7rem;color:#2e7d32;margin-top:2px}.user-avatar-image[data-v-bd02427e]{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}.nav-no-role-hint[data-v-bd02427e]{padding:12px 20px;font-size:12px;color:#90a4ae;text-align:center}.password-lock-card[data-v-bd02427e]{margin-bottom:12px;border:1px solid #ffcc80;background:#fff8e1;color:#8d4e00}.sidebar-nav button[data-v-bd02427e]:disabled{opacity:.55;cursor:not-allowed}.nav-group[data-v-bd02427e]{border:1px solid rgba(148,163,184,.24);border-radius:12px;background:#0f172a47;overflow:hidden}.nav-group+.nav-group[data-v-bd02427e]{margin-top:12px}.nav-group-summary[data-v-bd02427e]{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid rgba(148,163,184,.18)}.nav-group-summary[data-v-bd02427e]::-webkit-details-marker{display:none}.nav-group-title[data-v-bd02427e]{font-size:11px;font-weight:700;color:#cbd5e1;text-transform:uppercase;letter-spacing:.07em}.nav-group-chevron[data-v-bd02427e]{font-size:12px;color:#94a3b8;transition:transform .2s ease}.nav-group[open] .nav-group-chevron[data-v-bd02427e]{transform:rotate(180deg)}.nav-group-list[data-v-bd02427e]{display:grid;gap:3px;padding:6px}.nav-icon[data-v-bd02427e]{width:22px;min-width:22px;text-align:center;flex-shrink:0;font-size:18px;line-height:1}.nav-label[data-v-bd02427e]{min-width:0}.main-topbar[data-v-bd02427e]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.main-topbar-spacer[data-v-bd02427e]{flex:1}.account-menu[data-v-bd02427e]{position:relative;z-index:20}.account-menu-trigger[data-v-bd02427e]{list-style:none;display:flex;align-items:center;gap:10px;cursor:pointer;border:1px solid var(--border);border-radius:12px;background:var(--topbar-bg);padding:6px 10px 6px 6px;box-shadow:0 2px 10px #0f172a0f}.account-menu-trigger[data-v-bd02427e]::-webkit-details-marker{display:none}.account-avatar[data-v-bd02427e]{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#f97316,#fb923c);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.account-avatar-image[data-v-bd02427e]{width:100%;height:100%;border-radius:inherit;object-fit:cover}.account-meta[data-v-bd02427e]{min-width:0;text-align:left}.account-name[data-v-bd02427e]{color:var(--text);font-size:13px;font-weight:600;max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-role[data-v-bd02427e]{color:#64748b;font-size:11px;line-height:1.25}.account-menu-chevron[data-v-bd02427e]{color:#64748b;font-size:18px;transition:transform .2s ease}.account-menu[open] .account-menu-chevron[data-v-bd02427e]{transform:rotate(180deg)}.account-menu-panel[data-v-bd02427e]{position:absolute;top:calc(100% + 8px);right:0;min-width:188px;border:1px solid var(--border);border-radius:12px;background:var(--modal-bg);box-shadow:0 10px 30px #0f172a29;padding:6px;display:grid;gap:4px}.account-menu-btn[data-v-bd02427e]{border:0;background:transparent;display:flex;align-items:center;gap:8px;width:100%;border-radius:8px;padding:8px 10px;color:var(--text);font-size:13px}.account-menu-btn[data-v-bd02427e]:hover{background:var(--input-bg)}.account-menu-btn .material-symbols-outlined[data-v-bd02427e]{font-size:18px}.account-menu-btn-danger[data-v-bd02427e]{color:#b91c1c}.account-menu-btn-danger[data-v-bd02427e]:hover{background:#fef2f2}.standalone-parent-shell[data-v-bd02427e]{position:relative}.global-guide-btn[data-v-bd02427e]{position:fixed;width:46px;height:46px;border-radius:50%;border:none;background:linear-gradient(135deg,#ff9800,#ff6f00);color:#fff;font-size:22px;font-weight:700;cursor:grab;touch-action:none;box-shadow:0 8px 24px #00000040;z-index:10010;will-change:transform;transition:left .48s cubic-bezier(.22,1,.32,1),top .48s cubic-bezier(.22,1,.32,1),transform .2s ease,box-shadow .2s ease}@media (pointer: coarse){.global-guide-btn[data-v-bd02427e]{transition:left .35s cubic-bezier(.22,1,.32,1),top .35s cubic-bezier(.22,1,.32,1),box-shadow .2s ease}}.global-guide-btn[data-v-bd02427e]:hover:not(.is-dragging){transform:translateY(-2px)}.global-guide-btn.is-dragging[data-v-bd02427e]{cursor:grabbing;transform:none;transition:none}.guide-tour-popover-layer[data-v-bd02427e]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2147483000;pointer-events:auto}.guide-tour-popover[data-v-bd02427e]{position:fixed;width:min(360px,calc(100vw - 24px));max-width:calc(100vw - 32px);background:#fff;border-radius:14px;box-shadow:0 14px 38px #00000059;border:1px solid #ffe0b2;pointer-events:auto;overflow:hidden;isolation:isolate;display:flex;flex-direction:column}.guide-tour-popover[data-v-bd02427e]:after{content:"";position:absolute;width:10px;height:10px;background:#fff;border-left:1px solid #ffe0b2;border-top:1px solid #ffe0b2;transform:rotate(45deg)}.guide-tour-popover.placement-bottom[data-v-bd02427e]:after{top:-6px;left:clamp(20px,16%,42px)}.guide-tour-popover.placement-top[data-v-bd02427e]:after{bottom:-6px;left:clamp(20px,16%,42px);transform:rotate(225deg)}.guide-tour-popover.placement-left[data-v-bd02427e]:after{right:-6px;top:clamp(20px,28%,48px);transform:rotate(135deg)}.guide-tour-popover.placement-right[data-v-bd02427e]:after{left:-6px;top:clamp(20px,28%,48px);transform:rotate(-45deg)}.guide-tour-popover.placement-center[data-v-bd02427e]:after{display:none}.guide-tour-popover-head[data-v-bd02427e]{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px 8px;border-bottom:1px solid #f3f3f3}.guide-tour-head-title[data-v-bd02427e]{display:flex;align-items:center;gap:6px;min-width:0}.guide-tour-icon[data-v-bd02427e]{font-size:18px;line-height:1;flex-shrink:0}.guide-tour-popover-head strong[data-v-bd02427e]{font-size:14px;color:#263238}.guide-tour-close[data-v-bd02427e]{border:0;background:transparent;color:#607d8b;cursor:pointer;font-size:14px;flex-shrink:0}.guide-tour-popover-text[data-v-bd02427e]{margin:0;padding:12px 14px 8px;font-size:13px;line-height:1.6;color:#455a64;overflow-y:auto}.guide-tour-dots[data-v-bd02427e]{display:flex;justify-content:center;align-items:center;gap:6px;padding:4px 14px 0}.guide-tour-dot[data-v-bd02427e]{width:7px;height:7px;border-radius:50%;background:#cfd8dc;transition:background .2s,transform .2s}.guide-tour-dot.active[data-v-bd02427e]{background:#ff9800;transform:scale(1.3)}.guide-tour-popover-foot[data-v-bd02427e]{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:10px 14px 14px}.guide-tour-actions[data-v-bd02427e]{display:flex;gap:8px}.guide-tour-btn[data-v-bd02427e]{border:1px solid #cfd8dc;background:#fff;color:#455a64;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:12px}.guide-tour-btn[data-v-bd02427e]:disabled{opacity:.45;cursor:not-allowed}.guide-tour-btn-primary[data-v-bd02427e]{border-color:#ff9800;background:#ff9800;color:#fff}@media (max-width: 640px){.nav-group[data-v-bd02427e]{display:flex;gap:0;border:0;border-radius:0;background:transparent}.nav-group+.nav-group[data-v-bd02427e]{margin-top:0}.nav-group-summary[data-v-bd02427e]{display:none}.nav-group-list[data-v-bd02427e]{display:flex;gap:0;padding:0}.main-topbar[data-v-bd02427e]{margin-bottom:6px}.account-menu-trigger[data-v-bd02427e]{padding:5px 8px 5px 5px}.account-name[data-v-bd02427e]{max-width:102px}.guide-tour-popover-foot[data-v-bd02427e]{flex-direction:column;align-items:stretch}.guide-tour-actions[data-v-bd02427e]{justify-content:flex-end}}.shortcut-hint[data-v-bd02427e]{margin-top:8px;padding-top:8px;border-top:1px solid rgba(148,163,184,.15)}.shortcut-hint__toggle[data-v-bd02427e]{list-style:none;cursor:pointer;font-size:12px;color:var(--text-light, #94a3b8);padding:4px 2px;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:4px}.shortcut-hint__toggle[data-v-bd02427e]::-webkit-details-marker{display:none}.shortcut-hint__toggle[data-v-bd02427e]:hover{color:var(--text, #334155)}.shortcut-hint__list[data-v-bd02427e]{list-style:none;padding:6px 4px 2px;margin:0;display:flex;flex-direction:column;gap:5px}.shortcut-hint__list li[data-v-bd02427e]{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-light, #94a3b8)}.shortcut-hint__list span[data-v-bd02427e]{color:var(--text, #475569);margin-left:2px}.shortcut-hint__list kbd[data-v-bd02427e]{display:inline-block;padding:1px 5px;font-size:10px;font-family:inherit;background:#94a3b81f;border:1px solid rgba(148,163,184,.3);border-radius:4px;color:var(--text, #475569);line-height:1.6;white-space:nowrap}.theme-switcher[data-v-bd02427e]{margin-top:8px;padding-top:8px;border-top:1px solid rgba(148,163,184,.16)}.theme-switcher-label[data-v-bd02427e]{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-weight:600}.theme-buttons[data-v-bd02427e]{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}.theme-buttons-collapsed[data-v-bd02427e]{grid-template-columns:1fr}.theme-btn[data-v-bd02427e]{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 4px;border-radius:8px;border:1px solid rgba(148,163,184,.2);background:#94a3b814;color:#94a3b8;font-size:11px;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}.theme-btn[data-v-bd02427e]:hover{background:#94a3b82e;color:#e2e8f0}.theme-btn.active[data-v-bd02427e]{background:#0ea5e938;border-color:#7dd3fc73;color:#7dd3fc;font-weight:600}.theme-btn-label[data-v-bd02427e]{font-size:11px}.update-banner[data-v-bd02427e]{position:fixed;top:0;left:0;right:0;z-index:99999;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 18px;background:linear-gradient(135deg,#0ea5e9,#2563eb);color:#fff;font-size:14px;font-weight:500;box-shadow:0 2px 12px #0000002e}.update-banner-icon[data-v-bd02427e]{font-size:20px}.update-banner-text[data-v-bd02427e]{flex-shrink:1}.update-banner-btn[data-v-bd02427e]{background:#fff;color:#2563eb;border:none;border-radius:6px;padding:5px 16px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.update-banner-btn[data-v-bd02427e]:hover{background:#e0edff}.update-banner-close[data-v-bd02427e]{background:none;border:none;color:#fffc;font-size:20px;line-height:1;cursor:pointer;padding:0 4px;margin-left:4px;transition:color .15s}.update-banner-close[data-v-bd02427e]:hover{color:#fff}.update-banner-enter-active[data-v-bd02427e]{transition:transform .35s ease,opacity .35s ease}.update-banner-leave-active[data-v-bd02427e]{transition:transform .25s ease,opacity .25s ease}.update-banner-enter-from[data-v-bd02427e],.update-banner-leave-to[data-v-bd02427e]{transform:translateY(-100%);opacity:0}*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #E65100;--primary-light: #FF8A65;--primary-bg: #FFF3E0;--accent: #FFA726;--accent-hover: #FB8C00;--sidebar-bg: linear-gradient(180deg, #0f172a 0%, #111827 100%);--sidebar-w: 284px;--bg: #F5F5F5;--card-bg: #FFFFFF;--text: #37474F;--text-light: #78909C;--border: #E0E0E0;--success: #43A047;--success-bg: #E8F5E9;--danger: #E53935;--danger-bg: #FFEBEE;--warning: #FB8C00;--warning-bg: #FFF3E0;--radius: 12px;--shadow: 0 2px 8px rgba(0, 0, 0, .06);--shadow-hover: 0 4px 16px rgba(0, 0, 0, .1);--transition: all .2s ease;--input-bg: #FAFAFA;--input-focus-bg: #FFFFFF;--modal-bg: #FFFFFF;--topbar-bg: #FFFFFF;--topbar-border: #F0F0F0}[data-theme=dark]{--bg: #0f172a;--card-bg: #1e293b;--text: #e2e8f0;--text-light: #94a3b8;--border: #334155;--primary-bg: #431407;--success-bg: #052e16;--danger-bg: #450a0a;--warning-bg: #431407;--shadow: 0 2px 8px rgba(0, 0, 0, .4);--shadow-hover: 0 4px 20px rgba(0, 0, 0, .65);--input-bg: #1e293b;--input-focus-bg: #0f172a;--modal-bg: #1e293b;--topbar-bg: #1e293b;--topbar-border: #334155}html{overflow-x:hidden;max-width:100vw;-webkit-overflow-scrolling:touch}body{overflow-x:hidden;max-width:100vw}html{overflow-y:scroll}body{font-family:Inter,Noto Sans TC,Microsoft JhengHei,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;line-height:1}.app-layout{display:flex;min-height:100vh;min-height:100dvh}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);color:#d1d9e6;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:80;overflow-y:auto;overscroll-behavior:contain;padding:18px 14px 16px;border-right:1px solid rgba(148,163,184,.18);box-shadow:8px 0 28px #02061742}.sidebar-brand{padding:10px 12px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(148,163,184,.16);position:relative;margin-bottom:10px}.brand-logo-container{width:48px;height:48px;flex-shrink:0;border-radius:14px;background:#fff;padding:0;box-shadow:0 8px 18px #02061733;display:flex;align-items:center;justify-content:center;overflow:hidden}.brand-logo{width:100%;height:100%;object-fit:cover;transform:scale(1.08)}.sidebar-brand h1{font-size:16px;font-weight:700;color:#f8fafc;letter-spacing:.02em;line-height:1.2}.sidebar-brand .brand-sub{font-size:12px;color:#94a3b8;margin-top:3px}.sidebar-nav{flex:1;padding:4px 4px 10px;display:flex;flex-direction:column;gap:4px}.sidebar-nav button{display:flex;align-items:center;gap:12px;width:100%;padding:11px 12px;border:none;background:transparent;color:#c7d2e5;font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);text-align:left;border-radius:12px;font-family:inherit;position:relative}.sidebar-nav button:hover{background:#94a3b829;color:#fff}.sidebar-nav button.active{background:linear-gradient(135deg,#0ea5e940,#3b82f659);color:#f8fafc;font-weight:600;box-shadow:inset 0 0 0 1px #7dd3fc66,0 8px 14px #2563eb33}.sidebar-nav button .nav-icon{font-size:20px;width:22px;text-align:center;flex-shrink:0;color:currentColor;line-height:1}.sidebar-nav button .nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav button .nav-badge{margin-left:auto;font-size:11px;border-radius:999px;padding:1px 7px;background:#ff7043;color:#fff;font-weight:700;line-height:1.4}.sidebar-nav button .nav-badge.nav-badge-urgent{background:#d32f2f;animation:navBadgePulse 1.4s ease-in-out infinite}.sidebar-footer{margin-top:6px;padding:14px 12px;border-top:1px solid rgba(148,163,184,.16);background:#0f172a8c;border-radius:14px}@media (min-width: 641px){.sidebar-footer{background:#0f172a61;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}.sidebar-footer .user-block{display:flex;align-items:center;gap:10px;margin-bottom:10px}.sidebar-footer .user-avatar{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#f97316,#fb923c);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0;overflow:hidden}.sidebar-footer .user-name{font-size:13px;color:#f8fafc;font-weight:600}.sidebar-footer .user-role{font-size:11px;color:#94a3b8}.sidebar-footer .branch-switcher{margin-bottom:10px}.sidebar-footer .branch-switcher-label{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-weight:600}.sidebar-footer .branch-buttons{display:grid;grid-template-columns:1fr 1fr;gap:6px}.sidebar-footer .branch-btn{padding:7px 4px;border-radius:8px;border:1px solid rgba(148,163,184,.25);background:#94a3b81f;color:#d1d9e6;font-size:11px;cursor:pointer;transition:all .2s;font-family:inherit;text-align:center;white-space:nowrap}.sidebar-footer .branch-btn:hover{background:#0ea5e938;border-color:#7dd3fc73;color:#f8fafc}.sidebar-footer .branch-btn.active{background:linear-gradient(135deg,#0369a1,#2563eb);border-color:transparent;color:#fff;font-weight:700;box-shadow:0 6px 12px #2563eb59}.sidebar-footer .logout-btn{width:100%;padding:10px;border:1px solid rgba(248,113,113,.42);background:#ef44441f;color:#fecaca;border-radius:10px;cursor:pointer;font-size:12px;transition:var(--transition);font-family:inherit;margin-top:4px}.sidebar-footer .logout-btn:hover{background:#ef44443d;border-color:#fca5a58f;color:#fee2e2}.sidebar-collapse-btn{display:none;width:100%;height:28px;border-radius:6px;background:#94a3b81a;border:1px solid rgba(148,163,184,.15);color:#94a3b8;cursor:pointer;padding:0;align-items:center;justify-content:center;transition:all .2s;margin-bottom:6px}.sidebar-collapse-btn:hover{background:#334155;color:#f8fafc}.sidebar-collapse-btn .material-symbols-outlined{font-size:16px}@media (min-width: 641px){.sidebar-collapse-btn{display:flex}.sidebar{transition:width .25s ease}.sidebar.collapsed{width:64px;padding:18px 6px 16px}.sidebar.collapsed .sidebar-brand{justify-content:center;padding:10px 4px 16px;gap:0}.sidebar.collapsed .brand-logo-container{width:36px;height:36px;border-radius:10px}.sidebar.collapsed .sidebar-nav button{justify-content:center;padding:10px 0;gap:0}.sidebar.collapsed .sidebar-nav button .nav-icon{font-size:22px;margin:0}.sidebar.collapsed .sidebar-footer{padding:10px 4px}.sidebar.collapsed .sidebar-footer .user-block{justify-content:center;margin-bottom:0}.sidebar.collapsed .sidebar-footer .user-name,.sidebar.collapsed .sidebar-footer .user-role,.sidebar.collapsed .sidebar-footer .user-role-hint,.sidebar.collapsed .sidebar-footer .branch-switcher,.sidebar.collapsed .sidebar-footer .theme-switcher-label{display:none}.sidebar.collapsed .nav-group{border:none;padding:0;margin:0}.sidebar.collapsed .nav-group-list{gap:2px}.sidebar-is-collapsed .main-content{margin-left:64px;max-width:calc(100vw - 64px)}}.mobile-bottom-nav,.more-overlay,.more-sheet{display:none}@media (max-width: 640px){.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:#1e293b;z-index:10000;box-shadow:0 -2px 12px #0000002e;justify-content:space-around;align-items:stretch;will-change:transform;transform:translateZ(0)}.mob-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;background:none;border:none;color:#94a3b8;font-family:inherit;cursor:pointer;position:relative;padding:4px 0;transition:color .15s;-webkit-tap-highlight-color:transparent}.mob-tab.active{color:#f8fafc}.mob-tab.active:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:#3b82f6}.mob-tab-icon{font-size:22px}.mob-tab-label{font-size:10px;font-weight:500;white-space:nowrap}.mob-tab-badge{position:absolute;top:2px;right:calc(50% - 18px);font-size:9px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-weight:700;line-height:1.4;min-width:14px;text-align:center}.more-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:10001}.more-sheet{display:block;position:fixed;bottom:0;left:0;right:0;background:#1e293b;border-radius:16px 16px 0 0;z-index:10002;max-height:70vh;max-height:70dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 16px 24px;transform:translate3d(0,100%,0);transition:transform .3s ease;will-change:transform}.more-sheet.open{transform:translateZ(0)}.more-sheet-handle{width:36px;height:4px;background:#94a3b866;border-radius:2px;margin:4px auto 12px;cursor:pointer}.more-sheet-title{font-size:14px;font-weight:700;color:#f8fafc;margin-bottom:12px}.more-group{margin-bottom:14px}.more-group-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.more-group-items{display:grid;grid-template-columns:1fr 1fr;gap:6px}.more-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#94a3b81a;border:1px solid rgba(148,163,184,.15);border-radius:10px;color:#cbd5e1;font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s;min-width:0}.more-item-badge{margin-left:auto;flex-shrink:0;font-size:10px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-weight:700;line-height:1.35;min-width:18px;text-align:center}.more-item:hover,.more-item:active{background:#94a3b833;color:#f8fafc}.more-item.active{background:#3b82f633;border-color:#3b82f666;color:#93c5fd;font-weight:600}.more-item .material-symbols-outlined{font-size:20px}.more-group--theme{margin-top:4px;border-top:1px solid rgba(148,163,184,.15);padding-top:12px}.more-theme-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:6px}.more-theme-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 6px;background:#94a3b81a;border:1px solid rgba(148,163,184,.18);border-radius:10px;color:var(--text-light, #94a3b8);font-size:12px;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.more-theme-btn-icon{font-size:18px;line-height:1}.more-theme-btn:hover{background:#94a3b833}.more-theme-btn.active{background:#0ea5e938;border-color:#7dd3fc73;color:#7dd3fc;font-weight:600}}.main-content{margin-left:var(--sidebar-w);flex:1;padding:28px 34px;min-height:100vh;min-height:100dvh;overflow-x:hidden;max-width:calc(100vw - var(--sidebar-w))}.page-header{margin-bottom:24px}.page-header h2{font-size:22px;font-weight:700;color:var(--text)}.page-header .page-desc{font-size:13px;color:var(--text-light);margin-top:4px}.loading-screen{height:100vh;height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:16px;color:var(--text-light)}.loading-screen .spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes navBadgePulse{0%{box-shadow:0 0 #d32f2f8c;transform:scale(1)}60%{box-shadow:0 0 0 8px #d32f2f00;transform:scale(1.06)}to{box-shadow:0 0 #d32f2f00;transform:scale(1)}}.card{background:var(--card-bg);border:none;border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:var(--shadow);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-hover)}.card h2,.card h3{font-weight:700;color:var(--text);margin-bottom:4px}.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--input-bg);font-size:14px;color:var(--text);transition:var(--transition);font-family:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #ffa72626;background:var(--input-focus-bg)}button{font-family:inherit;cursor:pointer}button.primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);color:#fff;border:none;padding:10px 22px;border-radius:8px;font-weight:600;font-size:14px;transition:var(--transition);box-shadow:0 2px 6px #ffa72640}button.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ffa72659}button.small,button.xs{padding:6px 14px;font-size:12.5px;border-radius:6px}button.xs{padding:4px 10px;font-size:11.5px}button.danger{background:var(--danger);color:#fff;border:none;padding:6px 14px;border-radius:6px;font-size:12.5px;font-weight:600}button.small.danger{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;padding:4px 10px;font-size:12px}button.small.danger:hover{background:#fee2e2;color:#991b1b}button.ghost{background:transparent;border:1px solid var(--border);color:var(--text);padding:8px 16px;border-radius:8px;font-size:13px;transition:var(--transition)}button.ghost:hover{background:var(--bg);border-color:var(--accent)}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 12px;font-size:12px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;background:#fafafa;border-bottom:2px solid var(--border)}td{padding:10px 12px;font-size:13.5px;border-bottom:1px solid #F0F0F0;color:var(--text)}tr:hover td{background:#fafafa}.badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge-red{background:var(--danger-bg);color:var(--danger);padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.badge-green{background:var(--success-bg);color:var(--success);padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.badge-orange{background:var(--warning-bg);color:var(--warning);padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.tag{background:var(--primary-bg);color:var(--primary);font-size:11px;padding:2px 8px;border-radius:4px;font-weight:500}.status-tag{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.status-tag.active{background:var(--success-bg);color:var(--success)}.status-tag.pending{background:var(--warning-bg);color:var(--warning)}.status-tag.suspended{background:var(--danger-bg);color:var(--danger)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}@media (min-width: 641px){.modal-overlay{background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--modal-bg);padding:28px;border-radius:var(--radius);width:440px;max-width:90vw;max-height:90vh;max-height:90dvh;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;box-shadow:0 20px 60px #00000026;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translate3d(0,20px,0);opacity:0}to{transform:translateZ(0);opacity:1}}.modal h3{font-size:18px;font-weight:700;margin-bottom:20px;color:var(--text)}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:13px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px}.actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.hint{font-size:13px;color:var(--text-light)}.empty-text{color:#bdbdbd;font-style:italic;font-size:14px;text-align:center;padding:24px}.checkbox-group{display:flex;flex-wrap:wrap;gap:8px}.checkbox-item{display:flex;align-items:center;gap:4px;font-weight:400;font-size:13px}.checkbox-item input[type=checkbox]{width:auto}.profile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.profile-modal{background:#fff;padding:28px;border-radius:12px;width:400px;box-shadow:0 8px 32px #0003}.profile-modal h3{margin:0 0 20px;font-size:18px;color:var(--primary)}.profile-form-group{margin-bottom:16px}.profile-form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:4px;color:#333}.profile-form-group input{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit}.profile-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.profile-msg{padding:8px 12px;border-radius:6px;font-size:13px;margin-bottom:16px}.profile-msg.error{background:#ffebee;color:#c62828}.profile-msg.success{background:#e8f5e9;color:#2e7d32}.mobile-branch-bar{display:none}@media (max-width: 900px){.mobile-branch-bar{display:flex;align-items:center;gap:12px;padding:12px 0 16px;margin-bottom:8px;border-bottom:1px solid var(--border);flex-wrap:wrap}.mobile-branch-label{font-size:14px;font-weight:600;color:var(--text);flex-shrink:0}.mobile-branch-select{flex:1;min-width:140px;max-width:280px;padding:12px 36px 12px 14px;font-size:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);color:var(--text);font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2378909C' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.mobile-branch-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg)}}@media (max-width: 900px){:root{--sidebar-w: 246px}.sidebar{padding:14px 10px 12px;border-right-color:#94a3b833}.main-content{padding:20px 18px}}@media (max-width: 768px){:root{--sidebar-w: 216px}.main-content{padding:16px 12px}}.responsive-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.responsive-table-wrap>table{min-width:600px}@media (max-width: 640px){input,select,textarea{font-size:16px!important}}button,.button-outline,[type=button]{-webkit-tap-highlight-color:transparent}@media (max-width: 640px){.hide-mobile{display:none!important}}@media (min-width: 641px){.show-mobile{display:none!important}}@media (max-width: 640px){:root{--sidebar-w: 0px}.app-layout{flex-direction:column}.sidebar{display:none!important}.main-content{margin-left:0;padding:12px 10px calc(70px + env(safe-area-inset-bottom,0px)) 10px;min-height:calc(100vh - 56px);min-height:calc(100dvh - 56px);max-width:100vw}table{font-size:12px}th,td{padding:6px 8px}.card{padding:14px;border-radius:10px}.modal-overlay{padding:0!important;align-items:flex-end}.modal{width:100%!important;max-width:100vw!important;max-height:92vh!important;max-height:92dvh!important;border-radius:16px 16px 0 0!important;overflow-y:auto}.page-header{margin-bottom:12px}.page-header h2{font-size:1.1rem}.header-actions{flex-direction:column;gap:10px;align-items:stretch}.header-buttons{flex-wrap:wrap;gap:6px}.filter-bar.grid,.grid.filter-bar{grid-template-columns:1fr!important}}@media (max-width: 768px){.course-inner-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 640px){*{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.modal-overlay{background:#00000080}.sidebar-footer{background:#0f172aa6}}body.guide-tour-open{overflow:hidden}.guide-tour-highlighted{position:relative;z-index:2147482900!important;border-radius:10px;box-shadow:0 0 0 4px #ffa726e6,0 0 0 9999px #181f268c}
