.drag-table[data-v-fee41129]{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;font-size:13px}.drag-table.loading[data-v-fee41129]{opacity:.5;pointer-events:none}.drag-hd[data-v-fee41129]{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;color:#6b7280;font-size:12px}.drag-bd[data-v-fee41129]{min-height:60px}.drag-row[data-v-fee41129]{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #f3f4f6;transition:background .1s;-webkit-user-select:none;user-select:none}.drag-row[data-v-fee41129]:last-child{border-bottom:none}.drag-row[data-v-fee41129]:hover{background:#fafbfc}.drag-row.dragging[data-v-fee41129]{opacity:.4}.drag-row.over[data-v-fee41129]{border-top:2px solid #6366f1}.grip[data-v-fee41129]{font-size:14px;letter-spacing:-2px;cursor:grab}.style-editor[data-v-fee41129]{width:100%;background:#fafbfc;border:1px solid #e5e7eb;border-radius:8px;padding:12px}.se-row[data-v-fee41129]{display:flex;align-items:center;gap:8px;margin-bottom:8px}.se-row[data-v-fee41129]:last-of-type{margin-bottom:10px}.se-row label[data-v-fee41129]{width:40px;font-size:12px;color:#6b7280;flex-shrink:0}.se-color[data-v-fee41129]{width:32px;height:24px;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;padding:0;background:none}.se-preview[data-v-fee41129]{padding:8px 12px;background:#fff;border:1px dashed #d1d5db;border-radius:6px;font-size:13px;color:#111}:root{--c-bg: #f0f2f5;--c-sidebar: #0f172a;--c-sidebar-hover: rgba(255,255,255,.06);--c-sidebar-active: rgba(99,102,241,.15);--c-accent: #6366f1;--c-accent-hover: #4f46e5;--c-accent-light: #eef2ff;--c-text: #1e293b;--c-text2: #64748b;--c-text3: #94a3b8;--c-border: #e2e8f0;--c-card: #fff;--r-card: 16px;--sidebar-w: 240px;--sidebar-cw: 68px;--header-h: 56px}*{margin:0;padding:0;box-sizing:border-box}html,body,#app{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;color:var(--c-text);-webkit-font-smoothing:antialiased}body{background:var(--c-bg)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,#0f172a,#1e1b4b,#312e81);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:500px;height:500px;top:-100px;right:-100px;background:radial-gradient(circle,rgba(99,102,241,.2),transparent 70%);pointer-events:none}.login-page:after{content:"";position:absolute;width:400px;height:400px;bottom:-80px;left:-80px;background:radial-gradient(circle,rgba(139,92,246,.15),transparent 70%);pointer-events:none}.login-box{width:100%;max-width:400px;background:#fffffff7;border-radius:24px;padding:44px 36px;box-shadow:0 25px 60px #0000004d;position:relative;z-index:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-logo{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 8px 28px #6366f159}.login-box h2{text-align:center;font-size:22px;font-weight:700;color:#1e293b;margin-bottom:4px}.login-box .sub{text-align:center;font-size:13px;color:#94a3b8;margin-bottom:30px}.login-box .field{margin-bottom:18px}.login-box .field label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.login-box input{width:100%;height:44px;border:1.5px solid #e2e8f0;border-radius:11px;padding:0 14px;font-size:14px;outline:none;transition:all .2s}.login-box input:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px #6366f11f}.login-btn{width:100%;height:46px;border:none;border-radius:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin-top:10px;transition:all .2s;box-shadow:0 4px 16px #6366f14d}.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--c-sidebar);display:flex;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1);overflow:hidden;flex-shrink:0}.sidebar.collapsed{width:var(--sidebar-cw)}.sidebar-head{height:var(--header-h);display:flex;align-items:center;gap:12px;padding:0 18px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.sidebar-head .dot{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-head .dot svg{color:#fff}.sidebar-head .txt{color:#f1f5f9;font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-head{justify-content:center;padding:0}.sidebar.collapsed .sidebar-head .txt{display:none}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:0}.nav-group{font-size:10.5px;color:#94a3b8b3;text-transform:uppercase;letter-spacing:1px;padding:16px 12px 6px;font-weight:600;white-space:nowrap}.sidebar.collapsed .nav-group{font-size:0;padding:8px 0}.sidebar.collapsed .nav-group:after{content:"";display:block;width:20px;height:1px;background:#334155;margin:0 auto}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;cursor:pointer;color:#94a3b8;font-size:13.5px;white-space:nowrap;transition:all .15s;margin-bottom:2px;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--c-sidebar-hover);color:#e2e8f0}.nav-item.active{background:var(--c-sidebar-active);color:#a5b4fc;font-weight:600}.nav-item.active svg{color:#818cf8}.nav-item svg{width:19px;height:19px;flex-shrink:0}.sidebar.collapsed .nav-item{justify-content:center;padding:9px}.sidebar.collapsed .nav-item span{display:none}.sidebar-foot{padding:8px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.collapse-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px;border-radius:8px;border:none;background:0 0;color:#64748b;cursor:pointer;font-size:12px;transition:all .12s}.collapse-btn:hover{background:var(--c-sidebar-hover);color:#94a3b8}.collapse-btn svg{width:17px;height:17px}.sidebar.collapsed .collapse-btn span{display:none}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.top-bar{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#fff;border-bottom:1px solid var(--c-border);flex-shrink:0}.top-left{display:flex;align-items:center;gap:12px}.top-left h1{font-size:16px;font-weight:700;color:var(--c-text)}.mob-btn{display:none;width:36px;height:36px;border-radius:9px;border:1px solid var(--c-border);background:#fff;cursor:pointer;align-items:center;justify-content:center}.mob-btn:hover{background:#f8fafc}.mob-btn svg{width:19px;height:19px;color:#475569}.top-right{display:flex;align-items:center;gap:10px}.user-chip{display:flex;align-items:center;gap:7px;padding:5px 12px;border-radius:9px;background:#f8fafc;font-size:13px;color:var(--c-text2)}.user-chip .av{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center}.user-chip .av svg{width:14px;height:14px;color:#fff}.out-btn{display:flex;align-items:center;gap:4px;padding:5px 12px;border-radius:8px;border:1px solid #fecaca;background:#fff;color:#ef4444;font-size:13px;cursor:pointer;transition:all .12s}.out-btn:hover{background:#fef2f2}.out-btn svg{width:15px;height:15px}.page-body{flex:1;overflow-y:auto;padding:24px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--c-card);border-radius:var(--r-card);padding:20px;border:1px solid var(--c-border);transition:all .2s}.stat-card:hover{border-color:#c7d2fe;box-shadow:0 4px 16px #6366f114;transform:translateY(-2px)}.stat-card .ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-card .ic svg{width:20px;height:20px}.stat-card .val{font-size:28px;font-weight:800;line-height:1;color:var(--c-text)}.stat-card .lbl{font-size:12.5px;color:var(--c-text3);margin-top:4px}.toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;align-items:center}.pgbar{margin-top:16px;display:flex;justify-content:flex-end}.sec-card{background:var(--c-card);border-radius:var(--r-card);border:1px solid var(--c-border);padding:28px;max-width:680px}.sec-card .sec-head{display:flex;align-items:center;gap:8px;margin-bottom:22px;font-size:15px;font-weight:600;color:var(--c-text)}.sec-card .sec-head svg{width:18px;height:18px;color:var(--c-accent)}.field-row{margin-bottom:16px}.field-row label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:5px}.upload-area{border:2px dashed var(--c-border);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .2s;background:#fafbfc}.upload-area:hover{border-color:var(--c-accent);background:var(--c-accent-light)}.upload-area input[type=file]{display:none}.upload-area .upload-text{font-size:13px;color:var(--c-text2)}.upload-preview{margin-top:10px;max-width:200px;border-radius:8px}.drawer-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;opacity:0;pointer-events:none;transition:opacity .2s}.drawer-mask.open{opacity:1;pointer-events:auto}.drawer-panel{position:fixed;top:0;left:0;bottom:0;width:270px;background:var(--c-sidebar);z-index:1001;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}.drawer-mask.open .drawer-panel{transform:translate(0)}@media(max-width:768px){:root{--header-h:52px}.sidebar{display:none!important}.mob-btn{display:flex}.page-body{padding:14px}.top-bar{padding:0 14px}.user-chip span,.out-btn span{display:none}.out-btn{padding:5px 8px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:14px}.stat-card .val{font-size:20px}.stat-card .ic{width:34px;height:34px;margin-bottom:8px}.stat-card .ic svg{width:17px;height:17px}.toolbar{flex-direction:column}.toolbar>*{width:100%!important}.top-left h1{font-size:15px}}@media(min-width:769px)and (max-width:1024px){.stat-grid{grid-template-columns:repeat(3,1fr)}}.duration-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.duration-card{padding:12px 8px;border-radius:10px;border:1.5px solid var(--c-border);background:#fafbfc;text-align:center;cursor:pointer;transition:all .18s;-webkit-user-select:none;user-select:none}.duration-card:hover{border-color:#c7d2fe;background:#f5f3ff;transform:translateY(-1px)}.duration-card.active{border-color:var(--c-accent);background:linear-gradient(135deg,#eef2ff,#ede9fe);box-shadow:0 2px 8px #6366f126}.duration-card .duration-label{font-size:15px;font-weight:700;color:var(--c-text);line-height:1.2}.duration-card.active .duration-label{color:var(--c-accent)}.duration-card .duration-desc{font-size:11px;color:var(--c-text3);margin-top:2px}.duration-card.active .duration-desc{color:#818cf8}.expire-hint{margin-top:10px;padding:8px 12px;border-radius:8px;background:#f8fafc;font-size:12.5px;color:var(--c-text2);border:1px solid var(--c-border)}.date-range-box{width:100%;background:#f8fafc;border:1px solid var(--c-border);border-radius:12px;padding:14px}.date-range-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.date-range-row:last-child{margin-bottom:0}.date-range-label{font-size:12px;font-weight:600;color:var(--c-text2);width:32px;flex-shrink:0;text-align:right}.date-quick-row{display:flex;align-items:center;gap:10px}.date-quick-btns{display:flex;flex-wrap:wrap;gap:6px}.date-quick-tag{padding:3px 10px;border-radius:6px;font-size:12px;color:var(--c-accent);background:#eef2ff;border:1px solid #e0e7ff;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.date-quick-tag:hover{background:#ddd6fe;border-color:#c4b5fd;color:#4f46e5}@media(max-width:768px){.duration-grid{grid-template-columns:repeat(3,1fr);gap:6px}.duration-card{padding:10px 6px}.duration-card .duration-label{font-size:13px}}
