:root{--bg: #f8f7f5;--surface: #ffffff;--surface-elevated: #ffffff;--sidebar: #0f172a;--sidebar-hover: rgba(255, 255, 255, .05);--sidebar-active: rgba(255, 255, 255, .1);--text: #1e293b;--text-secondary: #64748b;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--text-inverse-secondary: rgba(255, 255, 255, .7);--primary: #1e3a5f;--primary-hover: #152a45;--primary-active: #0f1f33;--primary-subtle: rgba(30, 58, 95, .08);--accent: #c9a86c;--accent-hover: #b8975d;--accent-subtle: rgba(201, 168, 108, .12);--success: #16a34a;--success-subtle: #f0fdf4;--warning: #d97706;--warning-subtle: #fffbeb;--danger: #dc2626;--danger-subtle: #fef2f2;--info: #2563eb;--info-subtle: #eff6ff;--border: #e8e6e1;--border-strong: #d6d3cd;--border-input: #d6d3cd;--border-inverse: rgba(255, 255, 255, .1);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .06);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .08);--shadow-xl: 0 24px 56px rgba(15, 23, 42, .12);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--duration-fast: .15s;--duration-base: .25s;--duration-slow: .4s;--sidebar-width: 220px;--topbar-height: 64px}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--primary);text-decoration:none;transition:color var(--duration-fast) var(--ease-out-expo)}a:hover{color:var(--primary-hover)}.tabular{font-variant-numeric:tabular-nums;font-family:JetBrains Mono,Plus Jakarta Sans,monospace}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;border:none;border-radius:var(--radius-md);background:var(--primary);color:#fff;font-family:inherit;font-size:14px;font-weight:500;line-height:1.5;cursor:pointer;white-space:nowrap;transition:background var(--duration-fast) var(--ease-out-expo),transform var(--duration-fast) var(--ease-out-expo),box-shadow var(--duration-fast) var(--ease-out-expo)}.btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn:active:not(:disabled){background:var(--primary-active);transform:translateY(0)}.btn:disabled{background:var(--text-tertiary);cursor:not-allowed;opacity:.7}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border-input)}.btn-secondary:hover:not(:disabled){background:var(--bg);border-color:var(--border-strong);color:var(--primary)}.btn-secondary:active:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:active:not(:disabled){background:#991b1b}.btn-sm{padding:5px 12px;font-size:13px}.btn-lg{padding:10px 24px;font-size:15px}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.btn-link{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--primary);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:color var(--duration-fast) var(--ease-out-expo)}.btn-link:hover{color:var(--primary-hover);text-decoration:underline}.btn-link.danger{color:var(--danger)}.btn-link.danger:hover{color:#b91c1c}input,textarea,select{width:100%;padding:8px 12px;border:1px solid var(--border-input);border-radius:var(--radius-md);font-family:inherit;font-size:14px;color:var(--text);background:var(--surface);transition:border-color var(--duration-fast) var(--ease-out-expo),box-shadow var(--duration-fast) var(--ease-out-expo)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1e3a5f1a}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}input:disabled,textarea:disabled,select:disabled{background:var(--bg);color:var(--text-tertiary);cursor:not-allowed}textarea{resize:vertical;min-height:72px}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 256 256'%3E%3Cpath fill='%2364748b' d='M213.66 101.66l-80 80a8 8 0 0 1-11.32 0l-80-80A8 8 0 0 1 53.66 90.34L128 164.69l74.34-74.35a8 8 0 0 1 11.32 11.32z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.req{color:var(--danger)}.hint{color:var(--text-tertiary);font-weight:400;font-size:12px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;line-height:18px;white-space:nowrap}.tag-blue{background:var(--primary-subtle);color:var(--primary)}.tag-green{background:var(--success-subtle);color:var(--success)}.tag-orange{background:var(--warning-subtle);color:var(--warning)}.tag-red{background:var(--danger-subtle);color:var(--danger)}.tag-gray{background:var(--bg);color:var(--text-secondary)}.tag-gold{background:var(--accent-subtle);color:#8a6d3b}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow var(--duration-fast) var(--ease-out-expo),transform var(--duration-fast) var(--ease-out-expo)}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.tbl{width:100%;border-collapse:collapse;background:transparent;font-size:13px}.tbl th,.tbl td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.tbl th{font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.tbl tbody tr{transition:background var(--duration-fast) var(--ease-out-expo)}.tbl tbody tr:hover{background:#1e3a5f05}.tbl tbody tr.clickable{cursor:pointer}.tbl-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.tbl-responsive .tbl{min-width:720px}.page-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.01em}.section-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.cell-muted{color:var(--text-secondary)}.cell-topic{font-weight:500;color:var(--text)}.empty-state{padding:48px 24px;text-align:center;color:var(--text-secondary)}.error-state{padding:48px 24px;text-align:center;color:var(--danger)}.mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:100;display:flex;opacity:0;animation:fadeIn var(--duration-base) var(--ease-out-expo) forwards}.drawer{width:520px;max-width:92vw;background:var(--surface);height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);margin-left:auto;transform:translate(100%);animation:slideInRight var(--duration-slow) var(--ease-out-expo) forwards}.modal{width:640px;max-width:calc(100% - 32px);max-height:90vh;background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;margin:auto;transform:translateY(16px) scale(.98);opacity:0;animation:modalIn var(--duration-slow) var(--ease-out-expo) forwards}@media(max-width:640px){.modal{width:100%;max-width:100%;max-height:100dvh;border-radius:0;margin:0;transform:translateY(100%);animation:sheetUp var(--duration-slow) var(--ease-out-expo) forwards}}@keyframes fadeIn{to{opacity:1}}@keyframes slideInRight{to{transform:translate(0)}}@keyframes modalIn{to{transform:translateY(0) scale(1);opacity:1}}@keyframes sheetUp{to{transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.layout[data-v-6f3cf040]{display:flex;min-height:100vh}.sidebar[data-v-6f3cf040]{width:var(--sidebar-width);flex-shrink:0;background:var(--sidebar);color:var(--text-inverse);display:flex;flex-direction:column}.sidebar-logo[data-v-6f3cf040]{height:var(--topbar-height);display:flex;align-items:center;gap:10px;padding:0 20px;border-bottom:1px solid var(--border-inverse)}.logo-mark[data-v-6f3cf040]{width:32px;height:32px;background:var(--accent);color:var(--sidebar);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.logo-text[data-v-6f3cf040]{font-size:15px;font-weight:700;letter-spacing:-.01em}.menu[data-v-6f3cf040]{padding:12px;display:flex;flex-direction:column;gap:4px;flex:1}.menu-item[data-v-6f3cf040]{display:flex;align-items:center;gap:12px;padding:11px 14px;color:var(--text-inverse-secondary);border-radius:var(--radius-md);font-size:14px;font-weight:500;transition:color var(--duration-fast) var(--ease-out-expo),background var(--duration-fast) var(--ease-out-expo)}.menu-item[data-v-6f3cf040]:hover{color:var(--text-inverse);background:var(--sidebar-hover)}.menu-item.active[data-v-6f3cf040]{color:var(--text-inverse);background:var(--accent)}.menu-item.active[data-v-6f3cf040]:hover{background:var(--accent-hover)}.sidebar-footer[data-v-6f3cf040]{padding:16px 20px;border-top:1px solid var(--border-inverse)}.version[data-v-6f3cf040]{font-size:11px;color:var(--text-inverse-secondary)}.main[data-v-6f3cf040]{flex:1;display:flex;flex-direction:column;min-width:0}.topbar[data-v-6f3cf040]{height:var(--topbar-height);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.topbar-left[data-v-6f3cf040]{display:flex;align-items:center;gap:14px}.topbar-title[data-v-6f3cf040]{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.01em}.topbar-right[data-v-6f3cf040]{display:flex;align-items:center;gap:18px}.user-name[data-v-6f3cf040]{font-size:14px;color:var(--text-secondary);font-weight:500}.role-badge[data-v-6f3cf040]{font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--radius-pill);background:var(--primary-subtle);color:var(--primary);white-space:nowrap}.mobile-menu-btn[data-v-6f3cf040]{display:none}.content[data-v-6f3cf040]{flex:1;padding:24px;overflow:auto}.mobile-drawer-mask[data-v-6f3cf040]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:200;display:none}.mobile-drawer[data-v-6f3cf040]{width:260px;max-width:80vw;height:100%;background:var(--sidebar);color:var(--text-inverse);display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.mobile-drawer-header[data-v-6f3cf040]{display:flex;align-items:center;justify-content:space-between;padding-right:12px}.btn-icon-inverse[data-v-6f3cf040]{background:#ffffff1a;color:var(--text-inverse)}.btn-icon-inverse[data-v-6f3cf040]:hover:not(:disabled){background:#fff3}.fade-enter-active[data-v-6f3cf040],.fade-leave-active[data-v-6f3cf040]{transition:opacity var(--duration-base) var(--ease-out-expo)}.fade-enter-from[data-v-6f3cf040],.fade-leave-to[data-v-6f3cf040]{opacity:0}.modal-sm[data-v-6f3cf040]{width:420px}.modal-header[data-v-6f3cf040]{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.modal-title h3[data-v-6f3cf040]{font-size:16px;font-weight:700}.modal-sub[data-v-6f3cf040]{font-size:12px;color:var(--text-secondary);display:block}.modal-body[data-v-6f3cf040]{padding:20px 24px}.modal-footer[data-v-6f3cf040]{display:flex;justify-content:flex-end;gap:10px;padding:14px 24px;border-top:1px solid var(--border)}.pw-form[data-v-6f3cf040]{display:flex;flex-direction:column;gap:14px}.form-error[data-v-6f3cf040]{display:flex;align-items:center;gap:6px;color:var(--danger);font-size:12px}.form-success[data-v-6f3cf040]{display:flex;align-items:center;gap:6px;color:var(--success);font-size:12px}.spin[data-v-6f3cf040]{animation:spin .8s linear infinite}.topbar-right .btn-link[data-v-6f3cf040]{font-size:13px}@media(max-width:768px){.sidebar[data-v-6f3cf040]{display:none}.mobile-menu-btn[data-v-6f3cf040]{display:inline-flex}.mobile-drawer-mask[data-v-6f3cf040]{display:flex;animation:fadeIn var(--duration-base) var(--ease-out-expo) forwards}.mobile-drawer[data-v-6f3cf040]{transform:translate(-100%);animation:slideInLeft-6f3cf040 var(--duration-slow) var(--ease-out-expo) forwards}.topbar[data-v-6f3cf040]{padding:0 16px}.topbar-title[data-v-6f3cf040]{font-size:16px}.user-name[data-v-6f3cf040]{display:none}.content[data-v-6f3cf040]{padding:16px}}@keyframes slideInLeft-6f3cf040{to{transform:translate(0)}}@media(prefers-reduced-motion:reduce){.mobile-drawer[data-v-6f3cf040]{transform:none;animation:none}.mobile-drawer-mask[data-v-6f3cf040]{animation:none;opacity:1}}
