/* ================================================================
   CRM Pro – Feishu/DingTalk 风格现代商务主题
   只修改此文件，所有 class 名保持不变
   ================================================================ */

/* —— 1. 设计 Token —— */
:root{
  --primary:#3370FF;
  --primary-hover:#2860E1;
  --primary-light:#EBF1FF;
  --primary2:#34C759;
  --success:#34C759;
  --danger:#F53F3F;
  --warning:#FF7D00;
  --info:#3370FF;

  --text:#1F2329;
  --text-secondary:#646A73;
  --muted:#8F959E;
  --border:#DEE0E3;
  --border-light:#F0F1F2;

  --bg-page:#F5F6F7;
  --bg-card:#FFFFFF;
  --bg-hover:#F5F6F7;
  --bg-selected:#EBF1FF;
  --bg-input:#FFFFFF;
  --bg-readonly:#F5F6F7;

  --shadow-sm:0 1px 2px rgba(0,0,0,.06);
  --shadow:0 2px 8px rgba(0,0,0,.08);
  --shadow-md:0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:0 8px 24px rgba(0,0,0,.12);

  --sidebar-bg:#2B2F36;
  --sidebar-text:rgba(255,255,255,.88);
  --sidebar-hover:rgba(255,255,255,.08);
  --sidebar-active:rgba(255,255,255,.12);

  --font:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei","Noto Sans SC",sans-serif;
  --font-heading:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei","Noto Sans SC",sans-serif;
  --font-body:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei","Noto Sans SC",sans-serif;

  --radius-sm:4px;
  --radius:6px;
  --radius-lg:8px;
  --radius-xl:12px;
  --radius-full:999px;

  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;

  --ring:0 0 0 3px rgba(51,112,255,.20);
  --card-stack-gap:8px;
  --section-stack-gap:8px;
  --block-gap:16px;
  --list-search-field-width:240px;
}

