.bottom-nav[data-v-f03d46f9]{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;justify-content:space-around;align-items:center;height:64px;background-color:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(0,0,0,.06);box-shadow:0 -8px 20px #0000000d}.nav-item[data-v-f03d46f9]{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#8a8f98;text-decoration:none;font-size:12px;padding:6px 10px;border-radius:12px;transition:color .2s ease,background-color .2s ease}.icon[data-v-f03d46f9]{width:22px;height:22px;margin-bottom:4px}.router-link-exact-active[data-v-f03d46f9]{color:#14161a;background-color:#14161a0f}.publish[data-v-f03d46f9]{color:#fff;background-color:#111827;box-shadow:0 10px 22px #1118272e,inset 0 -1px #ffffff14}.publish .icon[data-v-f03d46f9]{margin-bottom:2px}.rolling-announcement[data-v-35c6e2d5]{background-color:#fff7ed;color:#c2410c;padding:8px 12px;border-bottom:1px solid #ffedd5;font-size:14px;overflow:hidden;position:relative;z-index:99}.content-wrapper[data-v-35c6e2d5]{display:flex;align-items:center;max-width:480px;margin:0 auto}.icon[data-v-35c6e2d5]{margin-right:8px;flex-shrink:0}.text-container[data-v-35c6e2d5]{flex:1;overflow:hidden;white-space:nowrap}.scrolling-text[data-v-35c6e2d5]{display:inline-block;animation:scroll-left-35c6e2d5 20s linear infinite;padding-left:100%}@keyframes scroll-left-35c6e2d5{0%{transform:translate(0)}to{transform:translate(-100%)}}.modal-overlay[data-v-f593bdba]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content[data-v-f593bdba]{background:white;border-radius:12px;width:100%;max-width:320px;box-shadow:0 4px 12px #00000026;overflow:hidden;animation:modal-pop-f593bdba .3s ease-out}@keyframes modal-pop-f593bdba{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-header[data-v-f593bdba]{padding:16px 20px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.modal-header h3[data-v-f593bdba]{margin:0;font-size:18px;color:#333}.close-btn[data-v-f593bdba]{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;line-height:1}.modal-body[data-v-f593bdba]{padding:20px;color:#666;font-size:15px;line-height:1.6;max-height:60vh;overflow-y:auto}.announcement-list ul[data-v-f593bdba]{margin:0;padding-left:20px}.announcement-list li[data-v-f593bdba]{margin-bottom:8px}.announcement-list li[data-v-f593bdba]:last-child{margin-bottom:0}.modal-footer[data-v-f593bdba]{padding:16px 20px;border-top:1px solid #f0f0f0;text-align:right}.btn-confirm[data-v-f593bdba]{background:#f53f3f;color:#fff;border:none;padding:8px 20px;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.btn-confirm[data-v-f593bdba]:active{background:#d62f2f}:root{--app-bg: #f4f6f8}body{margin:0;background-color:#e0e0e0}.app{min-height:100vh;background-color:var(--app-bg);max-width:480px;margin:0 auto;box-shadow:0 0 24px #0000001a;position:relative}.app.admin-mode{max-width:100%;box-shadow:none;margin:0}.main{padding-bottom:0}.app-toast[data-v-129fc426]{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);max-width:380px;pointer-events:auto;border-left:4px solid var(--color-border)}.app-toast--success[data-v-129fc426]{border-left-color:var(--color-success, #10B981)}.app-toast--error[data-v-129fc426]{border-left-color:var(--color-danger, #EF4444)}.app-toast--warning[data-v-129fc426]{border-left-color:var(--color-warning, #F59E0B)}.app-toast--info[data-v-129fc426]{border-left-color:var(--color-text-muted, #6B7280)}.app-toast-icon[data-v-129fc426]{flex-shrink:0;display:flex;align-items:center;padding-top:1px}.app-toast--success .app-toast-icon[data-v-129fc426]{color:#10b981}.app-toast--error .app-toast-icon[data-v-129fc426]{color:#ef4444}.app-toast--warning .app-toast-icon[data-v-129fc426]{color:#f59e0b}.app-toast--info .app-toast-icon[data-v-129fc426]{color:#6b7280}.app-toast-msg[data-v-129fc426]{flex:1;font-size:14px;line-height:1.5;color:var(--color-text-main);word-break:break-word}.app-toast-close[data-v-129fc426]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);padding:0;box-shadow:none}.app-toast-close[data-v-129fc426]:hover{background:var(--color-bg-hover);color:var(--color-text-main)}.app-toast-enter-active[data-v-129fc426],.app-toast-leave-active[data-v-129fc426]{transition:opacity 0ms}.app-toast-enter-from[data-v-129fc426],.app-toast-leave-to[data-v-129fc426]{opacity:0}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--color-bg: #FFFFFF;--color-bg-subtle: #F9FAFB;--color-bg-hover: #F3F4F6;--color-text-main: #111827;--color-text-muted: #6B7280;--color-border: #E5E7EB;--color-primary: #000000;--color-primary-hover: #333333;--color-primary-text: #FFFFFF;--color-danger: #EF4444;--color-danger-bg: #FEF2F2;--color-danger-text: #991B1B;--color-success: #10B981;--color-success-bg: #D1FAE5;--color-success-text: #065F46;--color-warning: #F59E0B;--color-warning-bg: #FEF3C7;--color-warning-text: #92400E;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-base: .2s ease-out;--transition-slow: .3s ease-out;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--overlay-bg: rgba(0, 0, 0, .3)}body{font-family:var(--font-sans);color:var(--color-text-main);background-color:var(--color-bg);margin:0;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-weight:600;letter-spacing:-.025em;margin-top:0}button,.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;font-size:14px;font-weight:500;border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:#fff;color:var(--color-text-main);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm);line-height:1.5}button:hover,.btn:hover{background-color:var(--color-bg-hover);border-color:#d1d5db}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-primary-text);border-color:transparent}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-danger{color:var(--color-danger);border-color:var(--color-border)}.btn-danger:hover{background-color:var(--color-danger-bg);border-color:var(--color-danger-bg)}.btn-sm{padding:4px 10px;font-size:12px}.table-actions,.action-buttons{display:inline-flex;align-items:center;gap:8px;flex-wrap:nowrap;white-space:nowrap}input,select,textarea{display:block;width:100%;padding:8px 12px;font-size:14px;line-height:1.5;color:var(--color-text-main);background-color:#fff;background-clip:padding-box;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;box-sizing:border-box}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0000001a}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{text-align:left;padding:12px 16px;border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-weight:500;background-color:var(--color-bg-subtle)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--color-border);color:var(--color-text-main)}.data-table td[data-label=操作]{white-space:nowrap}.data-table tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:12px;font-weight:500;border-radius:9999px;line-height:1.5}.badge.success{background-color:var(--color-success-bg);color:var(--color-success-text)}.badge.warn{background-color:var(--color-warning-bg);color:var(--color-warning-text)}.badge.danger{background-color:var(--color-danger-bg);color:var(--color-danger-text)}.badge.info{background-color:var(--color-bg-subtle);color:var(--color-text-muted);border:1px solid var(--color-border)}.page-container{padding:32px;max-width:100%;margin:0 auto}.header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header-actions h3{margin:0;font-size:20px}.table-container{background:white;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto;box-shadow:var(--shadow-sm)}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:180px;padding:24px;text-align:center;color:var(--color-text-muted)}.loading-state-panel,.error-state-panel,.empty-state-panel{background:white;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.error-state{color:var(--color-danger-text)}.empty-state{color:var(--color-text-muted)}.spinner{width:28px;height:28px;border:3px solid rgba(17,24,39,.12);border-top-color:var(--color-primary);border-radius:50%;animation:app-spinner-rotate .8s linear infinite}@keyframes app-spinner-rotate{to{transform:rotate(360deg)}}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:6px;background:transparent;border:1px solid transparent;color:var(--color-text-muted);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.btn-icon:hover{background-color:var(--color-bg-hover);color:var(--color-text-main)}.btn-icon svg{display:block;width:16px;height:16px}.btn-icon.edit:hover{color:var(--color-primary);background-color:var(--color-bg-hover)}.btn-icon.delete:hover{color:var(--color-danger);background-color:var(--color-danger-bg)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:white;padding:24px;border-radius:var(--radius-lg);width:500px;max-width:90%;box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.modal h3{margin-top:0;margin-bottom:16px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:var(--color-text-main)}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}*:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-bg),0 0 0 4px var(--color-primary)}.badge--success{background:#D1FAE5;color:#065f46}.badge--warning{background:#FEF3C7;color:#92400e}.badge--danger{background:#FEF2F2;color:#991b1b}.badge--active{background:#DBEAFE;color:#1d4ed8}.badge--inactive{background:#F3F4F6;color:#6b7280}.badge--pending{background:#FEF3C7;color:#92400e}.transition-colors{transition:color var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast)}.desktop-only{display:block}.mobile-only{display:none}.fab{position:fixed;bottom:80px;right:20px;width:52px;height:52px;border-radius:50%;background:var(--color-primary);color:var(--color-primary-text);border:none;box-shadow:0 4px 12px #00000040;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:24px;z-index:100;transition:transform var(--transition-fast),box-shadow var(--transition-fast);padding:0;line-height:1}.fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #0000004d}.fab:active{transform:scale(.95)}.search-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:white;cursor:pointer;color:var(--color-text-muted);padding:0;box-shadow:var(--shadow-sm);flex-shrink:0}.search-toggle:hover{background:var(--color-bg-hover)}.search-panel{overflow:hidden;max-height:0;transition:max-height .3s ease-out,opacity .2s ease-out;opacity:0}.search-panel.open{max-height:400px;opacity:1}.skeleton-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px;background:white}.skeleton-line{height:14px;border-radius:4px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;margin-bottom:12px}.skeleton-line:last-child{margin-bottom:0}.skeleton-line.w60{width:60%}.skeleton-line.w40{width:40%}.skeleton-line.w80{width:80%}.skeleton-line.h24{height:24px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 768px){.desktop-only{display:none!important}.mobile-only{display:block!important}.fab,.search-toggle{display:flex}.page-container{padding:12px}.data-table thead{display:none}.data-table tbody{display:flex;flex-direction:column;gap:10px}.data-table tr{display:flex;flex-wrap:wrap;margin-bottom:0;border:1px solid var(--color-border);border-radius:10px;box-shadow:0 1px 3px #0000000a;padding:14px;gap:4px 0}.data-table td{display:flex;flex-direction:column;padding:6px 0;border-bottom:none;font-size:14px;width:50%;gap:2px}.data-table td:before{content:attr(data-label);font-weight:500;font-size:11px;color:var(--color-text-muted);margin-right:0;letter-spacing:.02em}.data-table td[data-label=操作]{width:100%;flex-direction:row;justify-content:flex-end;align-items:center;border-top:1px solid var(--color-border);margin-top:8px;padding-top:10px;gap:8px}.data-table td[data-label=操作]:before{display:none}.data-table td[data-label=操作] .table-actions,.data-table td[data-label=操作] .action-buttons{width:100%;display:flex;gap:8px}.data-table td[data-label=操作] .table-actions button,.data-table td[data-label=操作] .action-buttons button{flex:1;min-height:38px;font-size:13px;font-weight:500}.pagination{gap:8px!important;flex-wrap:wrap}.pagination button{min-height:40px;min-width:40px;padding:8px 16px!important;font-size:13px!important}.pagination .page-info{width:100%;text-align:center;order:-1;font-size:12px!important}.pagination .page-jump{width:100%;justify-content:center}.header-actions{flex-direction:column;align-items:stretch!important;gap:8px!important}.header-actions h3{font-size:17px}.app-modal-body{padding:16px!important}.app-modal-header{padding:14px 16px!important}.app-modal-footer{padding:12px 16px!important}.form-grid{grid-template-columns:1fr!important}input,select,textarea{min-height:44px}}
