: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);color:#fff;transform:translateY(0)}.btn:disabled{background:var(--text-tertiary);color:#fff;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(--bg);border-color:var(--primary);color:var(--primary);transform:translateY(0)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c;color:#fff}.btn-danger:active:not(:disabled){background:#991b1b;color:#fff;transform:translateY(0)}.btn-dev{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;border:1px dashed var(--border-strong);border-radius:var(--radius-md);background:var(--bg);color:var(--text);font-family:inherit;font-size:13px;font-weight:500;line-height:1.5;cursor:pointer;transition:background var(--duration-fast) var(--ease-out-expo),border-color var(--duration-fast) var(--ease-out-expo),color var(--duration-fast) var(--ease-out-expo)}.btn-dev:hover:not(:disabled){border-color:var(--primary);background:var(--primary-subtle);color:var(--primary)}.btn-dev:active:not(:disabled){border-color:var(--primary);background:var(--primary-subtle);color:var(--primary-hover);transform:translateY(0)}.btn-dev:disabled{opacity:.55;cursor:not-allowed;color:var(--text-tertiary);background:var(--bg)}.btn-sm{padding:5px 12px;font-size:13px}.btn-lg{padding:10px 24px;font-size:15px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;padding:0;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background var(--duration-fast) var(--ease-out-expo),color var(--duration-fast) var(--ease-out-expo),border-color var(--duration-fast) var(--ease-out-expo)}.btn-icon:hover:not(:disabled){background:var(--primary-subtle);color:var(--primary);border-color:var(--border)}.btn-icon:active:not(:disabled){background:var(--primary-subtle);color:var(--primary-hover);border-color:var(--primary);transform:none}.btn-icon:disabled{opacity:.45;cursor:not-allowed}.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:active{color:var(--primary-active)}.btn-link.danger{color:var(--danger)}.btn-link.danger:hover{color:#b91c1c}.btn-link.danger:active{color:#991b1b}.period-btn,.preset-btn{-webkit-tap-highlight-color:transparent}.period-btn:active:not(:disabled):not(.active),.preset-btn:active:not(:disabled):not(.active){background:var(--primary-subtle);color:var(--primary);border-color:var(--primary)}.period-btn.active:active:not(:disabled),.preset-btn.active:active:not(:disabled){background:var(--primary-hover);color:#fff;border-color:var(--primary-hover)}.period-btn:disabled,.period-btn.unavailable{opacity:.45;cursor:not-allowed}.period-btn:disabled:hover,.period-btn.unavailable:hover{border-color:var(--border);color:var(--text-secondary);background:var(--surface)}.toggle-btn:active:not(.active){background:var(--bg);color:var(--text)}.toggle-btn.active:active{background:var(--primary-hover);color:#fff}button,[role=button]{-webkit-tap-highlight-color:transparent}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}@media(max-width:768px){.drawer{width:100%;max-width:100%}.card{padding:16px}.tbl th,.tbl td{padding:10px 12px}}.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)}@media(max-width:768px){#app{-webkit-tap-highlight-color:transparent}#app .card{padding:16px}#app .table-card{padding:0}#app .page-header{flex-direction:column;align-items:stretch;gap:12px}#app .page-header>.btn,#app .page-header-actions .btn{width:100%;justify-content:center}#app .page-header-title{gap:8px}#app .page-header-title svg{display:none}#app .page-header-meta .page-desc{font-size:12px;line-height:1.55}#app .page-hint{width:100%;font-size:12px;line-height:1.5}#app .page-title{font-size:16px}#app .stats{grid-template-columns:repeat(2,1fr);gap:10px}#app .stat-card{padding:14px 16px}#app .stat-num{font-size:24px}#app .filters,#app .card.filters{display:flex;flex-direction:column;align-items:stretch;gap:12px}#app .filter-field,#app .filter-grow,#app .filter-bool,#app .filter-field input,#app .filter-field select,#app .filter-grow input{width:100%;min-width:0}#app .filter-actions{display:flex;width:100%;gap:8px}#app .filter-actions .btn{flex:1;min-height:44px}#app .toggle-group{display:flex;width:100%}#app .toggle-btn{flex:1;min-height:44px;justify-content:center}#app .form-grid,#app .form-toggles{grid-template-columns:1fr}#app .form-grid .full-width{grid-column:auto}#app .form-header{flex-direction:column;gap:10px}#app .form-header-icon{display:none}#app .form-card{padding:20px 16px}#app .form-actions{flex-direction:column;align-items:stretch;gap:10px}#app .form-actions .btn{width:100%;min-height:44px}#app .result-actions{flex-direction:column;align-items:stretch}#app .result-actions .btn{width:100%}#app .period-btns{gap:8px}#app .period-btn{min-height:44px;padding:10px 14px;flex:1 1 calc(50% - 4px);min-width:calc(50% - 4px);justify-content:center;text-align:center}#app .attendee-header{flex-direction:column;align-items:stretch;gap:6px}#app .user-multi-search .search-panel{max-height:220px}#app .user-multi-search .chip-name{max-width:120px}#app .detail-layout{grid-template-columns:1fr;gap:16px}#app .detail-header{flex-direction:column;align-items:stretch;gap:12px}#app .detail-actions{display:flex;width:100%;gap:8px}#app .detail-actions .btn{flex:1;min-height:44px}#app .detail-grid{grid-template-columns:1fr}#app .read-row{flex-direction:column;align-items:flex-start;gap:4px}#app .tbl-responsive{margin:0 -16px;padding:0 16px 4px;scroll-padding:16px}#app .tbl-responsive:after{content:"← 左右滑动查看更多 →";display:block;text-align:center;font-size:11px;color:var(--text-tertiary);padding:8px 0 4px}#app .tbl th,#app .tbl td{padding:10px 12px}#app .cell-actions{display:flex;flex-direction:column;align-items:flex-start;gap:4px;white-space:nowrap}#app .cell-actions .btn-link{min-height:36px;padding:4px 0}#app .cell-topic,#app .cell-content{max-width:200px}#app .pagination{flex-direction:column;align-items:stretch;gap:12px;padding:12px 16px}#app .page-info{text-align:center}#app .page-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:8px}#app .page-actions .btn{min-height:44px;flex:1;min-width:0}#app .page-size{width:100%;min-height:44px}#app .drawer{width:100%;max-width:100%}#app .drawer-header{padding:14px 16px}#app .drawer-body{padding:16px}#app .drawer-sub{max-width:100%;white-space:normal;word-break:break-word}#app .modal-header,#app .modal-body,#app .modal-footer{padding-left:16px;padding-right:16px}#app .modal-footer{flex-direction:column-reverse;align-items:stretch;gap:8px}#app .modal-footer .btn{width:100%;min-height:44px;margin:0}#app .modal-sm{width:100%;max-width:100%}#app .welcome{flex-direction:column;align-items:flex-start;gap:8px}#app .quick-grid{grid-template-columns:1fr}#app .quick-card{min-height:56px;padding:16px}#app .recent-item{flex-direction:column;align-items:flex-start;gap:8px}#app .recent-topic{max-width:100%}#app .sync-card{padding:20px 16px}#app .btn:not(.btn-sm){min-height:44px}#app .btn-icon{min-width:44px;min-height:44px}#app input,#app textarea,#app select{min-height:44px;font-size:16px}#app textarea{min-height:88px}#app .login-page{padding:16px;align-items:flex-start;padding-top:max(48px,env(safe-area-inset-top,48px));min-height:100dvh}#app .login-card{padding:28px 20px}#app .login-header h1{font-size:20px}#app .apps{grid-template-columns:1fr}#app .app-card{min-height:56px}}@media(max-width:480px){#app .stats{grid-template-columns:1fr 1fr}#app .cell-topic,#app .cell-content{max-width:140px}#app .period-btn{flex:1 1 100%;min-width:100%}#app .tbl-responsive:after{font-size:10px}#app .topbar-right .btn-link span,#app .role-badge{display:none}#app .topbar-title{font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}}@supports (padding: env(safe-area-inset-bottom)){@media(max-width:768px){#app .content{padding-bottom:calc(16px + env(safe-area-inset-bottom))}#app .modal,#app .drawer{padding-bottom:env(safe-area-inset-bottom)}#app .topbar{padding-left:calc(16px + env(safe-area-inset-left));padding-right:calc(16px + env(safe-area-inset-right))}}}.layout[data-v-4262cd56]{display:flex;min-height:100vh}.sidebar[data-v-4262cd56]{width:var(--sidebar-width);flex-shrink:0;background:var(--sidebar);color:var(--text-inverse);display:flex;flex-direction:column}.sidebar-logo[data-v-4262cd56]{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-4262cd56]{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-4262cd56]{font-size:15px;font-weight:700;letter-spacing:-.01em}.menu[data-v-4262cd56]{padding:12px;display:flex;flex-direction:column;gap:4px;flex:1}.menu-item[data-v-4262cd56]{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-4262cd56]:hover{color:var(--text-inverse);background:var(--sidebar-hover)}.menu-item.active[data-v-4262cd56]{color:var(--text-inverse);background:var(--accent)}.menu-item.active[data-v-4262cd56]:hover{background:var(--accent-hover)}.sidebar-footer[data-v-4262cd56]{padding:16px 20px;border-top:1px solid var(--border-inverse)}.version[data-v-4262cd56]{font-size:11px;color:var(--text-inverse-secondary)}.main[data-v-4262cd56]{flex:1;display:flex;flex-direction:column;min-width:0}.topbar[data-v-4262cd56]{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-4262cd56]{display:flex;align-items:center;gap:14px}.topbar-title[data-v-4262cd56]{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.01em}.topbar-right[data-v-4262cd56]{display:flex;align-items:center;gap:18px}.user-name[data-v-4262cd56]{font-size:14px;color:var(--text-secondary);font-weight:500}.role-badge[data-v-4262cd56]{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-4262cd56]{display:none}.content[data-v-4262cd56]{flex:1;padding:24px;overflow:auto}.mobile-drawer-mask[data-v-4262cd56]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:200;display:none}.mobile-drawer[data-v-4262cd56]{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-4262cd56]{display:flex;align-items:center;justify-content:space-between;padding-right:12px}.btn-icon-inverse[data-v-4262cd56]{background:#ffffff1a;color:var(--text-inverse);border-color:transparent}.btn-icon-inverse[data-v-4262cd56]:hover:not(:disabled){background:#fff3;color:var(--text-inverse);border-color:transparent}.btn-icon-inverse[data-v-4262cd56]:active:not(:disabled){background:#ffffff3d;color:var(--text-inverse);border-color:transparent}.fade-enter-active[data-v-4262cd56],.fade-leave-active[data-v-4262cd56]{transition:opacity var(--duration-base) var(--ease-out-expo)}.fade-enter-from[data-v-4262cd56],.fade-leave-to[data-v-4262cd56]{opacity:0}.topbar-right .btn-link[data-v-4262cd56]{font-size:13px}@media(max-width:768px){.sidebar[data-v-4262cd56]{display:none}.mobile-menu-btn[data-v-4262cd56]{display:inline-flex}.mobile-drawer-mask[data-v-4262cd56]{display:flex;animation:fadeIn var(--duration-base) var(--ease-out-expo) forwards}.mobile-drawer[data-v-4262cd56]{transform:translate(-100%);animation:slideInLeft-4262cd56 var(--duration-slow) var(--ease-out-expo) forwards}.topbar[data-v-4262cd56]{padding:0 16px;gap:8px}.topbar-left[data-v-4262cd56]{min-width:0;flex:1}.topbar-title[data-v-4262cd56]{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-right[data-v-4262cd56]{gap:8px;flex-shrink:0}.user-name[data-v-4262cd56]{display:none}.content[data-v-4262cd56]{padding:16px}}@media(max-width:480px){.topbar-right .btn-link span[data-v-4262cd56],.role-badge[data-v-4262cd56]{display:none}.topbar-title[data-v-4262cd56]{font-size:15px;max-width:140px}}@keyframes slideInLeft-4262cd56{to{transform:translate(0)}}@media(prefers-reduced-motion:reduce){.mobile-drawer[data-v-4262cd56]{transform:none;animation:none}.mobile-drawer-mask[data-v-4262cd56]{animation:none;opacity:1}}