/* —— 2. 全局重置 —— */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:14px;
  color:var(--text);
  line-height:1.57;
  background:var(--bg-page);
}
a{color:inherit;text-decoration:none}
.cell-link,.cell-link:visited{color:var(--primary);text-decoration:none;transition:color .15s}
.cell-link:hover,.cell-link:focus-visible{color:var(--primary-hover);text-decoration:underline;text-underline-offset:2px}
.cell-link:active{color:#1D4ED8}
button,input,select,textarea{font:inherit}

:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
button:focus-visible,a:focus-visible,.tab:focus-visible{outline:2px solid var(--primary);outline-offset:2px;box-shadow:var(--ring)}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:var(--ring);border-color:var(--primary)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* —— 3. 布局 Shell —— */
.pro-shell{height:100vh;height:100dvh;display:flex;overflow:hidden}
.pro-sidebar{
  position:relative;
  width:220px;
  padding:12px 8px;
  background:var(--sidebar-bg);
  border-right:1px solid rgba(255,255,255,.06);
  display:flex;flex-direction:column;
  min-height:0;overflow:hidden;
}
.pro-sidebar::before,.pro-sidebar::after{content:none}
.pro-brand{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:10px;
  margin:0 0 8px;padding:10px 8px;
  border-radius:var(--radius-lg);
  border:none;background:transparent;box-shadow:none;
}
.pro-logo{
  width:32px;height:32px;border-radius:var(--radius);
  background:transparent;
  box-shadow:none;
  background-image:url("/pro/logo.png");
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
}
.pro-brand-title{font-family:var(--font-heading);font-weight:600;font-size:15px;color:var(--sidebar-text);letter-spacing:.2px}
.pro-brand-sub{color:rgba(255,255,255,.56);font-size:12px;margin-top:2px}

.pro-nav{
  position:relative;z-index:1;
  margin-top:4px;
  display:flex;flex-direction:column;gap:2px;
  flex:1;min-height:0;overflow:auto;
  padding:0 4px;
}
.pro-nav{-ms-overflow-style:none;scrollbar-width:none}
.pro-nav::-webkit-scrollbar{width:0;height:0}
.pro-nav-group{position:relative;display:flex;flex-direction:column;gap:2px}
.pro-nav-group-hd{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  position:relative;
  padding:8px 10px;
  border-radius:var(--radius);
  border:none;color:var(--sidebar-text);
  background:transparent;box-shadow:none;
  cursor:pointer;text-align:left;font:inherit;outline:none;
  appearance:none;-webkit-appearance:none;
  transition:background .15s,color .15s;
}
.pro-nav-group-hd:hover{background:var(--sidebar-hover)}
.pro-nav-group-hd.active{background:var(--sidebar-active);color:#fff}
.pro-nav-group-hd.active .pro-nav-icon{background:rgba(255,255,255,.20);color:#fff}
.pro-nav-group-hd:focus-visible{box-shadow:0 0 0 2px rgba(255,255,255,.20)}
.pro-nav-group-hd.indent{padding-left:28px}
.pro-nav-group-title{font-weight:600;font-size:14px;color:inherit}
.pro-nav-main{min-width:0;display:flex;align-items:center;gap:8px}
.pro-nav-icon{
  width:18px;height:18px;flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:var(--radius-sm);
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.72);
  overflow:hidden;
}
.pro-nav-icon svg{width:14px;height:14px;display:block}
.pro-nav-icon.leaf{width:16px;height:16px;border-radius:4px;background:transparent;color:rgba(255,255,255,.56)}
.pro-nav-icon.leaf svg{width:12px;height:12px}
.pro-nav-toggle{
  width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;
  background:transparent;border:none;color:rgba(255,255,255,.56);
  line-height:1;transition:transform .15s;
}
.pro-nav-toggle::before{content:"";width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-1px);transition:transform .15s}
.pro-nav-group[data-collapsed="0"] .pro-nav-toggle::before{transform:rotate(225deg) translateY(-1px)}
.pro-nav-group-hd:hover .pro-nav-toggle,.pro-nav-group-hd.active .pro-nav-toggle{color:rgba(255,255,255,.76)}
.pro-nav-children{position:relative;display:flex;flex-direction:column;gap:2px;margin:0 0 2px 8px;padding:0 0 0 10px}
.pro-nav-children::before{content:none}
.pro-nav a{
  display:flex;align-items:center;justify-content:space-between;
  position:relative;padding:7px 10px;
  border-radius:var(--radius);border:none;
  color:rgba(255,255,255,.76);background:transparent;box-shadow:none;
  transition:background .15s,color .15s;
  font-size:14px;font-weight:400;
}
.pro-nav>a{font-size:14px;font-weight:600}
.pro-nav a:hover{background:var(--sidebar-hover)}
.pro-nav a.active{color:#fff;background:var(--sidebar-active);font-weight:500}
.pro-nav a.active .pro-nav-icon{background:rgba(255,255,255,.20);color:#fff}
.pro-nav a.indent{padding-left:28px;font-size:13px;font-weight:400;color:rgba(255,255,255,.68)}
.pro-nav a.indent.active{color:#fff;font-weight:500}
.pro-nav .desc{color:rgba(255,255,255,.52);font-size:12px;margin-top:2px}
.pro-nav .left{display:flex;flex-direction:column}
.pro-nav .badge{font-size:12px;color:rgba(255,255,255,.88);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.10);padding:2px 8px;border-radius:var(--radius-full)}
.pro-sidebar .muted{color:rgba(255,255,255,.52)}

.pro-main{flex:1;min-width:0;padding:0;display:flex;flex-direction:column;min-height:0}
.pro-topbar{
  position:relative;z-index:40;overflow:visible;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 16px;
  border:1px solid var(--border-light);
  border-radius:0;
  background:var(--bg-card);
  box-shadow:var(--shadow-sm);
}
.pro-title{flex:1;min-width:0;font-weight:600;font-size:16px;letter-spacing:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.pro-userline{flex:0 0 auto;display:flex;align-items:center;gap:8px;color:var(--muted);margin-left:auto}
.pro-icon-btn{
  position:relative;width:32px;height:32px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--border);border-radius:var(--radius-full);
  background:var(--bg-card);color:var(--muted);cursor:pointer;
  transition:background .15s,color .15s,border-color .15s;
}
.pro-icon-btn:hover{color:var(--primary);border-color:var(--primary-light);background:var(--primary-light)}
.pro-icon-btn svg{width:18px;height:18px;display:block;fill:currentColor}
.pro-bell-badge{
  position:absolute;top:-3px;right:-5px;
  min-width:16px;height:16px;padding:0 4px;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-full);
  background:var(--danger);color:#fff;
  font-size:10px;font-weight:600;line-height:16px;
}
.pro-pill{padding:4px 10px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}
.pro-avatar{width:32px;height:32px;border-radius:var(--radius-full);border:1px solid var(--border-light);background:var(--bg-card);object-fit:cover;flex:0 0 auto}
.pro-account{position:relative;display:flex;align-items:center}
.pro-account-trigger{display:inline-flex;align-items:center;gap:4px;padding:0;border:none;background:transparent;cursor:pointer}
.pro-account-caret{color:var(--muted);font-size:12px;line-height:1}
.pro-account-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  min-width:160px;padding:4px;
  border:1px solid var(--border);border-radius:var(--radius-lg);
  background:var(--bg-card);
  box-shadow:var(--shadow-md);
  display:none;z-index:60;
}
.pro-account.open .pro-account-menu{display:block}
.pro-account-item{
  width:100%;display:flex;align-items:center;justify-content:flex-start;
  padding:8px 10px;border:none;border-radius:var(--radius);
  background:transparent;color:var(--text);cursor:pointer;text-align:left;
  font-size:13px;transition:background .15s;
}
.pro-account-item:hover{background:var(--bg-hover)}
.pro-account-item.danger{color:var(--danger)}
.pro-account-item.danger:hover{background:#FFF0F0}
/* —— 面包屑 —— */
.pro-breadcrumb{display:flex;align-items:center;gap:0;flex:1;min-width:0;font-size:14px;font-weight:600;overflow:hidden;white-space:nowrap}
.pro-breadcrumb-item{display:inline-flex;align-items:center;gap:0;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pro-breadcrumb-item:last-child{color:var(--text);font-weight:600}
.pro-breadcrumb-link{color:var(--muted);text-decoration:none;cursor:pointer;transition:color .15s;white-space:nowrap}
.pro-breadcrumb-link:hover{color:var(--primary)}
.pro-breadcrumb-sep{margin:0 6px;color:var(--border);font-weight:400;user-select:none;flex:0 0 auto}

/* —— 侧边栏颜色选择器 —— */
.pro-sidebar-theme{position:relative;z-index:1;margin-top:auto;padding:10px 8px 4px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:6px}
.pro-sidebar-theme-label{font-size:11px;color:rgba(255,255,255,.44);letter-spacing:.2px}
.pro-sidebar-theme-colors{display:flex;gap:6px;flex-wrap:wrap}
.pro-sidebar-theme-dot{
  width:20px;height:20px;border-radius:var(--radius-full);border:2px solid transparent;
  cursor:pointer;transition:border-color .15s,transform .15s;flex:0 0 auto;
}
.pro-sidebar-theme-dot:hover{transform:scale(1.15)}
.pro-sidebar-theme-dot.active{border-color:rgba(255,255,255,.72);box-shadow:0 0 0 2px rgba(255,255,255,.20)}

.pro-content{margin-top:8px;flex:1;min-width:0;display:flex;flex-direction:column;min-height:0;overflow:auto}
.pro-content{-ms-overflow-style:none;scrollbar-width:none}
.pro-content::-webkit-scrollbar{width:0;height:0}

/* —— 4. 列表布局 —— */
.list-card{display:flex;flex-direction:column;flex:1;min-height:0}
.list-card>.row{order:1}
.list-card .list-search-row{row-gap:10px}
.list-card .list-search-row>.field{flex:0 0 min(var(--list-search-field-width),100%)!important;width:min(var(--list-search-field-width),100%)!important;min-width:min(var(--list-search-field-width),100%)!important;max-width:100%}
.list-card .list-search-row>.field>input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
.list-card .list-search-row>.field>select,
.list-card .list-search-row>.field>.pro-select-wrap{width:100%!important}
.list-card .customer-report-date-search-field{flex:0 0 292px;width:292px;min-width:292px;max-width:100%}
.list-card .customer-report-search-row{align-items:end}
.list-card>.card-hd{order:2;margin-top:10px}
.list-card>.card-hd .card-title,.list-card>.card-hd .card-sub{display:none}
.list-card>.table-wrap{order:3;flex:1;min-height:0;margin-top:8px}
.list-card>.pager{order:4;margin-top:auto;padding-top:12px;border-top:none}
@supports selector(.x:has(*)){
  .list-card>.card-hd:not(:has(.btn)):not(:has(.btn-group)):not(:has(select)){display:none;margin-top:0}
  .list-card:has(.card-hd) .row button[id$="-search"],
  .list-card:has(.card-hd) .row button[id$="-reset"]{visibility:hidden}
}
@media (max-width:768px){
  .list-card .list-search-row>.field{flex:1 1 100%!important;width:100%!important;min-width:100%!important}
}
.fixed-pager-card{display:flex;flex-direction:column;flex:1;min-height:0}
.fixed-pager-card>.table-wrap{flex:1;min-height:0}
.fixed-pager-card>.pager{margin-top:auto;padding-top:12px;border-top:1px solid var(--border-light)}

/* —— 5. 卡片 —— */
.card{
  border-radius:var(--radius-lg);
  border:1px solid var(--border-light);
  background:var(--bg-card);
  box-shadow:var(--shadow-sm);
  min-width:0;padding:16px;
}
.card+.card{margin-top:var(--card-stack-gap)!important}
.card-hd{display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-hd-right{display:flex;align-items:center;gap:8px;justify-content:flex-end;margin-left:auto}
.card-title{font-family:var(--font-heading);font-weight:600;font-size:15px;line-height:1.4;color:var(--text)}
.card-sub{color:var(--muted);font-size:12px;margin-top:4px}
.report-detail-section{margin-top:var(--section-stack-gap);padding-top:var(--block-gap);border-top:1px solid var(--border-light)}
.report-detail-section-title{display:block;font-weight:600;font-size:14px;line-height:1.4;color:var(--text);padding-bottom:10px;border-bottom:1px solid var(--border-light)}
.section-title-inline{display:block;font-weight:600;font-size:14px;line-height:1.4;color:var(--text);padding-bottom:10px;border-bottom:1px solid var(--border-light)}
.form-section-group{margin-top:var(--section-stack-gap)}
.subtable-section-title{margin-top:12px;font-size:14px;font-weight:600;line-height:1.4;color:var(--text)}
.section-block-title{margin-top:10px;font-size:14px;font-weight:600;line-height:1.4;color:var(--text)}
.report-detail-action-box{
  margin-top:8px;padding:14px;border:1px solid var(--border-light);
  border-radius:var(--radius-lg);background:var(--bg-page);
  box-shadow:none;
}
.report-detail-action-box .report-detail-section-title{margin-bottom:10px;color:var(--primary)}
.report-detail-soft-section{border-top-color:var(--border-light)}
.report-detail-soft-table{border:none;border-radius:0;background:transparent;margin-top:8px}
.report-detail-soft-table table{background:transparent}
.report-detail-soft-table thead th{background:var(--bg-page)}
.report-detail-soft-records{margin-top:12px;padding:0;border:none;box-shadow:none;background:transparent}
.report-detail-soft-records .card-hd{padding-top:12px;border-top:1px solid var(--border-light)}
.report-detail-soft-records .card-title{font-size:14px;font-weight:600;color:var(--text)}
.report-detail-soft-table-compact table{font-size:inherit}
.report-detail-soft-table-compact thead th,.report-detail-soft-table-compact tbody td{padding-top:8px;padding-bottom:8px}
.vehicle-approval-records .report-detail-section{border-top:none}
.vehicle-approval-records .report-detail-section-title{border-bottom:none}
.vehicle-approval-records .report-detail-soft-table{border:none;border-radius:0}
.workflow-approval-records .report-detail-section{border-top:none}
.workflow-approval-records .report-detail-section-title{border-bottom:none}
.workflow-approval-records .report-detail-soft-table{border:none;border-radius:0}
.muted{color:var(--muted)}
.danger-text{color:var(--danger)}
.info-text{color:var(--primary)}
.ok-text{color:var(--success)}

/* —— 6. 标签 —— */
.tag{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:22px;padding:2px 8px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg-page);
  font-size:12px;line-height:1.4;font-weight:500;
  color:var(--text-secondary);white-space:nowrap;
}
.tag.warn{border-color:#FFE4BA;background:#FFF7EB;color:#B25000}
.tag.danger{border-color:#FDCDC5;background:#FFF0ED;color:#CB2634}
.tag.ok{border-color:#B2E1B5;background:#E8F8E9;color:#006428}
.tag.info{border-color:#B4D4FF;background:#EDF4FF;color:#1456CB}

/* —— 7. Tab —— */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--border-light)}
.tab{
  padding:8px 16px;
  border-radius:0;
  border:none;border-bottom:2px solid transparent;
  background:transparent;
  color:var(--text-secondary);
  cursor:pointer;user-select:none;
  font-size:14px;font-weight:500;
  transition:color .15s,border-color .15s;
}
.tab:hover{color:var(--text);border-bottom-color:var(--border)}
.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600;background:transparent}

/* —— 8. 表单 —— */
.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.row+.row{margin-top:8px}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:12px;color:var(--text-secondary);font-weight:500}
.field-value{min-height:32px;padding:6px 0;line-height:1.5;word-break:break-all}
.form-grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:start}
.form-grid-4+.form-grid-4{margin-top:12px}
.form-grid-4>.field,.form-grid-field{min-width:0}
.form-grid-4>.field>input,.form-grid-4>.field>select,.form-grid-4>.field>textarea,.form-grid-4>.field>.pro-select-wrap,
.form-grid-field>input,.form-grid-field>select,.form-grid-field>textarea,.form-grid-field>.pro-select-wrap{width:100%;min-width:0}
.form-grid-4>.field>label,.form-grid-field>label{line-height:1.4;white-space:normal;word-break:break-word}
.form-span-1{grid-column:span 1}
.form-span-2{grid-column:span 2}
.form-span-3{grid-column:span 3}
.form-span-4{grid-column:1/-1}
.form-size-s{min-width:150px}
.form-size-m{min-width:200px}
.form-size-l{min-width:260px}
@media (max-width:960px){.form-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.form-span-3{grid-column:1/-1}}
@media (max-width:640px){.form-grid-4{grid-template-columns:1fr}.form-span-2,.form-span-3{grid-column:1/-1}}

input,select,textarea{
  background:var(--bg-input);color:var(--text);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:7px 10px;outline:none;font-family:var(--font-body);
  font-size:14px;
  transition:border-color .15s,box-shadow .15s;
}
.list-card>.row input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
.list-card>.row select,
.list-card>.row .pro-select-trigger{height:32px;min-height:32px}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{box-shadow:var(--ring);border-color:var(--primary)}

/* ── Select 选择器 ── */
select.select-placeholder{color:var(--muted)}
select.select-placeholder option{color:var(--text)}
select.select-placeholder option[value=""]{color:var(--muted)}
select[multiple]{min-width:280px;min-height:220px}

/* ── 自定义 Select 下拉 ── */
.pro-select-wrap{position:relative;display:inline-block;vertical-align:middle;max-width:100%}
.field>.pro-select-wrap{display:block}
.pro-select-wrap,.pro-select-wrap select{font-size:14px;font-family:var(--font-body)}
.pro-select-wrap select{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:1}
.pro-select-wrap select:focus{outline:none;box-shadow:none}
.pro-select-trigger{
  display:flex;align-items:center;
  min-height:32px;padding:7px 30px 7px 10px;
  background:var(--bg-input);color:var(--text);
  border:1px solid var(--border);border-radius:var(--radius);
  cursor:pointer;user-select:none;
  transition:border-color .15s,box-shadow .15s;
  overflow:hidden;
}
.pro-select-trigger-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pro-select-trigger::after{
  content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:0;height:0;
  border-left:5px solid transparent;border-right:5px solid transparent;
  border-top:5px solid var(--muted);
  pointer-events:none;transition:transform .2s;
}
.pro-select-wrap.pro-select-open .pro-select-trigger::after{transform:translateY(-50%) rotate(180deg)}
.pro-select-wrap.pro-select-open .pro-select-trigger,
.pro-select-wrap:hover .pro-select-trigger{border-color:var(--primary)}
.pro-select-wrap.pro-select-open .pro-select-trigger{box-shadow:var(--ring)}
.pro-select-wrap.pro-select-placeholder .pro-select-trigger-text{color:var(--muted)}
.pro-select-wrap.pro-select-disabled .pro-select-trigger{background:var(--bg-readonly);color:var(--text-secondary);cursor:default}
.pro-select-wrap.pro-select-disabled:hover .pro-select-trigger{border-color:var(--border)}
.pro-select-wrap.pro-select-disabled .pro-select-trigger::after{border-top-color:var(--border)}
.pro-select-drop{
  display:none;position:absolute;z-index:1060;
  left:0;right:0;margin-top:2px;
  background:var(--bg-card);
  border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  max-height:280px;overflow-y:auto;
  overscroll-behavior:contain;
}
.pro-select-drop.open{display:block}
.pro-select-drop-empty{padding:10px 12px;color:var(--muted);font-size:13px;text-align:center}
.pro-select-opt{display:block;width:100%;text-align:left;padding:7px 12px;border:none;background:none;cursor:pointer;font-size:14px;color:var(--text);transition:background .1s}
.pro-select-opt:hover{background:var(--bg-hover)}
.pro-select-opt.selected{background:var(--bg-selected);color:var(--primary);font-weight:500}
.pro-select-optgroup-label{display:block;padding:6px 12px 4px;font-size:12px;font-weight:600;color:var(--muted);cursor:default;pointer-events:none}

/* ── Pager select ── */
.pro-pager-size{font-size:13px}
.pro-pager-size .pro-select-trigger{
  min-height:26px;padding:3px 26px 3px 8px;font-size:13px;color:var(--text-secondary);
  border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);
}
.pro-pager-size .pro-select-trigger::after{right:7px;border-left-width:4px;border-right-width:4px;border-top-width:4px}
.pro-pager-size .pro-select-drop{font-size:13px}
.field>input[readonly]:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="hidden"]),
.field>input[disabled]:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="hidden"]),
.field>textarea[readonly],.field>textarea[disabled],
.field>select[disabled],
body.pro-detail-page input[readonly],body.pro-detail-page input[disabled],
body.pro-detail-page textarea[readonly],body.pro-detail-page textarea[disabled],
body.pro-detail-page select[disabled],
.readonly-display[readonly],.readonly-display[disabled],
textarea.readonly-display[readonly],textarea.readonly-display[disabled],
select.readonly-display[disabled]{
  background:var(--bg-readonly);color:var(--text-secondary);
  pointer-events:none;user-select:none;-webkit-user-select:none;
  caret-color:transparent;cursor:default;
}
.field>input[readonly]:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="hidden"]):focus,
.field>input[disabled]:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="hidden"]):focus,
.field>textarea[readonly]:focus,.field>textarea[disabled]:focus,
.field>select[disabled]:focus,
.readonly-display[readonly]:focus,.readonly-display[disabled]:focus,
textarea.readonly-display[readonly]:focus,textarea.readonly-display[disabled]:focus,
select.readonly-display[disabled]:focus{box-shadow:none;border-color:var(--border)}
.field-link-value{
  min-height:32px;padding:7px 10px;
  border:1px solid var(--border);border-radius:var(--radius);
  background:var(--bg-readonly);color:var(--text-secondary);
  display:flex;align-items:center;line-height:1.5;word-break:break-all;
}
.field-help{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1px solid var(--border);background:var(--bg-readonly);color:var(--muted);font-size:12px;font-weight:600;line-height:1;cursor:help;vertical-align:middle}
.vehicle-return-detail-card .field-value,
.vehicle-use-detail-card .field-value,
.vehicle-insurance-detail-card .field-value,
.vehicle-inspection-detail-card .field-value,
.vehicle-basic-info-detail-card .field-value,
.asset-card-detail-card .field-value,
.asset-use-detail-card .field-value,
.asset-return-detail-card .field-value,
.hr-roster-detail-card .field-value{
  min-height:32px;padding:7px 10px;
  border:1px solid var(--border);border-radius:var(--radius);
  background:var(--bg-readonly);color:var(--text-secondary);
  display:flex;align-items:center;line-height:1.5;word-break:break-all;
}

