
:root{
  --bg:#f5f7fb;
  --card:#fff;
  --text:#111827;
  --muted:#6b7280;
  --border:#e5e7eb;
  --blue:#2563eb;
  --blue2:#eff6ff;
  --red:#dc2626;
  --orange:#f97316;
  --green:#16a34a;
  --yellow:#ca8a04;
  --purple:#7c3aed;
  --dark:#0f172a;
  --shadow:0 12px 35px rgba(15,23,42,.07);
  --radius:18px;
  --sidebar:260px;
  --topbar:72px;
}

*{box-sizing:border-box}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",Arial,sans-serif;
}
a{text-decoration:none}

.layout{min-height:100vh;display:flex}
.sidebar{
  position:fixed;
  left:0;
  top:0;
  bottom:0;
  width:var(--sidebar);
  z-index:1040;
  color:#fff;
  display:flex;
  flex-direction:column;
  background:
    radial-gradient(circle at top left,rgba(59,130,246,.28),transparent 34%),
    linear-gradient(180deg,#111827 0%,#0f172a 100%);
  transition:.25s;
}
.brand{
  height:var(--topbar);
  display:flex;
  align-items:center;
  gap:12px;
  padding:0 22px;
  border-bottom:1px solid rgba(255,255,255,.08)
}
.brand-logo{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#3b82f6,#7c3aed);
  font-size:22px;
  box-shadow:0 8px 24px rgba(37,99,235,.35)
}
.brand-title{font-weight:850;line-height:1.2}
.brand-sub{font-size:12px;color:#94a3b8;margin-top:2px}
.menu{padding:18px 12px;overflow:auto;flex:1}
.menu-title{font-size:12px;color:#94a3b8;padding:16px 12px 8px;letter-spacing:.08em}
.menu-link{
  display:flex;
  align-items:center;
  gap:12px;
  color:#cbd5e1;
  padding:11px 12px;
  border-radius:14px;
  margin-bottom:4px;
  transition:.18s;
  position:relative;
  cursor:pointer
}
.menu-link i{font-size:18px;width:22px;text-align:center}
.menu-link:hover,.menu-link.active{color:#fff;background:rgba(255,255,255,.08)}
.menu-link.active:before{
  content:"";
  position:absolute;
  left:-12px;
  top:10px;
  width:4px;
  height:24px;
  border-radius:999px;
  background:#60a5fa
}
.menu-badge{margin-left:auto;font-size:12px;background:#2563eb;color:#fff;border-radius:999px;padding:2px 8px}
.sidebar-footer{padding:14px 16px 18px;border-top:1px solid rgba(255,255,255,.08)}
.user-mini{display:flex;gap:10px;align-items:center;padding:10px;border-radius:16px;background:rgba(255,255,255,.06)}
.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#60a5fa,#a78bfa);font-weight:850}
.user-name{font-size:14px;font-weight:750}
.user-role{font-size:12px;color:#94a3b8}

.main{flex:1;margin-left:var(--sidebar);min-width:0}
.topbar{
  height:var(--topbar);
  position:sticky;
  top:0;
  z-index:1020;
  display:flex;
  align-items:center;
  gap:16px;
  padding:0 24px;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border)
}
.mobile-btn{display:none}
.icon-btn{
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#334155;
  position:relative
}
.dot{position:absolute;right:8px;top:8px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid #fff}
.search-wrap{flex:1;max-width:540px;position:relative}
.search-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted)}
.global-search{padding-left:40px;border-radius:999px;background:#f9fafb;border-color:var(--border)}
.top-actions{margin-left:auto;display:flex;gap:10px;align-items:center}
.content{padding:24px}

.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.page-title h1{font-size:28px;font-weight:850;margin:0 0 8px;letter-spacing:-.5px}
.page-title p{margin:0;color:var(--muted)}
.page-actions{display:flex;gap:10px;flex-wrap:wrap}

.cardx{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.cardx-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 18px 0}
.cardx-title{font-size:17px;font-weight:850;margin:0}
.cardx-body{padding:18px}

.hero{
  color:#fff;
  border-radius:24px;
  padding:24px;
  margin-bottom:18px;
  box-shadow:0 18px 45px rgba(37,99,235,.22);
  background:
    radial-gradient(circle at 12% 20%,rgba(255,255,255,.32),transparent 20%),
    linear-gradient(135deg,#2563eb 0%,#4f46e5 56%,#7c3aed 100%);
  overflow:hidden;
  position:relative
}
.hero:after{content:"";position:absolute;width:260px;height:260px;border-radius:50%;right:-88px;top:-100px;background:rgba(255,255,255,.12)}
.hero-inner{position:relative;z-index:1;display:flex;justify-content:space-between;gap:18px;align-items:center}
.hero h2{font-size:24px;font-weight:850;margin:0 0 8px}
.hero p{margin:0;color:rgba(255,255,255,.82)}
.hero-metrics{display:flex;gap:12px;flex-wrap:wrap}
.hero-mini{min-width:112px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18)}
.hero-mini span{display:block;font-size:12px;color:rgba(255,255,255,.76)}
.hero-mini strong{display:block;font-size:22px;line-height:1.1;margin-top:4px}

.stat-grid,.notice-stat-grid,.message-stat-grid,.permission-summary{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px
}
.stat-card,.notice-stat,.message-stat,.permission-summary-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 8px 24px rgba(15,23,42,.04);
  position:relative;
  overflow:hidden
}
.stat-card:after{content:"";position:absolute;width:96px;height:96px;border-radius:50%;right:-30px;top:-30px;opacity:.12;background:currentColor}
.stat-icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:rgba(37,99,235,.1);font-size:18px;margin-bottom:14px}
.stat-label,.notice-stat span,.message-stat span,.permission-summary-card span{color:var(--muted);font-size:13px;margin-bottom:6px;display:block}
.stat-number,.notice-stat strong,.message-stat strong,.permission-summary-card strong{font-size:28px;font-weight:850;line-height:1}

.text-blue{color:var(--blue)}
.text-red{color:var(--red)}
.text-orange{color:var(--orange)}
.text-yellow{color:var(--yellow)}
.text-green{color:var(--green)}
.text-purple{color:var(--purple)}

.workspace-grid,.v6-grid{display:grid;grid-template-columns:minmax(0,1fr)340px;gap:18px;align-items:start}
.v5-grid{display:grid;grid-template-columns:minmax(0,1fr)360px;gap:18px;align-items:start}
.v5-full-grid,.v6-three-grid{display:grid;grid-template-columns:300px minmax(0,1fr)340px;gap:18px;align-items:start}
.v6-two-grid,.role-layout{display:grid;grid-template-columns:330px minmax(0,1fr);gap:18px;align-items:start}
.designer-shell,.form-designer-shell{display:grid;grid-template-columns:260px minmax(0,1fr)320px;gap:16px;align-items:stretch;min-height:720px}
.side-col,.employee-side-card{display:grid;gap:18px}

.filter-line,.employee-toolbar,.announcement-toolbar,.message-toolbar,.permission-toolbar{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:16px
}
.tabs,.message-category-tabs{display:flex;gap:8px;overflow:auto;padding-bottom:2px}
.tab-btn,.message-tab{
  border:1px solid var(--border);
  background:#fff;
  color:#374151;
  border-radius:999px;
  padding:8px 14px;
  font-size:14px;
  white-space:nowrap;
  transition:.18s
}
.tab-btn:hover,.tab-btn.active,.message-tab.active,.message-tab:hover{background:var(--blue2);border-color:#bfdbfe;color:var(--blue)}
.tools,.employee-filters,.announcement-filters,.message-filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.local-search,.employee-filters .form-control,.announcement-filters .form-control,.message-filters .form-control{min-width:230px}

.todo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.todo-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 8px 22px rgba(15,23,42,.04);
  padding:18px;
  transition:.22s;
  position:relative;
  overflow:hidden;
  cursor:pointer
}
.todo-card:hover{transform:translateY(-2px);box-shadow:0 16px 35px rgba(15,23,42,.08)}
.todo-card:before{content:"";position:absolute;left:0;top:0;width:5px;height:100%;background:#d1d5db}
.todo-card.high:before{background:var(--red)}
.todo-card.soon:before{background:var(--orange)}
.todo-card.normal:before{background:var(--blue)}
.todo-card.returned:before{background:var(--yellow)}
.todo-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:10px}
.todo-type{font-size:13px;color:var(--muted);display:flex;gap:6px;align-items:center}
.todo-title{font-size:16px;font-weight:850;margin:0 0 10px;line-height:1.45}
.todo-meta{display:flex;flex-wrap:wrap;gap:8px 14px;color:var(--muted);font-size:13px;margin-bottom:12px}
.todo-summary{background:#f9fafb;border:1px solid #edf0f3;border-radius:14px;padding:11px 12px;color:#374151;font-size:14px;margin-bottom:14px;min-height:66px}
.todo-footer{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}
.todo-deadline{font-size:13px;color:var(--muted)}
.todo-deadline strong{color:#111827}
.todo-buttons{display:flex;gap:8px;flex-wrap:wrap}

.badge-soft-blue{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}
.badge-soft-red{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}
.badge-soft-orange{background:#fff7ed;color:#f97316;border:1px solid #fed7aa}
.badge-soft-yellow{background:#fefce8;color:#ca8a04;border:1px solid #fde68a}
.badge-soft-green{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}
.badge-soft-gray{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}

.quick-apps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.quick-app{border:1px solid var(--border);background:#fff;border-radius:16px;padding:14px 8px;text-align:center;color:#334155;transition:.18s;cursor:pointer}
.quick-app:hover{background:var(--blue2);border-color:#bfdbfe;color:var(--blue);transform:translateY(-1px)}
.quick-app i{display:block;font-size:22px;margin-bottom:8px}
.quick-app span{font-size:13px;font-weight:700}

.notice-list,.schedule-list,.announcement-list,.message-list,.role-list,.org-tree,.component-list,.node-palette,.setting-nav,.system-health,.login-log{display:grid;gap:12px}
.notice-item,.schedule-item,.announcement-item,.message-item,.role-item,.org-node,.component-item,.palette-node,.setting-nav-item{
  padding:13px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  transition:.18s;
  cursor:pointer
}
.notice-item,.schedule-item{background:#f9fafb;border-color:#eef2f7}
.announcement-item:hover,.announcement-item.active,.message-item:hover,.message-item.active,.role-item:hover,.role-item.active,.org-node:hover,.org-node.active,.component-item:hover,.palette-node:hover,.setting-nav-item:hover,.setting-nav-item.active{
  background:var(--blue2);
  border-color:#bfdbfe;
  transform:translateY(-1px)
}
.notice-title,.schedule-title,.announcement-title,.message-title,.role-name{font-size:14px;font-weight:850;margin-bottom:5px;line-height:1.4}
.notice-meta,.schedule-meta,.announcement-meta,.message-meta,.role-desc{color:var(--muted);font-size:12px}
.schedule-item{display:flex;gap:12px}
.schedule-time{width:54px;text-align:center;border-radius:14px;background:var(--blue2);color:var(--blue);padding:8px 6px;flex:0 0 auto;font-weight:850;font-size:13px}

.breadcrumbx{display:flex;align-items:center;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:14px;margin-bottom:14px}
.breadcrumbx a,.breadcrumbx button{border:0;background:transparent;color:var(--blue);padding:0}
.approval-header{
  color:#fff;
  border-radius:24px;
  padding:24px;
  margin-bottom:18px;
  box-shadow:0 18px 45px rgba(15,23,42,.16);
  background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 52%,#4f46e5 100%)
}
.approval-head-grid{display:grid;grid-template-columns:minmax(0,1fr)auto;gap:18px;align-items:center}
.approval-title-line{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:12px}
.approval-title-line h1{margin:0;font-size:26px;font-weight:850}
.approval-meta{color:rgba(255,255,255,.78);display:flex;flex-wrap:wrap;gap:8px 18px;font-size:14px}
.approval-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:20px}
.approval-summary-item{border-radius:18px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);padding:13px 14px}
.approval-summary-item span{display:block;color:rgba(255,255,255,.72);font-size:12px;margin-bottom:5px}
.approval-summary-item strong{display:block;font-size:16px;line-height:1.35}
.detail-grid{display:grid;grid-template-columns:minmax(0,1fr)380px;gap:18px;align-items:start}
.section-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:850;margin:0}
.form-section{padding:18px;border-bottom:1px solid var(--border)}
.form-section:last-child{border-bottom:0}
.form-grid,.setting-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}
.field-box{background:#f8fafc;border:1px solid #edf2f7;border-radius:16px;padding:13px 14px;min-height:72px}
.field-box.full{grid-column:1/-1}
.field-label,.setting-label{color:var(--muted);font-size:12px;margin-bottom:7px}
.field-value{font-size:15px;font-weight:750;line-height:1.45;word-break:break-word}
.amount-value{color:var(--red);font-size:20px;font-weight:850}
.detail-table{margin-top:14px;border:1px solid var(--border);border-radius:16px;overflow:hidden}
.detail-table table{margin:0;font-size:14px}
.attachment-list{display:grid;gap:10px;margin-top:14px}
.attachment-item{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:16px;padding:12px;background:#fff}
.attachment-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:var(--blue2);color:var(--blue);font-size:20px}
.attachment-name{font-weight:750;font-size:14px}
.attachment-meta{color:var(--muted);font-size:12px}
.sticky-box{position:sticky;top:88px}
.timeline{display:grid;gap:0;margin-top:14px}
.timeline-item{position:relative;display:grid;grid-template-columns:36px minmax(0,1fr);gap:12px;padding-bottom:18px}
.timeline-item:before{content:"";position:absolute;left:17px;top:36px;bottom:0;width:2px;background:#e5e7eb}
.timeline-item:last-child:before{display:none}
.timeline-dot{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;border:2px solid #e5e7eb;background:#fff;color:#64748b;z-index:1}
.timeline-item.done .timeline-dot{border-color:#bbf7d0;background:#f0fdf4;color:var(--green)}
.timeline-item.current .timeline-dot{border-color:#bfdbfe;background:var(--blue2);color:var(--blue);box-shadow:0 0 0 6px rgba(37,99,235,.08)}
.timeline-card{border:1px solid var(--border);border-radius:16px;background:#fff;padding:13px}
.timeline-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px}
.timeline-title{font-weight:850;font-size:14px}
.timeline-time{color:var(--muted);font-size:12px;white-space:nowrap}
.timeline-desc{color:#475569;font-size:13px;line-height:1.55}
.comment-box textarea{min-height:104px;border-radius:16px;resize:vertical}
.action-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.action-row .btn-primary{grid-column:1/-1}
.audit-tips{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:16px;padding:12px;font-size:13px;line-height:1.55;margin-top:12px}
.operation-log{display:grid;gap:10px;margin-top:14px}
.log-item{display:flex;gap:10px;font-size:13px;color:#475569}
.log-item i{color:var(--blue);margin-top:2px}

.designer-panel{background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}
.designer-panel-head{padding:16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:10px;align-items:center}
.designer-panel-title{font-weight:850;margin:0;font-size:16px}
.designer-panel-body{padding:16px}
.palette-node,.component-item{display:flex;gap:10px;align-items:center}
.palette-icon,.component-icon,.setting-nav-icon{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:#fff;color:var(--blue);border:1px solid var(--border)}
.palette-title,.component-name,.setting-nav-title{font-weight:850;font-size:14px}
.palette-desc,.component-desc,.setting-nav-desc{font-size:12px;color:var(--muted);margin-top:2px}
.flow-canvas{background:linear-gradient(#eef2f7 1px,transparent 1px),linear-gradient(90deg,#eef2f7 1px,transparent 1px);background-size:24px 24px;border-radius:0 0 20px 20px;min-height:655px;position:relative;overflow:auto;padding:34px}
.flow-stage{min-width:760px;position:relative;padding:18px 0 30px}
.flow-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible}
.flow-node{width:220px;background:#fff;border:2px solid var(--border);border-radius:18px;box-shadow:0 10px 26px rgba(15,23,42,.08);padding:14px;position:absolute;cursor:pointer;transition:.18s}
.flow-node:hover,.flow-node.active{border-color:#60a5fa;box-shadow:0 16px 36px rgba(37,99,235,.18);transform:translateY(-1px)}
.node-top{display:flex;gap:10px;align-items:center;margin-bottom:8px}
.node-round{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:var(--blue2);color:var(--blue)}
.flow-node.start .node-round{background:#f0fdf4;color:var(--green)}
.flow-node.end .node-round{background:#f8fafc;color:#64748b}
.flow-node.condition .node-round{background:#fff7ed;color:var(--orange)}
.node-name{font-weight:850;font-size:15px}
.node-sub{font-size:12px;color:var(--muted)}
.node-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.config-list{display:grid;gap:12px}
.config-item,.setting-card{padding:12px;border:1px solid var(--border);border-radius:16px;background:#f8fafc}
.config-label{font-size:12px;color:var(--muted);margin-bottom:6px}

.form-canvas-wrap{background:#f8fafc;border-radius:0 0 20px 20px;min-height:655px;padding:20px;overflow:auto}
.form-paper{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:22px;box-shadow:0 16px 45px rgba(15,23,42,.08);padding:24px}
.form-paper-head{border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:18px}
.form-paper-head h2{font-size:24px;font-weight:850;margin:0 0 8px}
.form-paper-head p{color:var(--muted);margin:0;font-size:14px}
.form-field-box{border:2px solid transparent;border-radius:16px;padding:12px;margin-bottom:12px;background:#f8fafc;cursor:pointer;transition:.18s}
.form-field-box:hover,.form-field-box.active{border-color:#60a5fa;background:#eff6ff}
.field-toolbar{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:8px}
.required-mark{color:var(--red)}
.drag-hint{font-size:12px;color:var(--muted)}

.employee-table-wrap{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#fff}
.employee-table{margin:0;font-size:14px}
.employee-table th{background:#f8fafc;color:#475569;font-weight:850;white-space:nowrap}
.employee-name-cell{display:flex;align-items:center;gap:10px}
.emp-avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#60a5fa,#a78bfa);color:#fff;font-weight:850;flex:0 0 auto}
.emp-avatar.green{background:linear-gradient(135deg,#22c55e,#14b8a6)}
.emp-avatar.orange{background:linear-gradient(135deg,#f97316,#facc15)}
.emp-avatar.purple{background:linear-gradient(135deg,#8b5cf6,#ec4899)}
.emp-avatar.gray{background:linear-gradient(135deg,#64748b,#94a3b8)}
.emp-main{font-weight:850;color:#111827}
.emp-sub{font-size:12px;color:var(--muted)}
.profile-card{text-align:center;padding:18px}
.profile-avatar{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;margin:0 auto 12px;background:linear-gradient(135deg,#60a5fa,#7c3aed);color:#fff;font-size:26px;font-weight:900}
.profile-name{font-size:18px;font-weight:850;margin-bottom:4px}
.profile-role{font-size:13px;color:var(--muted);margin-bottom:14px}
.profile-meta{display:grid;gap:8px;text-align:left;margin-top:14px}
.profile-meta-item,.health-item{display:flex;justify-content:space-between;gap:10px;background:#f8fafc;border:1px solid #edf2f7;border-radius:14px;padding:10px 12px;font-size:13px}
.profile-meta-item span,.health-item span{color:var(--muted)}
.profile-meta-item strong,.health-item strong{color:#111827;text-align:right}

.org-chart-canvas{min-height:620px;background:linear-gradient(#eef2f7 1px,transparent 1px),linear-gradient(90deg,#eef2f7 1px,transparent 1px);background-size:24px 24px;border-radius:0 0 20px 20px;padding:28px;overflow:auto}
.org-level{display:flex;justify-content:center;gap:18px;min-width:760px;margin-bottom:28px;position:relative}
.org-card{width:210px;background:#fff;border:2px solid var(--border);border-radius:18px;box-shadow:0 10px 26px rgba(15,23,42,.07);padding:14px;text-align:center;cursor:pointer;transition:.18s}
.org-card:hover,.org-card.active{border-color:#60a5fa;box-shadow:0 16px 36px rgba(37,99,235,.16);transform:translateY(-2px)}
.org-card-icon,.org-icon{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;margin:0 auto 10px;background:#eff6ff;color:var(--blue);font-size:22px}
.org-node-top{display:flex;align-items:center;gap:10px}
.org-icon{width:38px;height:38px;margin:0;font-size:18px}
.org-title,.org-card-title{font-weight:850;margin-bottom:4px}
.org-desc,.org-card-meta{font-size:12px;color:var(--muted)}
.org-children{display:grid;gap:8px;margin:10px 0 0 32px}
.org-mini-node{border:1px solid #e2e8f0;border-radius:14px;background:#f8fafc;padding:9px 10px;font-size:13px;cursor:pointer}
.org-mini-node:hover,.org-mini-node.active{background:#fff;border-color:#93c5fd;color:var(--blue)}
.org-stat-list{display:grid;gap:10px}
.org-stat-item{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid var(--border);background:#f8fafc;border-radius:16px;padding:12px}
.org-stat-item span{color:var(--muted);font-size:13px}
.org-stat-item strong{font-size:18px}

.permission-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0}
.permission-group{border:1px solid var(--border);border-radius:18px;background:#fff;overflow:hidden;margin-top: 15px;}
.permission-group-head{display:flex;justify-content:space-between;gap:12px;align-items:center;background:#f8fafc;border-bottom:1px solid var(--border);padding:13px 14px}
.permission-group-title{font-weight:850}
.permission-check{padding:12px 14px;border-bottom:1px solid #edf2f7;border-right:1px solid #edf2f7}
.permission-check:nth-child(2n){border-right:0}
.permission-check label{font-size:14px;font-weight:650}

.preview-title{font-size:20px;font-weight:900;line-height:1.35;margin:0}
.preview-meta{color:var(--muted);font-size:13px;display:flex;gap:10px;flex-wrap:wrap}
.preview-content{background:#f8fafc;border:1px solid #edf2f7;border-radius:18px;padding:16px;line-height:1.8;color:#334155;font-size:14px;margin: 15px 0;margin: 10px 0;}
.notice-editor textarea{min-height:190px;border-radius:16px;margin-bottom: 16px;}
.message-row{display:flex;gap:12px}
.message-icon{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;flex:0 0 auto;background:#eff6ff;color:var(--blue);font-size:20px}
.message-icon.warn{background:#fff7ed;color:var(--orange)}
.message-icon.success{background:#f0fdf4;color:var(--green)}
.message-icon.gray{background:#f8fafc;color:#64748b}
.unread-dot{width:9px;height:9px;background:var(--red);border-radius:50%;display:inline-block;margin-right:6px}

.setting-switch-row{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid var(--border);border-radius:16px;padding:13px 14px;background:#f8fafc;margin-bottom:10px}
.setting-switch-title{font-weight:800}
.setting-switch-desc,.setting-help{font-size:12px;color:var(--muted);line-height:1.5;margin-top:3px}
.login-log-item{display:flex;gap:10px;font-size:13px;color:#475569}
.login-log-item i{color:var(--blue);margin-top:2px}

.empty-state{display:none;text-align:center;padding:54px 12px;color:var(--muted);border:1px dashed var(--border);border-radius:var(--radius);background:#fafafa}
.empty-state i{font-size:56px;color:#cbd5e1;margin-bottom:12px}

.overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:1035}
.overlay.show{display:block}

@media(max-width:1280px){
  .designer-shell,.form-designer-shell{grid-template-columns:240px minmax(0,1fr)}
  .designer-shell .designer-panel:last-child,.form-designer-shell .designer-panel:last-child{grid-column:1/-1}
  .v5-full-grid,.v6-three-grid{grid-template-columns:260px minmax(0,1fr)}
  .v5-full-grid .cardx:last-child,.v6-three-grid .cardx:last-child{grid-column:1/-1}
  .v5-grid,.v6-grid,.v6-two-grid,.role-layout{grid-template-columns:1fr}
}
@media(max-width:1180px){
  .workspace-grid,.detail-grid{grid-template-columns:1fr}
  .side-col{grid-template-columns:repeat(2,minmax(0,1fr))}
  .side-col .cardx:first-child{grid-column:1/-1}
  .sticky-box{position:static}
}
@media(max-width:992px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.show{transform:translateX(0)}
  .main{margin-left:0}
  .mobile-btn{display:inline-flex}
  .search-wrap{max-width:none}
}
@media(max-width:768px){
  .topbar{padding:0 14px}
  .content{padding:18px 14px 42px}
  .top-actions .icon-btn:nth-child(2){display:none}
  .page-head,.hero-inner,.approval-head-grid{grid-template-columns:1fr;flex-direction:column}
  .page-title h1,.approval-title-line h1{font-size:24px}
  .page-actions,.page-actions .btn{width:100%}
  .stat-grid,.notice-stat-grid,.message-stat-grid,.approval-summary-grid,.permission-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .todo-grid,.form-grid,.setting-form-grid{grid-template-columns:1fr}
  .tools,.local-search,.tools .form-select{width:100%}
  .todo-buttons,.todo-buttons .btn{width:100%}
  .side-col,.designer-shell,.form-designer-shell,.v5-full-grid,.v6-three-grid,.role-layout{grid-template-columns:1fr}
  .v5-grid,.v6-grid,.v6-two-grid{grid-template-columns:1fr}
  .quick-apps{grid-template-columns:repeat(3,1fr)}
  .field-box.full{grid-column:auto}
  .permission-list{grid-template-columns:1fr}
  .permission-check{border-right:0}
  .employee-toolbar,.employee-filters,.announcement-toolbar,.announcement-filters,.message-toolbar,.message-filters{align-items:stretch}
  .employee-filters,.employee-filters .form-control,.employee-filters .form-select,
  .announcement-filters,.announcement-filters .form-control,.announcement-filters .form-select,
  .message-filters,.message-filters .form-control{width:100%}
  .flow-canvas{min-height:640px;padding:18px}
  .flow-stage{min-width:700px}
}
@media(max-width:420px){
  .hero-metrics{width:100%}
  .hero-mini{flex:1;min-width:0}
  .quick-apps{grid-template-columns:repeat(2,1fr)}
  .approval-summary-grid,.notice-stat-grid,.message-stat-grid,.permission-summary{grid-template-columns:1fr}
  .action-row{grid-template-columns:1fr}
  .action-row .btn-primary{grid-column:auto}
}
@media print{
  .sidebar,.topbar,.page-actions,.sticky-box .cardx:nth-child(2),.sticky-box .cardx:nth-child(3){display:none!important}
  .main{margin-left:0}
  .content{padding:0}
  .approval-header,.cardx{box-shadow:none}
  body{background:#fff}
}


/* V8 登录 / 个人中心 / 修改密码 / 操作日志 */
.auth-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px 16px;
  background:
    radial-gradient(circle at 10% 10%,rgba(37,99,235,.22),transparent 28%),
    radial-gradient(circle at 90% 20%,rgba(124,58,237,.2),transparent 30%),
    linear-gradient(135deg,#eef2ff 0%,#f8fafc 55%,#eff6ff 100%);
}
.auth-card{
  width:min(980px,100%);
  display:grid;
  grid-template-columns:1.08fr .92fr;
  background:#fff;
  border:1px solid var(--border);
  border-radius:28px;
  box-shadow:0 28px 80px rgba(15,23,42,.14);
  overflow:hidden;
}
.auth-visual{
  color:#fff;
  padding:42px;
  position:relative;
  background:
    radial-gradient(circle at 24% 18%,rgba(255,255,255,.22),transparent 24%),
    linear-gradient(135deg,#0f172a 0%,#1d4ed8 52%,#7c3aed 100%);
}
.auth-visual:after{
  content:"";
  position:absolute;
  width:280px;
  height:280px;
  border-radius:50%;
  right:-90px;
  bottom:-110px;
  background:rgba(255,255,255,.12);
}
.auth-visual-content{position:relative;z-index:1}
.auth-logo{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  font-size:26px;
  margin-bottom:24px;
}
.auth-visual h1{font-size:32px;font-weight:900;margin:0 0 12px}
.auth-visual p{color:rgba(255,255,255,.82);line-height:1.8;margin:0}
.auth-feature-list{display:grid;gap:12px;margin-top:34px}
.auth-feature{
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  border-radius:16px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
}
.auth-feature i{font-size:20px}
.auth-form{
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.auth-form h2{font-size:26px;font-weight:900;margin:0 0 8px}
.auth-form p{color:var(--muted);margin-bottom:24px}
.auth-form .form-control{
  min-height:48px;
  border-radius:16px;
}
.auth-form .input-group-text{
  border-radius:16px 0 0 16px;
  background:#f8fafc;
}
.auth-form .btn{
  min-height:48px;
  border-radius:16px;
  font-weight:800;
}
.auth-footer{
  color:var(--muted);
  font-size:13px;
  margin-top:20px;
  text-align:center;
}

.profile-grid{
  display:grid;
  grid-template-columns:360px minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.profile-hero{
  background:
    radial-gradient(circle at 18% 20%,rgba(255,255,255,.28),transparent 22%),
    linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);
  color:#fff;
  border-radius:24px;
  padding:24px;
  box-shadow:0 18px 45px rgba(37,99,235,.2);
}
.profile-hero .profile-avatar{
  margin:0 0 16px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.25);
}
.profile-hero .profile-role{color:rgba(255,255,255,.78)}
.profile-hero .profile-meta-item{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.18);
}
.profile-hero .profile-meta-item span{color:rgba(255,255,255,.72)}
.profile-hero .profile-meta-item strong{color:#fff}
.profile-section-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.profile-info-card{
  border:1px solid var(--border);
  border-radius:18px;
  background:#f8fafc;
  padding:14px;
}
.profile-info-card span{
  color:var(--muted);
  font-size:12px;
  display:block;
  margin-bottom:6px;
}
.profile-info-card strong{
  display:block;
  font-size:15px;
}
.password-strength{
  height:9px;
  border-radius:999px;
  background:#e5e7eb;
  overflow:hidden;
  margin-top:10px;
}
.password-strength span{
  display:block;
  height:100%;
  width:72%;
  border-radius:999px;
  background:linear-gradient(90deg,#f97316,#22c55e);
}
.log-toolbar{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.log-filters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.log-filters .form-control{min-width:240px}
.log-list{
  display:grid;
  gap:12px;
}
.log-card{
  border:1px solid var(--border);
  border-radius:18px;
  background:#fff;
  padding:14px;
  display:flex;
  gap:12px;
  align-items:flex-start;
  transition:.18s;
}
.log-card:hover{
  border-color:#bfdbfe;
  background:#eff6ff;
  transform:translateY(-1px);
}
.log-icon{
  width:42px;
  height:42px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:#eff6ff;
  color:var(--blue);
  flex:0 0 auto;
}
.log-icon.warn{background:#fff7ed;color:var(--orange)}
.log-icon.danger{background:#fef2f2;color:var(--red)}
.log-title{font-weight:850;margin-bottom:5px}
.log-meta{font-size:12px;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap}
.log-desc{font-size:13px;color:#475569;margin-top:8px;line-height:1.55}
@media(max-width:992px){
  .auth-card{grid-template-columns:1fr}
  .auth-visual{display:none}
  .profile-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .auth-form{padding:28px 22px}
  .profile-section-grid{grid-template-columns:1fr}
  .log-filters,.log-filters .form-control,.log-filters .form-select{width:100%}
}


/* V9 细节修复：滚动条、菜单折叠、消息标签、系统设置 */
html, body{
  overflow-x:hidden;
  scrollbar-gutter:stable;
}
*{
  scrollbar-width:thin;
  scrollbar-color:#cbd5e1 transparent;
}
*::-webkit-scrollbar{
  width:8px;
  height:8px;
}
*::-webkit-scrollbar-track{
  background:transparent;
}
*::-webkit-scrollbar-thumb{
  background:#cbd5e1;
  border-radius:999px;
  border:2px solid transparent;
  background-clip:content-box;
}
*::-webkit-scrollbar-thumb:hover{
  background:#94a3b8;
  border:2px solid transparent;
  background-clip:content-box;
}
.sidebar{
  overflow:hidden;
}
.sidebar .menu{
  overflow-y:auto;
  overflow-x:hidden;
  padding-right:10px;
  padding-bottom:18px;
}
.sidebar .menu::-webkit-scrollbar{
  width:5px;
}
.sidebar .menu::-webkit-scrollbar-thumb{
  background:rgba(148,163,184,.55);
  border:0;
}
.sidebar-footer{
  flex:0 0 auto;
}
.mobile-btn{
  display:inline-flex;
}
body.sidebar-collapsed .sidebar{
  transform:translateX(-100%);
}
body.sidebar-collapsed .main{
  margin-left:0;
}
body.sidebar-collapsed .topbar{
  left:0;
}
.message-category-tabs{
  flex-wrap:wrap;
  overflow:visible;
  padding-bottom:0;
  margin-bottom: 15px;
}
.tabs{
  scrollbar-width:none;
}
.tabs::-webkit-scrollbar,
.message-category-tabs::-webkit-scrollbar{
  display:none;
}
.cardx,
.stat-card,
.todo-card,
notice-stat,
message-stat{
  max-width:100%;
}
.content{
  max-width:100%;
}
.setting-nav-item.active{
  box-shadow:inset 3px 0 0 var(--blue);
}
.setting-form-grid{
  margin-top:0;
}
.setting-card .form-control,
.setting-card .form-select{
  background:#fff;
}
.topbar{
  overflow:hidden;
}
@media(max-width:992px){
  body.sidebar-collapsed .sidebar{
    transform:translateX(-100%);
  }
  body.sidebar-collapsed .main{
    margin-left:0;
  }
}


/* V10 审批中心 / 发起申请 / 我的申请 */
.approval-dashboard{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.approval-stat-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:16px;
  box-shadow:0 8px 24px rgba(15,23,42,.04);
}
.approval-stat-card span{
  display:block;
  color:var(--muted);
  font-size:12px;
  margin-bottom:6px;
}
.approval-stat-card strong{
  display:block;
  font-size:26px;
  font-weight:900;
}
.approval-center-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr)340px;
  gap:18px;
  align-items:start;
}
.approval-table-toolbar,
.application-toolbar,
.apply-toolbar{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.approval-filter-group,
.application-filter-group,
.apply-filter-group{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.approval-filter-group .form-control,
.application-filter-group .form-control,
.apply-filter-group .form-control{
  min-width:240px;
}
.approval-status-tabs,
.application-status-tabs{
  display:flex;
  gap:8px;
  overflow:auto;
  padding-bottom:2px;
  margin-bottom:14px;
}
.approval-status-tab,
.application-status-tab{
  border:1px solid var(--border);
  background:#fff;
  color:#374151;
  border-radius:999px;
  padding:8px 14px;
  font-size:14px;
  white-space:nowrap;
  transition:.18s;
}
.approval-status-tab:hover,
.approval-status-tab.active,
.application-status-tab:hover,
.application-status-tab.active{
  background:var(--blue2);
  border-color:#bfdbfe;
  color:var(--blue);
}
.approval-table-wrap{
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.approval-table{
  margin:0;
  font-size:14px;
}
.approval-table th{
  background:#f8fafc;
  color:#475569;
  font-weight:850;
  white-space:nowrap;
}
.approval-title-cell{
  min-width:260px;
}
.approval-title-main{
  font-weight:850;
  color:#111827;
  margin-bottom:4px;
}
.approval-title-sub{
  color:var(--muted);
  font-size:12px;
}
.approval-progress{
  display:flex;
  align-items:center;
  gap:8px;
}
.approval-progress-bar{
  flex:1;
  min-width:90px;
  height:8px;
  border-radius:999px;
  background:#e5e7eb;
  overflow:hidden;
}
.approval-progress-bar span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#2563eb,#7c3aed);
}
.approval-side-list{
  display:grid;
  gap:12px;
}
.approval-side-item{
  border:1px solid var(--border);
  background:#f8fafc;
  border-radius:16px;
  padding:13px;
}
.approval-side-title{
  font-weight:850;
  font-size:14px;
  margin-bottom:5px;
}
.approval-side-meta{
  color:var(--muted);
  font-size:12px;
}
.apply-layout{
  display:grid;
  grid-template-columns:300px minmax(0,1fr)340px;
  gap:18px;
  align-items:start;
}
.apply-template-list{
  display:grid;
  gap:10px;
}
.apply-template{
  border:1px solid var(--border);
  background:#fff;
  border-radius:18px;
  padding:14px;
  cursor:pointer;
  transition:.18s;
}
.apply-template:hover,
.apply-template.active{
  border-color:#bfdbfe;
  background:var(--blue2);
  transform:translateY(-1px);
}
.apply-template-top{
  display:flex;
  gap:10px;
  align-items:center;
}
.apply-template-icon{
  width:42px;
  height:42px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:#eff6ff;
  color:var(--blue);
  border:1px solid #bfdbfe;
  font-size:20px;
}
.apply-template-title{
  font-weight:900;
}
.apply-template-desc{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
  line-height:1.45;
}
.apply-form-section{
  border:1px solid var(--border);
  border-radius:18px;
  background:#fff;
  padding:16px;
  margin-bottom:14px;
}
.apply-form-section-title{
  font-weight:900;
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:8px;
}
.apply-field-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.apply-field-grid .full{
  grid-column:1/-1;
}
.apply-flow-preview{
  display:grid;
  gap:12px;
}
.apply-flow-step{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.apply-flow-num{
  width:34px;
  height:34px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#eff6ff;
  color:var(--blue);
  font-weight:900;
  flex:0 0 auto;
}
.apply-flow-card{
  flex:1;
  border:1px solid var(--border);
  background:#f8fafc;
  border-radius:15px;
  padding:11px 12px;
}
.apply-flow-title{
  font-weight:850;
  font-size:14px;
}
.apply-flow-desc{
  color:var(--muted);
  font-size:12px;
  margin-top:3px;
}
.application-card-list{
  display:grid;
  gap:14px;
}
.application-card{
  border:1px solid var(--border);
  background:#fff;
  border-radius:18px;
  padding:16px;
  transition:.18s;
}
.application-card:hover{
  border-color:#bfdbfe;
  box-shadow:0 12px 28px rgba(37,99,235,.08);
  transform:translateY(-1px);
}
.application-card-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:10px;
}
.application-card-title{
  font-size:16px;
  font-weight:900;
  margin-bottom:5px;
}
.application-card-meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:12px;
}
.application-card-body{
  background:#f8fafc;
  border:1px solid #edf2f7;
  border-radius:15px;
  padding:12px;
  color:#475569;
  font-size:13px;
  line-height:1.6;
  margin:12px 0;
}
.application-timeline-mini{
  display:flex;
  align-items:center;
  gap:8px;
  overflow:auto;
  padding-bottom:2px;
}
.application-step{
  display:flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
  color:var(--muted);
  font-size:12px;
}
.application-step-dot{
  width:20px;
  height:20px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#e5e7eb;
  color:#64748b;
  font-size:11px;
}
.application-step.done .application-step-dot{
  background:#dcfce7;
  color:var(--green);
}
.application-step.current .application-step-dot{
  background:#dbeafe;
  color:var(--blue);
}
.application-card-footer{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:12px;
}
.application-empty-tip{
  border:1px dashed #cbd5e1;
  background:#fff;
  border-radius:18px;
  padding:36px;
  text-align:center;
  color:var(--muted);
}
.application-empty-tip i{
  display:block;
  font-size:42px;
  color:#cbd5e1;
  margin-bottom:10px;
}
@media(max-width:1280px){
  .apply-layout{
    grid-template-columns:260px minmax(0,1fr);
  }
  .apply-layout .cardx:last-child{
    grid-column:1/-1;
  }
  .approval-center-grid{
    grid-template-columns:1fr;
  }
}
@media(max-width:992px){
  .approval-dashboard{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .apply-layout{
    grid-template-columns:1fr;
  }
}
@media(max-width:768px){
  .approval-dashboard,
  .apply-field-grid{
    grid-template-columns:1fr;
  }
  .apply-field-grid .full{
    grid-column:auto;
  }
  .approval-filter-group,
  .application-filter-group,
  .apply-filter-group,
  .approval-filter-group .form-control,
  .application-filter-group .form-control,
  .apply-filter-group .form-control,
  .approval-filter-group .form-select,
  .application-filter-group .form-select,
  .apply-filter-group .form-select{
    width:100%;
  }
  .approval-status-tabs,
  .application-status-tabs{
    scrollbar-width:none;
  }
}


/* V11 模板管理中心 / 通用组件库 */
.template-dashboard{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.template-stat-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:16px;
  box-shadow:0 8px 24px rgba(15,23,42,.04);
}
.template-stat-card span{
  display:block;
  color:var(--muted);
  font-size:12px;
  margin-bottom:6px;
}
.template-stat-card strong{
  display:block;
  font-size:26px;
  font-weight:900;
}
.template-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr)360px;
  gap:18px;
  align-items:start;
}
.template-toolbar{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.template-filter-group{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.template-filter-group .form-control{
  min-width:240px;
}
.template-tabs{
  display:flex;
  gap:8px;
  overflow:auto;
  padding-bottom:2px;
  margin-bottom:14px;
}
.template-tab{
  border:1px solid var(--border);
  background:#fff;
  color:#374151;
  border-radius:999px;
  padding:8px 14px;
  font-size:14px;
  white-space:nowrap;
  transition:.18s;
}
.template-tab:hover,
.template-tab.active{
  background:var(--blue2);
  border-color:#bfdbfe;
  color:var(--blue);
}
.template-table-wrap{
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.template-table{
  margin:0;
  font-size:14px;
}
.template-table th{
  background:#f8fafc;
  color:#475569;
  font-weight:850;
  white-space:nowrap;
}
.template-name-cell{
  min-width:260px;
}
.template-name-main{
  font-weight:900;
  color:#111827;
  margin-bottom:4px;
}
.template-name-sub{
  color:var(--muted);
  font-size:12px;
}
.template-preview-card{
  display:grid;
  gap:12px;
}
.template-preview-title{
  font-size:20px;
  font-weight:900;
  line-height:1.35;
}
.template-preview-meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.template-flow-mini{
  display:grid;
  gap:10px;
}
.template-flow-mini-item{
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.template-flow-mini-num{
  width:30px;
  height:30px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#eff6ff;
  color:var(--blue);
  font-weight:900;
  flex:0 0 auto;
}
.template-flow-mini-card{
  border:1px solid var(--border);
  background:#f8fafc;
  border-radius:14px;
  padding:10px 12px;
  flex:1;
}
.template-flow-mini-title{
  font-weight:850;
  font-size:13px;
}
.template-flow-mini-desc{
  font-size:12px;
  color:var(--muted);
  margin-top:2px;
}
.form-preview-paper{
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:18px;
  box-shadow:0 10px 28px rgba(15,23,42,.06);
}
.form-preview-head{
  border-bottom:1px solid var(--border);
  padding-bottom:14px;
  margin-bottom:14px;
}
.form-preview-head h3{
  font-size:20px;
  font-weight:900;
  margin:0 0 6px;
}
.form-preview-head p{
  color:var(--muted);
  margin:0;
  font-size:13px;
}
.form-field-preview{
  border:1px solid #edf2f7;
  background:#f8fafc;
  border-radius:14px;
  padding:12px;
  margin-bottom:10px;
}
.form-field-preview label{
  display:block;
  font-size:13px;
  font-weight:850;
  margin-bottom:7px;
}
.form-field-preview .fake-input{
  height:38px;
  border:1px solid var(--border);
  background:#fff;
  border-radius:12px;
  display:flex;
  align-items:center;
  padding:0 12px;
  color:#94a3b8;
  font-size:13px;
}
.form-field-preview .fake-textarea{
  height:80px;
  align-items:flex-start;
  padding-top:10px;
}
.component-layout{
  display:grid;
  grid-template-columns:260px minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.component-nav{
  position:sticky;
  top:88px;
  display:grid;
  gap:10px;
}
.component-nav a{
  border:1px solid var(--border);
  background:#fff;
  border-radius:16px;
  padding:12px 14px;
  color:#334155;
  font-weight:800;
  display:flex;
  gap:10px;
  align-items:center;
  transition:.18s;
}
.component-nav a:hover{
  background:var(--blue2);
  border-color:#bfdbfe;
  color:var(--blue);
}
.component-section{
  scroll-margin-top:96px;
  margin-bottom:18px;
}
.component-showcase{
  display:grid;
  gap:14px;
}
.component-demo-box{
  border:1px solid var(--border);
  background:#fff;
  border-radius:18px;
  padding:16px;
}
.component-demo-title{
  font-weight:900;
  margin-bottom:12px;
}
.component-button-row,
.component-badge-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.component-card-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.component-empty{
  border:1px dashed #cbd5e1;
  background:#fff;
  border-radius:18px;
  padding:38px 18px;
  text-align:center;
  color:var(--muted);
}
.component-empty i{
  display:block;
  font-size:42px;
  color:#cbd5e1;
  margin-bottom:10px;
}
.component-upload{
  border:1px dashed #93c5fd;
  background:#eff6ff;
  border-radius:18px;
  padding:28px;
  text-align:center;
  color:#2563eb;
}
.component-upload i{
  font-size:40px;
  display:block;
  margin-bottom:10px;
}
.component-user-picker{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.picker-user{
  display:flex;
  gap:8px;
  align-items:center;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  padding:6px 10px 6px 6px;
}
.picker-user .emp-avatar{
  width:28px;
  height:28px;
  font-size:12px;
}
.component-code{
  background:#0f172a;
  color:#cbd5e1;
  border-radius:14px;
  padding:12px 14px;
  font-size:12px;
  overflow:auto;
  margin-top:12px;
}
@media(max-width:1280px){
  .template-layout{
    grid-template-columns:1fr;
  }
}
@media(max-width:992px){
  .template-dashboard{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .component-layout{
    grid-template-columns:1fr;
  }
  .component-nav{
    position:static;
  }
  .component-card-grid{
    grid-template-columns:1fr;
  }
}
@media(max-width:768px){
  .template-dashboard{
    grid-template-columns:1fr;
  }
  .template-filter-group,
  .template-filter-group .form-control,
  .template-filter-group .form-select{
    width:100%;
  }
}


/* V12 文件中心 / 日程会议 / 考勤管理 */
.extension-dashboard{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.extension-stat-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:16px;
  box-shadow:0 8px 24px rgba(15,23,42,.04);
}
.extension-stat-card span{
  display:block;
  color:var(--muted);
  font-size:12px;
  margin-bottom:6px;
}
.extension-stat-card strong{
  display:block;
  font-size:26px;
  font-weight:900;
}
.files-layout,
.calendar-layout,
.attendance-layout{
  display:grid;
  grid-template-columns:300px minmax(0,1fr)340px;
  gap:18px;
  align-items:start;
}
.file-category-list,
.file-list,
.event-list,
.room-list,
.attendance-alert-list{
  display:grid;
  gap:12px;
}
.file-category{
  display:flex;
  gap:12px;
  align-items:center;
  border:1px solid var(--border);
  background:#fff;
  border-radius:16px;
  padding:13px;
  cursor:pointer;
  transition:.18s;
}
.file-category:hover,
.file-category.active{
  background:var(--blue2);
  border-color:#bfdbfe;
  transform:translateY(-1px);
}
.file-category-icon{
  width:42px;
  height:42px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:#eff6ff;
  color:var(--blue);
  border:1px solid #bfdbfe;
  font-size:20px;
  flex:0 0 auto;
}
.file-category-title{
  font-weight:900;
  margin-bottom:3px;
}
.file-category-meta{
  font-size:12px;
  color:var(--muted);
}
.file-toolbar,
.calendar-toolbar,
.attendance-toolbar{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.file-filter-group,
.calendar-filter-group,
.attendance-filter-group{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.file-filter-group .form-control,
.calendar-filter-group .form-control,
.attendance-filter-group .form-control{
  min-width:240px;
}
.file-table-wrap,
.attendance-table-wrap{
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.file-table,
.attendance-table{
  margin:0;
  font-size:14px;
}
.file-table th,
.attendance-table th{
  background:#f8fafc;
  color:#475569;
  font-weight:850;
  white-space:nowrap;
}
.file-name-cell{
  display:flex;
  gap:10px;
  align-items:center;
  min-width:260px;
}
.file-icon{
  width:38px;
  height:38px;
  border-radius:13px;
  display:grid;
  place-items:center;
  background:#eff6ff;
  color:var(--blue);
  flex:0 0 auto;
}
.file-icon.pdf{background:#fef2f2;color:var(--red)}
.file-icon.sheet{background:#f0fdf4;color:var(--green)}
.file-icon.image{background:#fff7ed;color:var(--orange)}
.file-icon.doc{background:#eff6ff;color:var(--blue)}
.file-name-main{
  font-weight:900;
  color:#111827;
  margin-bottom:3px;
}
.file-name-sub{
  color:var(--muted);
  font-size:12px;
}
.file-preview{
  display:grid;
  gap:12px;
}
.file-preview-visual{
  height:180px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at 20% 15%,rgba(37,99,235,.18),transparent 26%),
    linear-gradient(135deg,#f8fafc,#eff6ff);
  border:1px solid var(--border);
  color:var(--blue);
}
.file-preview-visual i{
  font-size:58px;
}
.file-meta-list{
  display:grid;
  gap:8px;
}
.file-meta-item{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  border:1px solid var(--border);
  background:#f8fafc;
  border-radius:14px;
  padding:10px 12px;
  font-size:13px;
}
.file-meta-item span{
  color:var(--muted);
}
.file-meta-item strong{
  text-align:right;
}
.upload-dropzone{
  border:1px dashed #93c5fd;
  background:#eff6ff;
  color:#2563eb;
  border-radius:18px;
  padding:24px 16px;
  text-align:center;
}
.upload-dropzone i{
  display:block;
  font-size:40px;
  margin-bottom:10px;
}
.calendar-main{
  display:grid;
  gap:18px;
}
.calendar-board{
  border:1px solid var(--border);
  border-radius:20px;
  background:#fff;
  overflow:hidden;
}
.calendar-head{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  background:#f8fafc;
  border-bottom:1px solid var(--border);
}
.calendar-head div{
  padding:12px 8px;
  text-align:center;
  font-size:13px;
  font-weight:900;
  color:#475569;
}
.calendar-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
}
.calendar-day{
  min-height:112px;
  padding:10px;
  border-right:1px solid #edf2f7;
  border-bottom:1px solid #edf2f7;
  background:#fff;
}
.calendar-day:nth-child(7n){
  border-right:0;
}
.calendar-day.muted{
  background:#f8fafc;
  color:#94a3b8;
}
.calendar-day.today{
  background:#eff6ff;
}
.calendar-date{
  font-weight:900;
  margin-bottom:8px;
}
.calendar-event{
  font-size:12px;
  border-radius:10px;
  padding:5px 7px;
  background:#eff6ff;
  color:#1d4ed8;
  margin-bottom:5px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.calendar-event.green{
  background:#f0fdf4;
  color:#15803d;
}
.calendar-event.orange{
  background:#fff7ed;
  color:#c2410c;
}
.event-item,
.room-item,
.attendance-alert-item{
  border:1px solid var(--border);
  background:#f8fafc;
  border-radius:16px;
  padding:13px;
}
.event-item{
  display:flex;
  gap:12px;
}
.event-time{
  width:62px;
  flex:0 0 auto;
  border-radius:14px;
  background:#eff6ff;
  color:#2563eb;
  padding:8px 6px;
  text-align:center;
  font-weight:900;
  font-size:13px;
}
.event-title,
.room-title,
.attendance-alert-title{
  font-weight:900;
  margin-bottom:4px;
}
.event-meta,
.room-meta,
.attendance-alert-meta{
  color:var(--muted);
  font-size:12px;
  line-height:1.45;
}
.room-status{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}
.attendance-check-card{
  color:#fff;
  border-radius:24px;
  padding:24px;
  background:
    radial-gradient(circle at 16% 18%,rgba(255,255,255,.28),transparent 22%),
    linear-gradient(135deg,#0f766e 0%,#2563eb 58%,#7c3aed 100%);
  box-shadow:0 18px 45px rgba(37,99,235,.18);
}
.attendance-check-time{
  font-size:36px;
  font-weight:900;
  line-height:1;
  margin-bottom:8px;
}
.attendance-check-date{
  color:rgba(255,255,255,.78);
  margin-bottom:18px;
}
.attendance-check-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-bottom:16px;
}
.attendance-check-item{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  padding:12px;
}
.attendance-check-item span{
  display:block;
  font-size:12px;
  color:rgba(255,255,255,.72);
  margin-bottom:4px;
}
.attendance-check-item strong{
  display:block;
  font-size:16px;
}
.attendance-calendar-mini{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
}
.attendance-date{
  aspect-ratio:1;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:850;
  color:#475569;
}
.attendance-date.ok{
  background:#f0fdf4;
  border-color:#bbf7d0;
  color:#15803d;
}
.attendance-date.late{
  background:#fff7ed;
  border-color:#fed7aa;
  color:#c2410c;
}
.attendance-date.absent{
  background:#fef2f2;
  border-color:#fecaca;
  color:#b91c1c;
}
.attendance-date.today{
  box-shadow:0 0 0 3px rgba(37,99,235,.12);
  border-color:#93c5fd;
  color:#2563eb;
}
.attendance-status-tag{
  display:inline-flex;
  align-items:center;
  gap:5px;
}
@media(max-width:1280px){
  .files-layout,
  .calendar-layout,
  .attendance-layout{
    grid-template-columns:260px minmax(0,1fr);
  }
  .files-layout .cardx:last-child,
  .calendar-layout .cardx:last-child,
  .attendance-layout .cardx:last-child{
    grid-column:1/-1;
  }
}
@media(max-width:992px){
  .files-layout,
  .calendar-layout,
  .attendance-layout{
    grid-template-columns:1fr;
  }
  .extension-dashboard{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .calendar-day{
    min-height:92px;
  }
}
@media(max-width:768px){
  .extension-dashboard,
  .attendance-check-grid{
    grid-template-columns:1fr;
  }
  .file-filter-group,
  .calendar-filter-group,
  .attendance-filter-group,
  .file-filter-group .form-control,
  .calendar-filter-group .form-control,
  .attendance-filter-group .form-control,
  .file-filter-group .form-select,
  .calendar-filter-group .form-select,
  .attendance-filter-group .form-select{
    width:100%;
  }
  .calendar-board{
    overflow:auto;
  }
  .calendar-head,
  .calendar-grid{
    min-width:760px;
  }
}


/* V13 系统监控 / 错误页 / 状态页 */
.monitor-dashboard{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.monitor-stat-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:16px;
  box-shadow:0 8px 24px rgba(15,23,42,.04);
  overflow:hidden;
  position:relative;
}
.monitor-stat-card:after{
  content:"";
  position:absolute;
  width:94px;
  height:94px;
  right:-32px;
  top:-32px;
  border-radius:50%;
  background:currentColor;
  opacity:.12;
}
.monitor-stat-card span{
  display:block;
  color:var(--muted);
  font-size:12px;
  margin-bottom:6px;
}
.monitor-stat-card strong{
  display:block;
  font-size:26px;
  font-weight:900;
}
.monitor-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr)360px;
  gap:18px;
  align-items:start;
}
.monitor-service-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.monitor-service-card{
  border:1px solid var(--border);
  background:#fff;
  border-radius:18px;
  padding:16px;
  transition:.18s;
}
.monitor-service-card:hover{
  border-color:#bfdbfe;
  background:#eff6ff;
  transform:translateY(-1px);
}
.monitor-service-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:12px;
}
.monitor-service-title{
  font-weight:900;
  margin-bottom:4px;
}
.monitor-service-meta{
  color:var(--muted);
  font-size:12px;
}
.monitor-bar{
  height:9px;
  border-radius:999px;
  background:#e5e7eb;
  overflow:hidden;
  margin-top:10px;
}
.monitor-bar span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#2563eb,#7c3aed);
}
.monitor-bar.green span{
  background:linear-gradient(90deg,#16a34a,#22c55e);
}
.monitor-bar.orange span{
  background:linear-gradient(90deg,#f97316,#facc15);
}
.monitor-bar.red span{
  background:linear-gradient(90deg,#dc2626,#f97316);
}
.monitor-chart{
  height:220px;
  border:1px solid var(--border);
  background:
    linear-gradient(#eef2f7 1px,transparent 1px),
    linear-gradient(90deg,#eef2f7 1px,transparent 1px);
  background-size:32px 32px;
  border-radius:18px;
  padding:18px;
  display:flex;
  align-items:end;
  gap:10px;
}
.monitor-chart-bar{
  flex:1;
  border-radius:12px 12px 0 0;
  background:linear-gradient(180deg,#3b82f6,#7c3aed);
  min-height:18px;
  position:relative;
}
.monitor-chart-bar span{
  position:absolute;
  bottom:100%;
  left:50%;
  transform:translateX(-50%);
  font-size:11px;
  color:var(--muted);
  margin-bottom:5px;
  white-space:nowrap;
}
.backup-list,
.monitor-log-list{
  display:grid;
  gap:12px;
}
.backup-item,
.monitor-log-item{
  border:1px solid var(--border);
  background:#f8fafc;
  border-radius:16px;
  padding:13px;
}
.backup-top,
.monitor-log-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:6px;
}
.backup-title,
.monitor-log-title{
  font-weight:900;
}
.backup-meta,
.monitor-log-meta{
  color:var(--muted);
  font-size:12px;
  line-height:1.45;
}
.status-page-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.state-demo-card{
  border:1px solid var(--border);
  background:#fff;
  border-radius:20px;
  padding:24px;
  min-height:250px;
  display:grid;
  place-items:center;
  text-align:center;
}
.state-icon{
  width:74px;
  height:74px;
  border-radius:24px;
  display:grid;
  place-items:center;
  margin:0 auto 16px;
  background:#eff6ff;
  color:var(--blue);
  font-size:34px;
}
.state-icon.green{
  background:#f0fdf4;
  color:var(--green);
}
.state-icon.orange{
  background:#fff7ed;
  color:var(--orange);
}
.state-icon.red{
  background:#fef2f2;
  color:var(--red);
}
.state-title{
  font-size:20px;
  font-weight:900;
  margin-bottom:8px;
}
.state-desc{
  color:var(--muted);
  line-height:1.65;
  margin-bottom:18px;
}
.loading-spinner{
  width:54px;
  height:54px;
  border-radius:50%;
  border:5px solid #e5e7eb;
  border-top-color:#2563eb;
  animation:oaSpin 1s linear infinite;
  margin:0 auto 18px;
}
@keyframes oaSpin{
  to{transform:rotate(360deg)}
}
.skeleton-wrap{
  display:grid;
  gap:12px;
  width:100%;
}
.skeleton-line{
  height:14px;
  border-radius:999px;
  background:linear-gradient(90deg,#e5e7eb,#f8fafc,#e5e7eb);
  background-size:200% 100%;
  animation:oaSkeleton 1.4s ease-in-out infinite;
}
.skeleton-line.w80{width:80%}
.skeleton-line.w60{width:60%}
.skeleton-line.w40{width:40%}
.skeleton-block{
  height:88px;
  border-radius:18px;
  background:linear-gradient(90deg,#e5e7eb,#f8fafc,#e5e7eb);
  background-size:200% 100%;
  animation:oaSkeleton 1.4s ease-in-out infinite;
}
@keyframes oaSkeleton{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.error-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px 16px;
  background:
    radial-gradient(circle at 10% 10%,rgba(37,99,235,.18),transparent 28%),
    radial-gradient(circle at 90% 20%,rgba(124,58,237,.16),transparent 30%),
    linear-gradient(135deg,#f8fafc 0%,#eff6ff 100%);
}
.error-card{
  width:min(920px,100%);
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  background:#fff;
  border:1px solid var(--border);
  border-radius:30px;
  box-shadow:0 28px 80px rgba(15,23,42,.14);
  overflow:hidden;
}
.error-visual{
  color:#fff;
  padding:42px;
  position:relative;
  background:
    radial-gradient(circle at 24% 18%,rgba(255,255,255,.22),transparent 24%),
    linear-gradient(135deg,#0f172a 0%,#1d4ed8 52%,#7c3aed 100%);
}
.error-visual.red{
  background:
    radial-gradient(circle at 24% 18%,rgba(255,255,255,.22),transparent 24%),
    linear-gradient(135deg,#7f1d1d 0%,#dc2626 52%,#f97316 100%);
}
.error-visual.orange{
  background:
    radial-gradient(circle at 24% 18%,rgba(255,255,255,.22),transparent 24%),
    linear-gradient(135deg,#7c2d12 0%,#ea580c 52%,#facc15 100%);
}
.error-code{
  font-size:86px;
  line-height:1;
  font-weight:1000;
  letter-spacing:-4px;
  margin-bottom:16px;
}
.error-visual-title{
  font-size:24px;
  font-weight:900;
  margin-bottom:12px;
}
.error-visual-desc{
  color:rgba(255,255,255,.82);
  line-height:1.8;
}
.error-content{
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.error-content h1{
  font-size:30px;
  font-weight:1000;
  margin:0 0 12px;
}
.error-content p{
  color:var(--muted);
  line-height:1.8;
  margin-bottom:24px;
}
.error-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.error-help-list{
  display:grid;
  gap:10px;
  margin-top:24px;
}
.error-help-item{
  border:1px solid var(--border);
  background:#f8fafc;
  border-radius:14px;
  padding:11px 12px;
  color:#475569;
  font-size:13px;
}
@media(max-width:1280px){
  .monitor-layout{
    grid-template-columns:1fr;
  }
}
@media(max-width:992px){
  .monitor-dashboard,
  .monitor-service-grid,
  .status-page-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .error-card{
    grid-template-columns:1fr;
  }
  .error-visual{
    padding:32px;
  }
}
@media(max-width:768px){
  .monitor-dashboard,
  .monitor-service-grid,
  .status-page-grid{
    grid-template-columns:1fr;
  }
  .error-code{
    font-size:64px;
  }
  .error-content{
    padding:30px 22px;
  }
}


/* V14 左侧导航优化：二级菜单 / WordPress 风格折叠 */
.sidebar{
  width:var(--sidebar);
}
.menu{
  padding:14px 10px 18px;
}
.menu-title{
  padding:14px 12px 7px;
}
.menu-group{
  margin-bottom:4px;
}
.menu-parent{
  width:100%;
  border:0;
  background:transparent;
  color:#cbd5e1;
  border-radius:14px;
  padding:11px 12px;
  display:flex;
  align-items:center;
  gap:12px;
  transition:.18s;
  position:relative;
  text-align:left;
}
.menu-parent:hover,
.menu-parent.active,
.menu-parent.open{
  color:#fff;
  background:rgba(255,255,255,.08);
}
.menu-parent.active:before{
  content:"";
  position:absolute;
  left:-10px;
  top:10px;
  width:4px;
  height:24px;
  border-radius:999px;
  background:#60a5fa;
}
.menu-parent i:first-child{
  font-size:18px;
  width:22px;
  text-align:center;
  flex:0 0 auto;
}
.menu-parent span{
  flex:1;
  font-weight:760;
}
.menu-chevron{
  width:18px!important;
  font-size:13px!important;
  color:#94a3b8;
  transition:.18s;
}
.menu-parent.open .menu-chevron{
  transform:rotate(90deg);
  color:#fff;
}
.submenu{
  display:none;
  padding:5px 0 5px 38px;
}
.menu-group.open .submenu{
  display:grid;
  gap:3px;
}
.submenu-link{
  display:flex;
  align-items:center;
  gap:9px;
  color:#94a3b8;
  border-radius:12px;
  padding:9px 10px;
  font-size:13px;
  transition:.18s;
  position:relative;
}
.submenu-link:hover,
.submenu-link.active{
  color:#fff;
  background:rgba(255,255,255,.07);
}
.submenu-link.active:before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:#60a5fa;
  position:absolute;
  left:-15px;
  top:50%;
  transform:translateY(-50%);
}
.submenu-link i{
  width:18px;
  font-size:15px;
  text-align:center;
}
.submenu-link .submenu-badge{
  margin-left:auto;
  font-size:11px;
  padding:1px 7px;
  border-radius:999px;
  background:#2563eb;
  color:#fff;
}
.menu-link{
  font-weight:760;
}
.sidebar-collapse-hint{
  font-size:11px;
  color:#64748b;
  padding:8px 12px 0;
}

/* 桌面端折叠为图标模式，而不是完全隐藏 */
@media(min-width:993px){
  body.sidebar-collapsed .sidebar{
    width:76px;
    transform:none!important;
  }
  body.sidebar-collapsed .main{
    margin-left:76px;
  }
  body.sidebar-collapsed .brand{
    padding:0 14px;
    justify-content:center;
  }
  body.sidebar-collapsed .brand-logo{
    width:44px;
    height:44px;
  }
  body.sidebar-collapsed .brand-title,
  body.sidebar-collapsed .brand-sub,
  body.sidebar-collapsed .menu-title,
  body.sidebar-collapsed .menu-parent span,
  body.sidebar-collapsed .menu-chevron,
  body.sidebar-collapsed .submenu,
  body.sidebar-collapsed .user-name,
  body.sidebar-collapsed .user-role,
  body.sidebar-collapsed .sidebar-collapse-hint{
    display:none!important;
  }
  body.sidebar-collapsed .menu{
    padding:14px 8px;
  }
  body.sidebar-collapsed .menu-parent{
    justify-content:center;
    padding:12px 0;
  }
  body.sidebar-collapsed .menu-parent i:first-child{
    width:auto;
    font-size:20px;
  }
  body.sidebar-collapsed .menu-parent.active:before{
    left:-8px;
  }
  body.sidebar-collapsed .sidebar-footer{
    padding:12px 8px 16px;
  }
  body.sidebar-collapsed .user-mini{
    justify-content:center;
    padding:8px 0;
  }
  body.sidebar-collapsed .avatar{
    width:40px;
    height:40px;
  }
}

/* 移动端仍然保留抽屉 + 遮罩 */
@media(max-width:992px){
  .submenu{
    padding-left:36px;
  }
  body.sidebar-collapsed .sidebar{
    transform:translateX(-100%)!important;
  }
  body.sidebar-collapsed .main{
    margin-left:0;
  }
}
