:root{--c-bg: #f8f9fb;--c-surface: #ffffff;--c-sidebar: #1e293b;--c-sidebar-hover: #334155;--c-sidebar-active: #0d9488;--c-border: #e2e8f0;--c-border-strong: #cbd5e1;--c-text: #1e293b;--c-text-secondary: #64748b;--c-text-muted: #94a3b8;--c-text-inverse: #ffffff;--c-primary: #0d9488;--c-primary-hover: #0f766e;--c-primary-light: #f0fdfa;--c-danger: #ef4444;--c-danger-hover: #dc2626;--c-danger-light: #fef2f2;--c-warning: #f59e0b;--c-success: #22c55e;--c-info: #3b82f6;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--font: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Segoe UI", system-ui, sans-serif;--sidebar-w: 240px;--topbar-h: 56px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:15px;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);line-height:1.6;min-height:100vh}a{color:var(--c-primary);text-decoration:none}button{font:inherit;cursor:pointer}input,textarea,select{font:inherit}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f4a45,#0d9488 40%,#14b8a6);padding:2rem}.login-card{background:var(--c-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:2.5rem;width:100%;max-width:400px}.login-card h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem;color:var(--c-text)}.login-card p{font-size:.85rem;color:var(--c-text-secondary);margin-bottom:1.5rem}.login-error{background:var(--c-danger-light);color:var(--c-danger);padding:.6rem .75rem;border-radius:var(--r-sm);font-size:.8rem;margin-bottom:1rem}.admin-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--c-sidebar);color:var(--c-text-inverse);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;height:var(--topbar-h);border-bottom:1px solid rgba(255,255,255,.1);font-size:1.05rem;font-weight:700}.sidebar-brand svg{width:24px;height:24px;flex-shrink:0}.sidebar-nav{flex:1;padding:.75rem 0}.sidebar-section{padding:.5rem 1.25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;color:#fff6;letter-spacing:.05em;margin-top:.5rem}.sidebar-item{display:flex;align-items:center;gap:.6rem;padding:.55rem 1.25rem;font-size:.85rem;color:#ffffffb3;transition:all .15s;border:none;background:none;width:100%;text-align:left}.sidebar-item:hover{background:var(--c-sidebar-hover);color:var(--c-text-inverse)}.sidebar-item.active{background:var(--c-sidebar-active);color:var(--c-text-inverse);font-weight:600}.sidebar-item svg{width:16px;height:16px;flex-shrink:0}.sidebar-footer{padding:.75rem 1.25rem;border-top:1px solid rgba(255,255,255,.1)}.main-area{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{height:var(--topbar-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:flex-end;padding:0 1.5rem;gap:1rem;position:sticky;top:0;z-index:50}.topbar-user{font-size:.85rem;color:var(--c-text-secondary)}.topbar-btn{padding:.4rem .75rem;border-radius:var(--r-sm);font-size:.8rem;border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text-secondary);transition:all .15s}.topbar-btn:hover{border-color:var(--c-danger);color:var(--c-danger)}.content{padding:1.5rem;flex:1}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.page-header h2{font-size:1.35rem;font-weight:700}.page-header-actions{display:flex;gap:.5rem;align-items:center}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--r-sm);font-size:.85rem;font-weight:500;border:1px solid transparent;transition:all .15s;white-space:nowrap}.btn svg{width:14px;height:14px}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover{background:var(--c-primary-hover)}.btn-outline{background:var(--c-surface);color:var(--c-text-secondary);border-color:var(--c-border)}.btn-outline:hover{border-color:var(--c-border-strong);color:var(--c-text)}.btn-danger{background:var(--c-danger);color:#fff}.btn-danger:hover{background:var(--c-danger-hover)}.btn-sm{padding:.3rem .6rem;font-size:.78rem}.btn-lg{padding:.65rem 1.25rem;font-size:.9rem}.btn-icon{padding:.4rem;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);padding:1.25rem}.stat-card-label{font-size:.75rem;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.35rem}.stat-card-value{font-size:1.75rem;font-weight:700;color:var(--c-text)}.stat-card-sub{font-size:.78rem;color:var(--c-text-secondary);margin-top:.25rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md)}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--c-border);font-weight:600;font-size:.9rem;display:flex;align-items:center;justify-content:space-between}.card-body{padding:1.25rem}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}thead{background:var(--c-bg)}th{padding:.7rem .85rem;text-align:left;font-weight:600;font-size:.78rem;color:var(--c-text-secondary);border-bottom:2px solid var(--c-border);white-space:nowrap}td{padding:.65rem .85rem;border-bottom:1px solid var(--c-border)}tr:hover{background:var(--c-primary-light)}.table-actions{display:flex;gap:.35rem}.toolbar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.search-input{padding:.5rem .75rem;border:1px solid var(--c-border);border-radius:var(--r-sm);font-size:.85rem;width:240px;outline:none}.search-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #0d94881a}.filter-select{padding:.5rem .75rem;border:1px solid var(--c-border);border-radius:var(--r-sm);font-size:.85rem;background:var(--c-surface);outline:none}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--c-text-secondary);margin-bottom:.35rem}.form-label .required{color:var(--c-danger)}.form-input,.form-textarea,.form-select{width:100%;padding:.55rem .75rem;border:1px solid var(--c-border);border-radius:var(--r-sm);font-size:.85rem;outline:none;transition:border-color .15s}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #0d94881a}.form-textarea{min-height:100px;resize:vertical}.form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.form-hint{font-size:.75rem;color:var(--c-text-muted);margin-top:.25rem}.form-actions{display:flex;gap:.5rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--c-border);margin-top:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:3rem 1rem 1rem;overflow-y:auto}.modal{background:var(--c-surface);border-radius:var(--r-lg);box-shadow:0 8px 30px #00000026;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-lg{max-width:900px}.modal-header{padding:1rem 1.5rem;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--c-surface);z-index:1}.modal-header h3{font-size:1.05rem;font-weight:700}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--c-border);border-radius:var(--r-sm);background:var(--c-surface);font-size:1.2rem;color:var(--c-text-secondary);cursor:pointer}.modal-close:hover{background:var(--c-bg);color:var(--c-text)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--c-border);display:flex;justify-content:flex-end;gap:.5rem}.pagination{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-top:1.5rem}.pagination button{padding:.4rem .65rem;border:1px solid var(--c-border);border-radius:var(--r-sm);background:var(--c-surface);font-size:.8rem;color:var(--c-text-secondary);min-width:34px;text-align:center;cursor:pointer}.pagination button:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.pagination button.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.pagination button:disabled{opacity:.35;cursor:default}.badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:var(--r-sm);font-size:.7rem;font-weight:600;white-space:nowrap}.badge-green{background:#dcfce7;color:#166534}.badge-red{background:#fee2e2;color:#991b1b}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:#f1f5f9;color:#475569}.badge-teal{background:#ccfbf1;color:#115e59}.toast-container{position:fixed;top:1rem;right:1rem;z-index:300;display:flex;flex-direction:column;gap:.5rem}.toast{padding:.75rem 1rem;border-radius:var(--r-sm);font-size:.85rem;box-shadow:var(--shadow-md);animation:slideIn .25s ease;max-width:360px}.toast-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.toast-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.toast-info{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--c-text-muted)}.empty-state svg{width:48px;height:48px;margin-bottom:.75rem;opacity:.4}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:200px}.import-preview{max-height:300px;overflow-y:auto;margin:1rem 0;border:1px solid var(--c-border);border-radius:var(--r-sm)}.import-preview table{font-size:.78rem}@media(max-width:1024px){.stat-grid,.detail-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sidebar{width:60px}.sidebar-brand span,.sidebar-section,.sidebar-item span,.sidebar-footer span{display:none}.sidebar-item{justify-content:center;padding:.55rem 0}.main-area{margin-left:60px}:root{--sidebar-w:60px}.page-header{flex-direction:column;align-items:flex-start}.stat-grid,.form-row{grid-template-columns:1fr}.toolbar{flex-direction:column;align-items:stretch}.search-input{width:100%}.table-wrap{font-size:.78rem}.modal{margin:1rem;max-height:85vh}}