/* —— 选择器组件 —— */
.role-menu-picker,.user-role-picker,.workflow-dept-picker{
  border:1px solid var(--border);border-radius:var(--radius-lg);
  background:var(--bg-card);overflow:hidden;box-shadow:var(--shadow);
}
.role-menu-toolbar,.user-role-toolbar,.workflow-dept-toolbar{
  display:flex;flex-direction:column;gap:8px;padding:12px 16px;
  border-bottom:1px solid var(--border-light);background:transparent;
}
.role-menu-filter-bar,.user-role-filter-bar,.workflow-dept-filter-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.role-menu-toolbar-main,.user-role-toolbar-main,.workflow-dept-toolbar-main{display:flex;align-items:flex-start;gap:8px;flex-wrap:nowrap;min-width:0;flex:1}
.role-menu-search-field,.user-role-search-field,.workflow-dept-search-field{display:flex;flex-direction:column;gap:4px;flex:1 1 0;min-width:220px}
.role-menu-search-field label,.user-role-search-field label,.workflow-dept-search-field label{font-size:12px;line-height:1.4;color:var(--text-secondary);font-weight:500}
.role-menu-toolbar-main input,.user-role-toolbar-main input,.workflow-dept-toolbar-main input{width:min(320px,100%);min-width:0}
.role-menu-toolbar-bottom,.user-role-toolbar-bottom,.workflow-dept-toolbar-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;width:100%}
.role-menu-toolbar-actions,.user-role-toolbar-actions,.workflow-dept-toolbar-actions{flex:0 0 auto;margin-left:auto}
.role-menu-toolbar-meta,.user-role-toolbar-meta,.workflow-dept-toolbar-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1 1 auto}
.role-menu-toolbar-meta .role-menu-stat,.role-menu-stat,.user-role-stat,.workflow-dept-stat{
  display:inline-flex;align-items:center;min-height:26px;padding:0 10px;
  border-radius:var(--radius-full);border:1px solid var(--border);
  background:var(--bg-page);color:var(--text-secondary);
  font-size:12px;font-weight:500;white-space:nowrap;
}
.role-menu-toolbar-meta .role-menu-stat.accent,.user-role-stat.accent,.workflow-dept-stat.accent{border-color:var(--primary-light);background:var(--primary-light);color:var(--primary)}

