.notif-wrap[data-v-593ebf07]{position:relative}.notif-bell-ico[data-v-593ebf07]{font-size:15px;line-height:1;opacity:.7;transition:var(--trans)}.topbar-icon-btn:hover .notif-bell-ico[data-v-593ebf07],.topbar-icon-btn.has-unread .notif-bell-ico[data-v-593ebf07]{opacity:1}.notif-badge[data-v-593ebf07]{position:absolute;top:4px;right:4px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;line-height:1;padding:2px 4px;border-radius:10px;min-width:16px;text-align:center;pointer-events:none}.notif-dropdown[data-v-593ebf07]{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:9999;overflow:hidden}.notif-dropdown-header[data-v-593ebf07]{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.notif-dropdown-title[data-v-593ebf07]{font-weight:600;font-size:13px}.notif-empty[data-v-593ebf07]{padding:24px 16px;text-align:center;font-size:13px;color:var(--text3)}.notif-list[data-v-593ebf07]{max-height:360px;overflow-y:auto}.notif-item[data-v-593ebf07]{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s}.notif-item[data-v-593ebf07]:last-child{border-bottom:none}.notif-item[data-v-593ebf07]:hover{background:var(--bg2)}.notif-item.unread[data-v-593ebf07]{background:var(--primary-soft)}.notif-item.unread[data-v-593ebf07]:hover{background:#e3f0ff}.notif-icon[data-v-593ebf07]{font-size:18px;flex-shrink:0;margin-top:1px}.notif-body[data-v-593ebf07]{flex:1;min-width:0}.notif-title[data-v-593ebf07]{font-weight:600;font-size:12.5px;color:var(--text)}.notif-sub[data-v-593ebf07]{font-size:11.5px;color:var(--text3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-time[data-v-593ebf07]{font-size:11px;color:var(--muted);margin-top:3px}.notif-del[data-v-593ebf07]{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--muted);font-size:12px;padding:2px 4px;border-radius:4px;opacity:0;transition:opacity .15s}.notif-item:hover .notif-del[data-v-593ebf07]{opacity:1}.notif-del[data-v-593ebf07]:hover{background:var(--danger-soft);color:var(--danger)}.dropdown-enter-active[data-v-593ebf07],.dropdown-leave-active[data-v-593ebf07]{transition:opacity .15s,transform .15s}.dropdown-enter-from[data-v-593ebf07],.dropdown-leave-to[data-v-593ebf07]{opacity:0;transform:translateY(-8px)}:root{--bg: #f5f8fa;--bg2: #eef2f7;--surface: #ffffff;--surface2: #f9fafb;--surface3: #f1f4f9;--border: #e8edf3;--border2: #d1dae8;--text: #1e2129;--text2: #3f4254;--text3: #6c7293;--muted: #99a1b7;--primary: #3e97ff;--primary-soft: #eff6ff;--primary-dark: #1a73e8;--success: #17c653;--success-soft: #e9faf0;--success-dark: #0ea144;--danger: #f8285a;--danger-soft: #fff0f3;--danger-dark: #d4183c;--warning: #f6b100;--warning-soft: #fff8ea;--warning-dark: #d4940b;--info: #7239ea;--info-soft: #f3eeff;--info-dark: #5d2fc8;--purple: #7239ea;--purple-soft: #f3eeff;--orange: #fd7e14;--orange-soft: #fff4e5;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--mono: "JetBrains Mono", monospace;--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 2px 8px rgba(0,0,0,.07), 0 1px 3px rgba(0,0,0,.04);--shadow: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);--shadow-md: 0 8px 24px rgba(0,0,0,.1), 0 3px 8px rgba(0,0,0,.05);--shadow-lg: 0 16px 48px rgba(0,0,0,.12), 0 6px 16px rgba(0,0,0,.06);--topbar-h: 68px;--sidebar-w: 260px;--trans: all .15s ease;--trans-slow: all .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);font-size:13.5px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:1fr;grid-template-areas:"sidebar body";height:100vh;overflow:hidden}.body-area{grid-area:body;display:flex;flex-direction:column;overflow:hidden}.sidebar{grid-area:sidebar;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 20px;height:var(--topbar-h);border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--purple));display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;font-weight:800;flex-shrink:0;box-shadow:0 4px 12px #3e97ff59}.sidebar-logo-text{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.3px}.sidebar-logo-ver{font-size:10px;color:var(--muted);font-weight:600;margin-top:1px}.sidebar-inner{padding:16px 12px;flex:1}.sidebar-section{margin-bottom:8px}.sidebar-heading{font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);padding:8px 10px 6px;margin-bottom:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--trans);font-size:13px;font-weight:500;color:var(--text3);border:none;background:transparent;width:100%;text-align:left;position:relative;line-height:1}.nav-item:hover{color:var(--primary);background:var(--primary-soft)}.nav-item.active{color:var(--primary);background:var(--primary-soft);font-weight:600}.nav-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px;opacity:.7;transition:var(--trans)}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}.nav-badge{margin-left:auto;font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-full);background:var(--primary-soft);color:var(--primary);line-height:1.4}.nav-badge.danger{background:var(--danger-soft);color:var(--danger)}.nav-item.locked{color:var(--text3);opacity:.55}.nav-item.locked:hover{color:var(--text3);background:var(--surface2);opacity:.8}.nav-lock{margin-left:auto;font-size:12px;opacity:.8;line-height:1}.nav-item.soon{color:var(--text3);opacity:.55;cursor:default}.nav-item.soon:hover{color:var(--text3);background:var(--surface2);opacity:.8}.nav-soon{margin-left:auto;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:1px 6px;border-radius:var(--radius-full);background:var(--surface3);color:var(--text3);line-height:1.5}.sidebar-footer{padding:12px;border-top:1px solid var(--border);flex-shrink:0}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 24px;flex-shrink:0;box-shadow:var(--shadow-xs)}.topbar-search{flex:1;max-width:340px;position:relative}.topbar-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;display:flex;align-items:center}.topbar-search input[type=search]{width:100%;background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:8px 12px 8px 34px;outline:none;transition:var(--trans);font-size:13px;box-shadow:none}.topbar-search input::placeholder{color:var(--muted)}.topbar-search input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px #3e97ff1a}.topbar-spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:4px}.topbar-icon-btn{width:38px;height:38px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--text3);transition:var(--trans);position:relative}.topbar-icon-btn:hover{background:var(--surface3);color:var(--text)}.topbar-notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)}.topbar-divider{width:1px;height:28px;background:var(--border);margin:0 6px}.user-menu{display:flex;align-items:center;gap:10px;padding:5px 8px 5px 5px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--trans);border:none;background:transparent}.user-menu:hover{background:var(--surface3)}.user-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--purple));display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.user-info{text-align:left;line-height:1.3}.user-name{font-size:13px;font-weight:600;color:var(--text)}.user-role{font-size:11px;color:var(--muted)}.main-content{flex:1;overflow-y:auto;padding:28px 28px 40px;background:var(--bg)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px}.page-header-left{display:flex;flex-direction:column;gap:4px}.page-title{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.4px}.page-subtitle{font-size:13px;color:var(--muted)}.page-actions{display:flex;gap:8px;align-items:center}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted);margin-bottom:4px}.breadcrumb a,.breadcrumb span{color:var(--muted)}.breadcrumb a:hover{color:var(--primary)}.breadcrumb-sep{color:var(--border2);font-size:10px}.breadcrumb-current{color:var(--text3);font-weight:500}.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);border-radius:var(--radius-sm);padding:9px 16px;cursor:pointer;font-weight:600;font-size:13px;transition:var(--trans);white-space:nowrap;line-height:1;box-shadow:var(--shadow-xs)}.btn:hover{background:var(--surface3);border-color:var(--border2);box-shadow:var(--shadow-sm)}.btn:active{transform:scale(.985)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 12px #3e97ff4d}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 6px 16px #3e97ff66}.btn-success{background:var(--success);border-color:var(--success);color:#fff;box-shadow:0 4px 12px #17c65340}.btn-success:hover{background:var(--success-dark);border-color:var(--success-dark)}.btn-danger{background:var(--danger-soft);border-color:var(--danger-soft);color:var(--danger)}.btn-danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.btn-warning{background:var(--warning-soft);border-color:var(--warning-soft);color:var(--warning-dark)}.btn-warning:hover{background:var(--warning);border-color:var(--warning);color:#fff}.btn-light{background:var(--surface3);border-color:var(--surface3);color:var(--text2);box-shadow:none}.btn-light:hover{background:var(--border);border-color:var(--border)}.btn-restore{background:#f0fdf4;border-color:#bbf7d0;color:#16a34a;font-weight:600}.btn-restore:hover{background:#16a34a;border-color:#16a34a;color:#fff}.btn-ghost{background:transparent;border-color:transparent;color:var(--text3);box-shadow:none}.btn-ghost:hover{background:var(--surface3);border-color:transparent;color:var(--text)}.btn-sm{padding:6px 12px;font-size:12px;border-radius:var(--radius-xs)}.btn-xs{padding:4px 9px;font-size:11px;border-radius:var(--radius-xs)}.btn-icon{padding:8px;aspect-ratio:1;justify-content:center;box-shadow:none}.btn-icon.btn-sm{padding:6px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:16px;margin-bottom:20px;border-bottom:1px solid var(--border)}.card-title{font-size:15px;font-weight:700;color:var(--text)}.card-subtitle{font-size:12px;color:var(--muted);margin-top:2px}.card-actions{display:flex;gap:6px;align-items:center}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.panel-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:18px;display:flex;align-items:center;gap:10px}.panel-title-line{width:4px;height:18px;border-radius:3px;background:var(--primary);flex-shrink:0}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 24px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:16px;transition:var(--trans-slow)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-icon-wrap{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.stat-icon-wrap.blue{background:var(--primary-soft)}.stat-icon-wrap.green{background:var(--success-soft)}.stat-icon-wrap.red{background:var(--danger-soft)}.stat-icon-wrap.yellow{background:var(--warning-soft)}.stat-icon-wrap.purple{background:var(--purple-soft)}.stat-icon-wrap.orange{background:var(--orange-soft)}.stat-body{flex:1;min-width:0}.stat-label{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}.stat-value{font-size:26px;font-weight:800;color:var(--text);letter-spacing:-1px;line-height:1}.stat-delta{font-size:12px;color:var(--muted);margin-top:4px;display:flex;align-items:center;gap:4px}.stat-delta.up{color:var(--success)}.stat-delta.down{color:var(--danger)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-grid.cols1{grid-template-columns:1fr}.form-grid.cols3{grid-template-columns:repeat(3,1fr)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field:last-child{margin-bottom:0}.field-row{display:flex;gap:12px;margin-bottom:16px}.field-row .field{flex:1;margin-bottom:0}.field.full{grid-column:1 / -1}.field-label{font-size:12px;font-weight:600;color:var(--text2)}.field-hint{font-size:11.5px;color:var(--muted)}.input,input[type=text],input[type=number],input[type=date],input[type=email],input[type=tel],input[type=search],input[type=password],textarea,select{width:100%;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);padding:10px 13px;outline:none;transition:var(--trans);font-size:13px;box-shadow:var(--shadow-xs)}select{padding-right:36px;-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 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.input:focus,input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3e97ff1f}input[readonly]{background:var(--surface3);color:var(--muted);cursor:default}.toggle-row{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-row input[type=checkbox]{display:none}.toggle-track{width:36px;height:20px;border-radius:99px;background:var(--border2);position:relative;flex-shrink:0;transition:background .2s}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.toggle-row input:checked+.toggle-track{background:var(--primary)}.toggle-row input:checked+.toggle-track:after{transform:translate(16px)}.toggle-label{font-size:14px;color:var(--text)}textarea{min-height:88px;resize:vertical}select option{background:var(--surface)}input::placeholder,textarea::placeholder{color:var(--muted)}.form-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}table{width:100%;border-collapse:collapse}thead th{background:var(--surface3);font-size:11.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:var(--trans)}thead th.sortable:hover{color:var(--text)}td{padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:13.5px;color:var(--text2)}tr:last-child td{border-bottom:none}tbody tr{transition:background .1s}tbody tr:hover td{background:var(--surface3)}tbody tr.row-selected td{background:var(--primary-soft)}.col-actions{width:1%;white-space:nowrap}.row-actions{display:flex;gap:4px;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-full);font-size:11.5px;font-weight:700;white-space:nowrap}.badge-dot:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;display:inline-block;flex-shrink:0}.badge-default{background:var(--surface3);color:var(--text3)}.badge-primary{background:var(--primary-soft);color:var(--primary)}.badge-success{background:var(--success-soft);color:var(--success-dark)}.badge-danger{background:var(--danger-soft);color:var(--danger-dark)}.badge-warning{background:var(--warning-soft);color:var(--warning-dark)}.badge-info{background:var(--info-soft);color:var(--info-dark)}.badge-purple{background:var(--purple-soft);color:var(--purple)}.badge-orange{background:var(--orange-soft);color:var(--orange)}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:18px}.toolbar .field{min-width:180px;margin-bottom:0}.split{display:grid;grid-template-columns:340px minmax(0,1fr);gap:20px;align-items:start}.row{display:flex;gap:12px;align-items:center}.col{display:flex;flex-direction:column;gap:12px}.flex-1{flex:1}.ml-auto{margin-left:auto}.mt-auto{margin-top:auto}.mb-4{margin-bottom:4px!important}.mb-8{margin-bottom:8px!important}.mb-16{margin-bottom:16px!important}.mb-20{margin-bottom:20px!important}.mb-24{margin-bottom:24px!important}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.text-sm{font-size:12.5px}.text-xs{font-size:11.5px}.font-bold{font-weight:700}.font-med{font-weight:500}.muted{color:var(--muted)}.text2{color:var(--text2)}.mono{font-family:var(--mono)}.text-primary{color:var(--primary)}.text-success{color:var(--success-dark)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning-dark)}.avatar{border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--primary),var(--purple))}.avatar-xs{width:28px;height:28px;font-size:11px;border-radius:7px}.avatar-sm{width:34px;height:34px;font-size:13px;border-radius:9px}.avatar{width:40px;height:40px;font-size:15px}.avatar-lg{width:52px;height:52px;font-size:18px;border-radius:13px}.avatar-xl{width:64px;height:64px;font-size:22px;border-radius:16px}.avatar-blue{background:linear-gradient(135deg,#3e97ff,#1a73e8)}.avatar-green{background:linear-gradient(135deg,#17c653,#0ea144)}.avatar-purple{background:linear-gradient(135deg,#7239ea,#5d2fc8)}.avatar-orange{background:linear-gradient(135deg,#fd7e14,#e85d00)}.avatar-red{background:linear-gradient(135deg,#f8285a,#d4183c)}.avatar-teal{background:linear-gradient(135deg,#0dcaf0,#0aa3c2)}.empty-state{padding:56px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.empty-icon{font-size:40px;opacity:.35}.empty-title{font-size:15px;font-weight:700;color:var(--text2)}.empty-sub{font-size:13px;color:var(--muted);max-width:280px;line-height:1.6}.divider{height:1px;background:var(--border);margin:16px 0}.divider-v{width:1px;background:var(--border);align-self:stretch}.progress-bar{height:6px;background:var(--surface3);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:99px;transition:width .4s ease}.progress-fill.success{background:var(--success)}.progress-fill.warning{background:var(--warning)}.progress-fill.danger{background:var(--danger)}.progress-fill.purple{background:var(--purple)}.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.metric{background:var(--surface3);border-radius:var(--radius-sm);padding:14px 16px}.metric-label{font-size:11.5px;color:var(--muted);margin-bottom:4px;font-weight:500}.metric-value{font-size:18px;font-weight:800;color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0f142373;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px 28px;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:17px;font-weight:700;color:var(--text)}.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--surface3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--muted);transition:var(--trans)}.modal-close:hover{background:var(--border2);color:var(--text)}.modal-body{padding:0 0 4px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-flex;align-items:center;gap:5px;background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius-xs);padding:4px 9px;font-size:12px;font-weight:500;color:var(--text2)}.tag-remove{cursor:pointer;color:var(--muted);font-size:13px;line-height:1;transition:var(--trans)}.tag-remove:hover{color:var(--danger)}.toast-container{position:fixed;top:calc(var(--topbar-h) + 16px);right:24px;z-index:300;width:340px;display:flex;flex-direction:column;align-items:flex-end;gap:8px;pointer-events:none}.toast{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;font-size:13px;font-weight:500;color:var(--text2);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:10px;pointer-events:all;max-width:340px;min-width:240px}.toast-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.toast.success .toast-icon{background:var(--success-soft)}.toast.error .toast-icon{background:var(--danger-soft)}.toast.warning .toast-icon{background:var(--warning-soft)}.toast-body{flex:1}.toast-title{font-weight:600;color:var(--text);font-size:13px;margin-bottom:1px}.toast-sub{font-size:12px;color:var(--muted)}.search-wrap{position:relative}.search-wrap input{padding-left:36px}.search-ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;display:flex;align-items:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}.fade-enter-active,.fade-leave-active{transition:opacity .15s,transform .15s}.fade-enter-from,.fade-leave-to{opacity:0;transform:translateY(5px)}.toast-enter-active{transition:opacity .35s ease,transform .35s cubic-bezier(.22,.61,.36,1)}.toast-leave-active{transition:opacity .4s ease,transform .4s cubic-bezier(.4,0,.2,1);position:absolute;right:0;width:100%}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(120%)}.toast-move{transition:transform .4s cubic-bezier(.22,.61,.36,1)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:149;background:#0f142373;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease}.sidebar-overlay.visible{display:block}.topbar-burger{display:none;width:38px;height:38px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;flex-shrink:0}.topbar-burger span{display:block;width:20px;height:2px;background:var(--text3);border-radius:2px;transition:var(--trans)}.topbar-burger:hover span{background:var(--text)}@media (max-width: 1100px){:root{--sidebar-w: 220px}.split{grid-template-columns:1fr}.stats-grid,.metrics{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){:root{--sidebar-w: 260px}.app-shell{grid-template-columns:1fr;grid-template-areas:"body"}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:150;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.topbar-burger{display:flex}.topbar{padding:0 12px;gap:8px}.topbar-search{max-width:200px}.user-info{display:none}.main-content{padding:16px 14px 32px}.page-header{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:16px}.page-actions{flex-wrap:wrap}.page-header-right{flex-wrap:wrap;gap:6px}[style*="grid-template-columns:1fr 1fr"],[style*="grid-template-columns: 1fr 1fr"],[style*="grid-template-columns:2fr 1fr"],[style*="grid-template-columns: 2fr 1fr"]{grid-template-columns:1fr!important}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:16px}.stat-value{font-size:22px}.split{grid-template-columns:1fr;gap:14px}.form-grid{grid-template-columns:1fr;gap:12px}.toolbar{gap:8px}.toolbar .field{min-width:0;flex:1 1 140px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:580px}.card,.panel{padding:16px;border-radius:var(--radius)}.metrics{grid-template-columns:repeat(3,1fr);gap:8px}.metric{padding:10px 12px}.metric-value{font-size:16px}.modal{padding:20px;max-width:100%;border-radius:var(--radius-lg)}.modal-overlay{padding:12px;align-items:flex-end}.breadcrumb{font-size:11.5px}.toast-container{top:calc(var(--topbar-h) + 12px);right:12px;left:12px;width:auto}.toast{max-width:100%;min-width:0}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.topbar-search{display:none}.metrics{grid-template-columns:1fr}.page-title{font-size:17px}.modal-overlay{padding:0;align-items:flex-end}.modal{border-bottom-left-radius:0;border-bottom-right-radius:0;max-height:95vh}}@media print{.sidebar,.topbar,.toolbar,.form-actions,.btn,.nav-item,.sidebar-overlay,.topbar-burger{display:none!important}body{background:#fff}}