.role-menu-tree{max-height:460px;overflow:auto;padding:0}
.role-menu-group{border:none;border-bottom:1px solid var(--border-light);border-radius:0;background:transparent;box-shadow:none}
.role-menu-group+.role-menu-group{margin-top:0}
.role-menu-group-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:8px 12px;flex-wrap:wrap;background:transparent}
.role-menu-group-main{flex:1;min-width:280px}
.role-menu-group-tools{display:flex;align-items:center;justify-content:flex-end;gap:4px;flex-wrap:wrap}
.role-menu-group-bd{padding:0 12px 8px}
.role-menu-node+.role-menu-node{margin-top:1px}
.role-menu-children{margin-left:12px;padding-left:12px;border-left:1px dashed var(--border)}
.role-menu-line{display:flex;align-items:flex-start;gap:8px;padding:5px 8px;border-radius:var(--radius);transition:background .12s}
.role-menu-line:hover{background:var(--bg-hover)}
.role-menu-root-line{padding:0}
.role-menu-toggle,.role-menu-toggle-placeholder{width:20px;height:20px;flex:0 0 20px}
.role-menu-toggle{position:relative;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted);cursor:pointer;box-shadow:none}
.role-menu-toggle:hover{color:var(--text-secondary)}
.role-menu-toggle::before{content:"";position:absolute;left:6px;top:5px;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(-45deg);transition:transform .12s}
.role-menu-toggle.collapsed::before{transform:rotate(45deg)}
.role-menu-option{flex:1;min-width:0;display:flex;align-items:flex-start;gap:6px;cursor:pointer}
.role-menu-option input{margin-top:2px}
.role-menu-text{min-width:0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.role-menu-name{font-weight:500;line-height:1.3;word-break:break-word;color:var(--text)}
.role-menu-sub{font-size:12px;line-height:1.4;color:var(--muted);word-break:break-all;white-space:nowrap}
.role-menu-mini-btn{min-height:30px;padding:6px 10px;font-size:13px}
.role-menu-empty{padding:28px 12px;text-align:center;color:var(--muted)}

.user-role-list{max-height:260px;overflow:auto;padding:8px 10px}
.user-role-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid transparent;border-radius:var(--radius);background:transparent;cursor:pointer;transition:background .12s}
.user-role-item+.user-role-item{margin-top:2px}
.user-role-item:hover{background:var(--bg-hover)}
.user-role-item.checked{background:var(--bg-selected);border-color:var(--primary-light)}
.user-role-item-main{min-width:0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.user-role-item-name{font-weight:500;line-height:1.4;color:var(--text)}
.user-role-item-code{font-size:12px;line-height:1.4;color:var(--muted);white-space:nowrap}

.user-form-profile-row{align-items:flex-start}
.user-form-avatar-field{min-width:320px}
.user-form-avatar-box{min-height:124px}
.user-form-avatar-preview{flex:0 0 112px}
.user-form-avatar-actions{min-width:200px}
.user-form-side-fields{min-width:320px}
.user-form-reset-box{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.workflow-dept-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:0}
.workflow-dept-field{gap:4px}
.workflow-dept-helper{
  display:inline-flex;align-items:center;min-height:22px;padding:0 8px;
  border-radius:var(--radius-full);border:1px solid #FFE4BA;
  background:#FFF7EB;color:#B25000;font-size:12px;line-height:1.2;font-weight:500;white-space:nowrap;
}
.workflow-dept-list{max-height:220px;overflow:auto;padding:8px 10px}
.workflow-dept-item,.wf-dept-item{
  display:flex;align-items:center;gap:8px;width:100%;box-sizing:border-box;
  padding:6px 8px;border:1px solid transparent;border-radius:var(--radius);
  background:transparent;cursor:pointer;transition:background .12s;
}
.workflow-dept-item+.workflow-dept-item,.wf-dept-item+.wf-dept-item{margin-top:2px}
.workflow-dept-item:hover,.wf-dept-item:hover{background:var(--bg-hover)}
.workflow-dept-item.checked,.wf-dept-item.checked{background:var(--bg-selected);border-color:var(--primary-light)}
.workflow-dept-item input,.wf-dept-item input{margin-top:2px}
.workflow-dept-item-main,.wf-dept-item-main{min-width:0;line-height:1.4;font-weight:500;color:var(--text)}

@media (max-width:768px){
  .role-menu-tree{max-height:none;padding:0}
  .role-menu-toolbar-main{flex-wrap:wrap}
  .role-menu-search-field{min-width:0;flex:1 1 100%}
  .role-menu-toolbar-main input{width:100%;min-width:0}
  .role-menu-filter-bar{align-items:stretch}
  .role-menu-toolbar-bottom{align-items:stretch}
  .role-menu-toolbar-actions{width:auto;justify-content:flex-end}
  .role-menu-group-hd{padding:8px}
  .role-menu-group-bd{padding:0 8px 8px}
  .role-menu-children{margin-left:8px;padding-left:8px}
  .user-role-toolbar{align-items:stretch}
  .user-role-toolbar-main{flex-wrap:wrap}
  .user-role-search-field{min-width:0;flex:1 1 100%}
  .user-role-toolbar-main input{width:100%;min-width:0}
  .user-role-filter-bar{align-items:stretch}
  .user-role-toolbar-bottom{align-items:stretch}
  .user-role-toolbar-actions{width:auto;justify-content:flex-end;margin-left:0}
  .user-form-avatar-field,.user-form-side-fields{min-width:100%;flex:1 1 100%}
  .user-form-avatar-box{min-height:0}
  .user-form-reset-box{align-items:stretch}
  .workflow-dept-toolbar{align-items:stretch}
  .workflow-dept-toolbar-main{flex-wrap:wrap}
  .workflow-dept-search-field{min-width:0;flex:1 1 100%}
  .workflow-dept-toolbar-main input{width:100%;min-width:0}
  .workflow-dept-filter-bar{align-items:stretch}
  .workflow-dept-toolbar-bottom{align-items:stretch}
  .workflow-dept-toolbar-actions{width:auto;justify-content:flex-end;margin-left:0}
}

/* —— 9. 按钮 —— */
.btn{
  border:1px solid var(--border);
  background:var(--bg-card);color:var(--text);
  padding:6px 14px;border-radius:var(--radius);
  cursor:pointer;min-height:32px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:500;line-height:1.2;white-space:nowrap;
  transition:background .15s,color .15s,border-color .15s,box-shadow .15s;
}
.btn:hover{border-color:var(--primary-light);background:var(--primary-light);color:var(--primary)}
.btn.primary{color:#fff;background:var(--primary);border-color:var(--primary)}
.btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}
.btn.primary:active{background:#1D4ED8;border-color:#1D4ED8}
.btn.danger{color:var(--danger);background:#FFF0ED;border-color:#FDCDC5}
.btn.danger:hover{background:#FFE0DA;border-color:#FDB8AE}
.btn.ghost{background:transparent;border-color:transparent}
.btn.ghost:hover{background:var(--bg-hover);border-color:transparent}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
.btn.tone-blue{color:#1456CB;background:#EDF4FF;border-color:#B4D4FF}
.btn.tone-blue:hover{background:#DBE9FF;border-color:#8DBFFF}
.btn.tone-green{color:#006428;background:#E8F8E9;border-color:#B2E1B5}
.btn.tone-green:hover{background:#D4F2D6;border-color:#8BCF90}
.btn.tone-red{color:#CB2634;background:#FFF0ED;border-color:#FDCDC5}
.btn.tone-red:hover{background:#FFE0DA;border-color:#FDB8AE}
.btn.tone-slate{color:var(--text-secondary);background:var(--bg-page);border-color:var(--border)}
.btn.tone-slate:hover{background:#ECEEF0;border-color:#C2C6CC}
.btn.tone-amber{color:#B25000;background:#FFF7EB;border-color:#FFE4BA}
.btn.tone-amber:hover{background:#FFF0D6;border-color:#FFD58A}
.btn.tone-cyan{color:#00688A;background:#E5F9FF;border-color:#A3D9F0}
.btn.tone-cyan:hover{background:#D0F3FF;border-color:#7BCBE8}
.btn.tone-indigo{color:#1456CB;background:#EDF4FF;border-color:#B4D4FF}
.btn.tone-indigo:hover{background:#DBE9FF;border-color:#8DBFFF}
.btn.tone-approval{color:#006428;background:#E8F8E9;border-color:#B2E1B5}
.btn.tone-approval:hover{background:#D4F2D6;border-color:#8BCF90}
.btn.wf-reassign-btn{color:#1456CB;background:#EDF4FF;border-color:#B4D4FF;box-shadow:none}
.btn.wf-reassign-btn:hover{background:#DBE9FF;border-color:#8DBFFF}
.btn.wf-activate-btn{color:#00688A;background:#E5F9FF;border-color:#A3D9F0;box-shadow:none}
.btn.wf-activate-btn:hover{background:#D0F3FF;border-color:#7BCBE8}
.btn-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.spacer{flex:1}

/* —— 10. 表格 —— */
.table-wrap{width:100%;margin-top:12px;overflow:auto;border-radius:var(--radius-lg);border:1px solid var(--border-light)}
table{width:100%;border-collapse:collapse;background:var(--bg-card)}
th,td{padding:8px 12px;border-bottom:1px solid var(--border-light);text-align:left;vertical-align:top}
th{color:var(--text-secondary);font-weight:500;font-size:13px}
thead th{position:sticky;top:0;background:var(--bg-page);z-index:1}
tr:hover td{background:var(--bg-hover)}
body.pro-detail-page tr:hover td{background:transparent}
.list-card tbody tr{height:48px}
.list-card tbody td{vertical-align:middle;white-space:nowrap;line-height:20px;height:48px;padding-top:0;padding-bottom:0;font-size:14px}
.list-card tbody td:not(.cell-actions){overflow:hidden;text-overflow:ellipsis}
.table-empty-row td{text-align:center;vertical-align:middle}
.table-empty-row:hover td{background:transparent}
.table-empty-row.borderless td{border-bottom:none;pointer-events:none;background:transparent}
.row-middle td{vertical-align:middle}
.cell-text-middle{height:34px;line-height:20px}
.subtable-compact input{padding:4px 8px;min-height:28px}
.subtable-compact .pro-select-trigger{padding:4px 28px 4px 8px;min-height:28px;font-size:13px}
.subtable-compact .pro-select-trigger::after{right:8px;border-left-width:4px;border-right-width:4px;border-top-width:4px}
.subtable-compact td{padding-top:6px;padding-bottom:6px}
.subtable-compact th,.subtable-compact td{overflow:hidden}
.subtable-compact th{vertical-align:middle;font-size:13px;font-weight:500;color:var(--text-secondary)}
.subtable-compact .center{text-align:center}
.subtable-compact .th-check{display:flex;align-items:center;justify-content:center}
.subtable-compact .th-check input{margin:0}
.subtable-compact input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
.subtable-compact select,
.subtable-compact textarea{
  display:block;width:100%;max-width:100%;min-width:0;box-sizing:border-box
}
.subtable-compact .product-cell-select{width:100%;max-width:100%;display:block}
.subtable-compact td>.pro-select-wrap{display:block;width:100%;max-width:100%}
.subtable-compact td>.pro-select-wrap .pro-select-trigger{width:100%;box-sizing:border-box}
.subtable-scrollbar{height:14px;padding:2px 0;scrollbar-width:thin;scrollbar-color:var(--muted) transparent}
.subtable-scrollbar::-webkit-scrollbar{height:8px}
.subtable-scrollbar::-webkit-scrollbar-track{border-radius:var(--radius-full);background:var(--bg-page)}
.subtable-scrollbar::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:var(--border);border:2px solid transparent;background-clip:padding-box}
.subtable-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--muted);border:2px solid transparent;background-clip:padding-box}
.contract-items-table{table-layout:fixed}
.nowrap{white-space:nowrap}
.ellipsis{display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom}
.list-card tbody .ellipsis{vertical-align:middle}
.workflow-comment-cell{width:320px;max-width:320px}
.workflow-comment-cell .ellipsis{max-width:320px;vertical-align:middle}
.td-roles{max-width:240px;width:240px}
.cell-actions{display:flex;gap:8px;flex-wrap:nowrap;align-items:center;height:48px}
.workbench-table{table-layout:fixed}
.workbench-task-table{min-width:1330px}
.workbench-notify-table{min-width:1280px}
.workbench-table td .cell-link,.workbench-table td .wb-cell-link{display:block;width:100%;max-width:100%;vertical-align:middle}
.workbench-table td .ellipsis,.workbench-table td .wb-cell-ellipsis{display:block;width:100%;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}
.workbench-task-table td.wb-col-task-code{width:180px;max-width:180px}
.workbench-task-table th.wb-col-task-type,.workbench-task-table td.wb-col-task-type{width:160px;max-width:160px}
.workbench-task-table th.wb-col-task-code,.workbench-task-table td.wb-col-task-code{width:180px;max-width:180px}
.workbench-task-table th.wb-col-task-step,.workbench-task-table td.wb-col-task-step{width:180px;max-width:180px}
.workbench-task-table th.wb-col-task-role,.workbench-task-table td.wb-col-task-role{width:160px;max-width:160px}
.workbench-task-table th.wb-col-task-user,.workbench-task-table td.wb-col-task-user{width:130px;max-width:130px}
.workbench-task-table th.wb-col-task-status,.workbench-task-table td.wb-col-task-status{width:130px;max-width:130px}
.workbench-task-table th.wb-col-task-time,.workbench-task-table td.wb-col-task-time{width:170px;max-width:170px}
.workbench-task-table th.wb-col-task-actions,.workbench-task-table td.wb-col-task-actions{width:240px;max-width:240px}
.workbench-notify-table th.wb-col-notify-source,.workbench-notify-table td.wb-col-notify-source{width:120px;max-width:120px}
.workbench-notify-table th.wb-col-notify-code,.workbench-notify-table td.wb-col-notify-code{width:160px;max-width:160px}
.workbench-notify-table th.wb-col-notify-title,.workbench-notify-table td.wb-col-notify-title{width:260px;max-width:260px}
.workbench-notify-table th.wb-col-notify-content,.workbench-notify-table td.wb-col-notify-content{width:420px;max-width:420px}
.workbench-notify-table th.wb-col-notify-time,.workbench-notify-table td.wb-col-notify-time{width:170px;max-width:170px}
.workbench-notify-table th.wb-col-notify-actions,.workbench-notify-table td.wb-col-notify-actions{width:150px;max-width:150px}

/* —— 11. 分页 —— */
.pager{display:flex;align-items:center;justify-content:flex-end;margin-top:12px;gap:8px;flex-wrap:wrap}
.pager .info{color:var(--muted);font-size:13px}
.pro-pager{flex-wrap:wrap}
.pro-pager-ctrl{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.pro-pager-pages{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.pro-pager-page{min-width:32px;text-align:center;border-radius:var(--radius);font-size:13px}
.pro-pager-page.active{background:var(--primary);border-color:var(--primary);color:#fff}
.pro-pager-dots{color:var(--muted);padding:0 2px;font-size:13px}
.pro-pager-size{min-width:100px}
.pro-pager-jump{width:36px;min-width:36px;text-align:center;padding:7px 8px;background:transparent}

/* —— 12. 弹窗 —— */
.modal-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  display:flex;align-items:center;justify-content:center;
  padding:16px;z-index:9999;
}
.modal{
  width:min(960px,96vw);max-height:min(86vh,860px);overflow:auto;
  border-radius:var(--radius-xl);
  border:1px solid var(--border);background:var(--bg-card);
  box-shadow:var(--shadow-lg);padding:20px;
}
.modal-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.modal-title{font-family:var(--font-heading);font-weight:600;font-size:16px;color:var(--text)}
.modal-actions{display:flex;gap:8px;align-items:center}
.modal-bd{margin-top:12px}

/* —— 13. Toast —— */
.toast{
  position:fixed;
  left:50%;top:14px;
  top:calc(env(safe-area-inset-top,0px) + 14px);
  transform:translateX(-50%);
  z-index:10000;width:max-content;max-width:min(920px,92vw);
  padding:10px 16px;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);background:var(--bg-card);
  box-shadow:var(--shadow-md);
}
.toast .t{font-weight:600;line-height:1.45;white-space:normal;word-break:break-word;font-size:14px}
.toast .m{color:var(--text-secondary);margin-top:2px;font-size:12px}
.toast.ok{border-color:#B2E1B5;background:#E8F8E9;color:#006428}
.toast.err{border-color:#FDCDC5;background:#FFF0ED;color:#CB2634}
.toast.warn{border-color:#FFE4BA;background:#FFF7EB;color:#B25000}

/* —— 14. 登录 —— */
.login-wrap{
  min-height:100vh;min-height:100dvh;
  display:grid;place-items:center;padding:20px 16px;
  background:var(--bg-page);
}
.login-card{
  width:min(420px,96vw);
  border-radius:var(--radius-xl);
  border:1px solid var(--border);background:var(--bg-card);
  box-shadow:var(--shadow-lg);padding:24px;
}
.login-hd{display:flex;align-items:center;gap:12px}
.login-hd-text{min-width:0}
.login-logo{
  width:48px;height:48px;border-radius:var(--radius-lg);
  background:var(--bg-page);border:1px solid var(--border-light);box-shadow:none;
  background-image:url("/pro/logo.png");background-repeat:no-repeat;background-position:center;background-size:contain;
}
.login-title{font-family:var(--font-heading);font-weight:600;font-size:18px;color:var(--text);letter-spacing:0}
.login-sub{color:var(--muted);font-size:13px;margin-top:4px}
.login-form{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.login-actions{margin-top:14px}
.login-btn{width:100%}
.login-foot{margin-top:10px;color:var(--muted);font-size:12px;text-align:center}
.captcha-wrap{display:flex;gap:10px;align-items:center}
.captcha-wrap input{flex:1;min-width:140px}
.captcha-img{
  width:120px;height:40px;object-fit:contain;
  border-radius:var(--radius);border:1px solid var(--border);
  background:#fff;cursor:pointer;user-select:none;
}
.captcha-img:active{transform:scale(.98)}
@media (max-width:520px){
  .login-card{padding:16px;border-radius:var(--radius-lg)}
  .login-logo{width:40px;height:40px;border-radius:var(--radius)}
}

/* —— 15. 响应式 —— */
@media (max-width:980px){.pro-sidebar{width:200px}}
@media (max-width:860px){
  .pro-shell{flex-direction:column}
  .pro-sidebar{width:auto;border-right:none;border-bottom:1px solid var(--border-light);padding-bottom:8px}
  .pro-main{padding:0}
  .pro-topbar{border-radius:0}
}
