*{margin:0;padding:0;box-sizing:border-box}
:root{--pri:#4F46E5;--pri-l:#818CF8;--ok:#10B981;--warn:#F59E0B;--err:#EF4444;--bg:#EEF2FF;--card:rgba(255,255,255,.82);--txt:#1E293B;--txt-l:#64748B;--bd:rgba(255,255,255,.55)}
body.dark{--bg:#0B1020;--card:rgba(22,30,52,.78);--txt:#E2E8F0;--txt-l:#94A3B8;--bd:rgba(129,140,248,.18)}
body.dark .login-page{background:
  radial-gradient(ellipse 120% 80% at 72% 18%,rgba(124,58,237,.55),transparent 52%),
  radial-gradient(ellipse 100% 70% at 18% 82%,rgba(6,182,212,.4),transparent 55%),
  radial-gradient(ellipse 80% 55% at 88% 88%,rgba(236,72,153,.32),transparent 50%),
  linear-gradient(160deg,#050816 0%,#12082b 38%,#0c1a3a 72%,#061525 100%)}
body.dark .login-card{background:rgba(22,30,52,.88);color:#E2E8F0;border:1px solid rgba(129,140,248,.2);backdrop-filter:blur(20px) saturate(1.15);box-shadow:0 28px 60px rgba(0,0,0,.45),0 0 0 1px rgba(129,140,248,.08) inset}
body.dark input,body.dark select,body.dark textarea{background:#334155;color:#E2E8F0;border-color:#475569}
body.dark .tbl th{background:#334155;color:#94A3B8}
body.dark .tbl td{border-color:#334155}
body.dark .card{border-color:#334155}
body.dark .b2-o{border-color:#475569;color:#94A3B8}
body.dark .stat-card{background:var(--card);border-color:var(--bd)}
body.dark .stat-card .num{color:#818CF8!important}
body.dark .alert-info{background:#1E3A5F;border-color:#2563EB;color:#93C5FD}
body.dark .alert-success{background:#14532D;border-color:#166534;color:#86EFAC}
body.dark .alert-warning{background:#78350F;border-color:#B45309;color:#FDE68A}
body.dark .alert-error{background:#7F1D1D;border-color:#DC2626;color:#FCA5A5}
body.dark .tbl tr:hover{background:#1E293B}
body.dark .tbl tbody tr:nth-child(even){background:#162032}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--txt)}
#app{position:relative;min-height:100vh;--bg-orb1:rgba(139,92,246,.38);--bg-orb2:rgba(34,211,238,.32);--bg-orb3:rgba(244,114,182,.26);--bg-orb4:rgba(99,102,241,.22)}
#app[data-page="dashboard"]{--bg-orb1:rgba(129,140,248,.4);--bg-orb2:rgba(168,85,247,.3);--bg-orb3:rgba(56,189,248,.24)}
#app[data-page="positions"]{--bg-orb1:rgba(34,211,238,.38);--bg-orb2:rgba(59,130,246,.3);--bg-orb3:rgba(99,102,241,.22)}
#app[data-page="resume_eval"]{--bg-orb1:rgba(52,211,153,.34);--bg-orb2:rgba(34,211,238,.26);--bg-orb3:rgba(129,140,248,.2)}
#app[data-page="models"]{--bg-orb1:rgba(192,132,252,.38);--bg-orb2:rgba(244,114,182,.28);--bg-orb3:rgba(129,140,248,.22)}
#app[data-page="smtp"]{--bg-orb1:rgba(251,146,60,.32);--bg-orb2:rgba(248,113,113,.24);--bg-orb3:rgba(250,204,21,.18)}
#app[data-page="admin"]{--bg-orb1:rgba(251,191,36,.32);--bg-orb2:rgba(249,115,22,.22);--bg-orb3:rgba(129,140,248,.18)}
#app[data-page="superadmin"]{--bg-orb1:rgba(99,102,241,.38);--bg-orb2:rgba(67,56,202,.28);--bg-orb3:rgba(168,85,247,.22)}
#app > .nav,#app > .main{position:relative;z-index:1}
.app-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.app-bg-base{position:absolute;inset:0;background:
  radial-gradient(ellipse 95% 65% at 88% 12%,rgba(167,139,250,.42),transparent 58%),
  radial-gradient(ellipse 80% 55% at 8% 88%,rgba(34,211,238,.34),transparent 54%),
  radial-gradient(ellipse 70% 50% at 52% 42%,rgba(244,114,182,.22),transparent 56%),
  radial-gradient(ellipse 60% 45% at 20% 30%,rgba(129,140,248,.2),transparent 52%),
  linear-gradient(135deg,#eef2ff 0%,#ede9fe 22%,#ecfeff 48%,#fce7f3 72%,#e0e7ff 100%);
  background-size:100% 100%,100% 100%,100% 100%,100% 100%,320% 320%;animation:appBgShift 22s ease-in-out infinite alternate}
@keyframes appBgShift{0%{background-position:0% 0%,0% 0%,0% 0%,0% 0%,0% 50%}100%{background-position:8% 6%,-6% 8%,5% -4%,-4% 5%,100% 50%}}
.app-bg-grid{position:absolute;inset:0;opacity:.55;background-image:
  linear-gradient(rgba(99,102,241,.06) 1px,transparent 1px),
  linear-gradient(90deg,rgba(99,102,241,.06) 1px,transparent 1px),
  radial-gradient(circle at 50% 50%,rgba(255,255,255,.08) 0%,transparent 70%);
  background-size:36px 36px,36px 36px,100% 100%;mask-image:radial-gradient(ellipse 85% 75% at 50% 38%,#000 18%,transparent 78%)}
.app-bg-orb{position:absolute;border-radius:50%;filter:blur(88px);opacity:1;will-change:transform;mix-blend-mode:multiply}
.app-bg-orb--1{width:min(560px,72vw);height:min(560px,72vw);background:var(--bg-orb1);top:-14%;right:-10%;animation:appOrb1 20s ease-in-out infinite alternate}
.app-bg-orb--2{width:min(480px,62vw);height:min(480px,62vw);background:var(--bg-orb2);bottom:-12%;left:-8%;animation:appOrb2 24s ease-in-out infinite alternate}
.app-bg-orb--3{width:min(400px,54vw);height:min(400px,54vw);background:var(--bg-orb3);top:36%;left:40%;animation:appOrb3 28s ease-in-out infinite alternate}
.app-bg-orb--4{width:min(320px,44vw);height:min(320px,44vw);background:var(--bg-orb4);top:8%;left:12%;animation:appOrb4 32s ease-in-out infinite alternate}
@keyframes appOrb1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-48px,36px) scale(1.12)}}
@keyframes appOrb2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(42px,-32px) scale(1.1)}}
@keyframes appOrb3{0%{transform:translate(-50%,-50%) scale(1)}100%{transform:translate(calc(-50% + 36px),calc(-50% - 28px)) scale(1.14)}}
@keyframes appOrb4{0%{transform:translate(0,0) scale(1)}100%{transform:translate(28px,40px) scale(1.08)}}
#app-bg-canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.65}
body.dark #app .app-bg-base{background:
  radial-gradient(ellipse 100% 70% at 80% 10%,rgba(124,58,237,.35),transparent 55%),
  radial-gradient(ellipse 85% 60% at 12% 90%,rgba(6,182,212,.28),transparent 52%),
  radial-gradient(ellipse 70% 50% at 50% 50%,rgba(236,72,153,.18),transparent 58%),
  linear-gradient(135deg,#050816 0%,#0f0a24 35%,#0a1628 68%,#061018 100%);
  background-size:100% 100%,100% 100%,100% 100%,280% 280%}
body.dark #app .app-bg-grid{opacity:.32;background-image:linear-gradient(rgba(129,140,248,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(129,140,248,.08) 1px,transparent 1px);background-size:40px 40px}
body.dark #app .app-bg-orb{mix-blend-mode:screen;filter:blur(96px)}
body.dark #app{--bg-orb1:rgba(124,58,237,.28);--bg-orb2:rgba(34,211,238,.22);--bg-orb3:rgba(236,72,153,.18);--bg-orb4:rgba(99,102,241,.16)}
@media(prefers-reduced-motion:reduce){
  .app-bg-base,.app-bg-orb{animation:none}
  #app-bg-canvas{display:none}
}
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background-color:#0a0a1a;background-image:
  radial-gradient(ellipse 120% 85% at 70% 15%,rgba(124,58,237,.5),transparent 52%),
  radial-gradient(ellipse 100% 70% at 25% 85%,rgba(6,182,212,.38),transparent 55%),
  radial-gradient(ellipse 85% 60% at 92% 75%,rgba(236,72,153,.32),transparent 50%),
  linear-gradient(155deg,#0f0c29 0%,#1a1442 35%,#162447 68%,#0c4a6e 100%);background-size:100% 100%,100% 100%,100% 100%,200% 200%;animation:loginAurora 20s ease-in-out infinite alternate}
@keyframes loginAurora{0%{background-position:0% 0%,0% 0%,0% 0%,0% 50%}100%{background-position:6% 4%,-5% 6%,4% -3%,100% 50%}}
.login-page::before{content:'';position:absolute;width:min(680px,90vw);height:min(680px,90vw);border-radius:50%;background:radial-gradient(circle,rgba(167,139,250,.18) 0%,transparent 68%);top:-220px;right:-140px;animation:loginGlow1 14s ease-in-out infinite alternate}
.login-page::after{content:'';position:absolute;width:min(480px,70vw);height:min(480px,70vw);border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,.14) 0%,transparent 70%);bottom:-120px;left:-120px;animation:loginGlow2 18s ease-in-out infinite alternate}
@keyframes loginGlow1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-30px,25px) scale(1.08)}}
@keyframes loginGlow2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(25px,-20px) scale(1.06)}}
.login-card{background:rgba(255,255,255,.9);border-radius:24px;padding:48px 40px;width:420px;max-width:90vw;box-shadow:0 32px 64px rgba(15,12,41,.35),0 0 0 1px rgba(255,255,255,.25) inset;backdrop-filter:blur(20px) saturate(1.2);border:1px solid rgba(255,255,255,.35);position:relative;z-index:2}
.login-error{margin:12px 0 4px;padding:10px 12px;border-radius:10px;background:#FEF2F2;border:1px solid #FECACA;color:#B91C1C;font-size:13px;line-height:1.5;text-align:center}
body.dark .login-error{background:#7F1D1D;border-color:#DC2626;color:#FCA5A5}
.login-logo{text-align:center;margin-bottom:32px}
.login-logo .icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--pri),var(--pri-l));color:#fff;font-size:28px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}
.login-logo h1{font-size:22px;color:var(--txt)}
.login-logo p{font-size:13px;color:var(--txt-l);margin-top:4px}
.login-tabs{display:flex;border-bottom:2px solid var(--bd);margin-bottom:24px}
.login-tab{flex:1;padding:12px;text-align:center;cursor:pointer;color:var(--txt-l);font-size:14px;font-weight:500;border:none;background:none;transition:.2s;position:relative}
.login-tab.active{color:var(--pri)}
.login-tab.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--pri)}
.login-form{display:none}.login-form.active{display:block}
.reg-agree-tip{font-size:12px;line-height:1.6;color:var(--txt-l);margin:0 0 10px;padding:8px 10px;background:rgba(245,158,11,.08);border-radius:8px;border-left:3px solid #F59E0B}
.reg-agree-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.6;color:var(--txt-l);margin-bottom:8px;cursor:pointer}
.reg-agree-item:last-child{margin-bottom:0}
.reg-agree-item input{margin-top:3px;flex-shrink:0;width:16px;height:16px;cursor:pointer}
.reg-agree-item a{color:var(--pri);text-decoration:underline;text-underline-offset:2px}
.legal-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;align-items:center;justify-content:center}
.legal-modal-overlay[style*="flex"]{display:flex!important}
.legal-modal-box{max-width:720px;width:94%;max-height:90vh;background:#fff;border-radius:14px;display:flex;flex-direction:column;overflow:hidden}
.legal-modal-body{padding:16px 20px;overflow:auto;font-size:12px;line-height:1.9;color:#334155;white-space:pre-wrap;flex:1;max-height:calc(90vh - 120px)}
.legal-modal-foot{padding:12px 20px 18px;border-top:1px solid #E2E8F0;text-align:center}
body.dark .legal-modal-box{background:#1E293B}
body.dark .legal-modal-body{color:#CBD5E1}
body.dark .reg-agreements{background:rgba(99,102,241,.12);border-color:rgba(129,140,248,.25)}
.ru-idle-legal{margin-top:8px;font-size:11px;color:var(--txt-l);line-height:1.5}
.ru-idle-legal a{color:var(--pri);text-decoration:underline}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--txt)}
.fg input{width:100%;padding:11px 14px;border:1px solid var(--bd);border-radius:10px;font-size:14px;outline:none;transition:.2s}
.fg input:focus{border-color:var(--pri);box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.btn{width:100%;padding:12px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:.2s}
.btn-p{background:linear-gradient(135deg,var(--pri),var(--pri-l));color:#fff}
.btn-p:hover{opacity:.9;transform:translateY(-1px)}
.btn-p:disabled{opacity:.5;cursor:not-allowed;transform:none}
.lf{text-align:center;margin-top:16px;font-size:13px;color:var(--txt-l)}
.lf a{color:var(--pri);cursor:pointer;text-decoration:none}
.lf a:hover{text-decoration:underline}
.nav{background:linear-gradient(180deg,rgba(255,255,255,.88) 0%,rgba(248,250,255,.78) 100%);backdrop-filter:blur(18px) saturate(1.15);border-bottom:1px solid rgba(255,255,255,.45);padding:0 24px 0 28px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;column-gap:20px;height:76px;box-shadow:0 8px 32px rgba(79,70,229,.1);position:sticky;top:0;z-index:100}
.nav-logo{font-size:16px;font-weight:800;color:#1E293B;display:flex;align-items:center;gap:10px;letter-spacing:-.02em;white-space:nowrap;flex-shrink:0}
.nav-logo span{background:linear-gradient(135deg,#4F46E5 0%,#7C3AED 55%,#EC4899 100%);color:#fff;width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 6px 18px rgba(79,70,229,.35)}
.nav-tabs{display:flex;gap:10px;align-items:center;justify-content:center;min-width:0;padding:0 8px;overflow-x:auto;scrollbar-width:none}.nav-tabs::-webkit-scrollbar{display:none}
.nav-sep{width:1px;min-width:1px;background:linear-gradient(180deg,transparent,#CBD5E1,transparent);margin:10px 4px;align-self:stretch;flex-shrink:0}
.nav-tab{padding:5px 12px 5px 5px;border-radius:12px;cursor:pointer;color:#475569;font-size:13px;font-weight:600;border:1px solid transparent;background:transparent;transition:all .22s ease;display:flex;align-items:center;gap:8px;min-height:42px;white-space:nowrap;flex-shrink:0}
.nav-tab .tab-icon{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:transform .22s ease,box-shadow .22s ease;box-shadow:0 4px 14px rgba(15,23,42,.12);position:relative;overflow:hidden}
.nav-tab .tab-icon::after{content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.28),transparent 55%);pointer-events:none}
.nav-tab .tab-icon svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1}
.nav-tab .tab-icon-emoji{font-size:17px;line-height:1;z-index:1}
.nav-tab .tab-icon--dashboard{background:linear-gradient(135deg,#6366F1,#8B5CF6)}
.nav-tab .tab-icon--positions{background:linear-gradient(135deg,#0EA5E9,#2563EB)}
.nav-tab .tab-icon--resume_eval{background:linear-gradient(135deg,#10B981,#059669)}
.nav-tab .tab-icon--models{background:linear-gradient(135deg,#A855F7,#EC4899)}
.nav-tab .tab-icon--smtp{background:linear-gradient(135deg,#FB923C,#EF4444)}
.nav-tab .tab-icon--superadmin{background:linear-gradient(135deg,#6366F1,#4338CA)}
.nav-tab .tab-icon--admin{background:linear-gradient(135deg,#F59E0B,#D97706)}
.nav-tab .tab-icon--analytics{background:linear-gradient(135deg,#06B6D4,#3B82F6)}
.nav-tab .tab-icon--funnel{background:linear-gradient(135deg,#8B5CF6,#6366F1)}
.nav-tab .tab-icon--profile{background:linear-gradient(135deg,#F472B6,#DB2777)}
.nav-tab .tab-name{font-size:12.5px;line-height:1.2;font-weight:700;letter-spacing:0}
.nav-tab:hover{background:#fff;border-color:#E2E8F0;box-shadow:0 4px 16px rgba(15,23,42,.06)}
.nav-tab:hover .tab-icon{transform:translateY(-2px) scale(1.04)}
.nav-tab.active{color:#fff;border-color:transparent}
.nav-tab.active .tab-icon{background:rgba(255,255,255,.22)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 4px 12px rgba(0,0,0,.12)}
.nav-tab.active.nav-tab--dashboard{background:linear-gradient(135deg,#6366F1,#8B5CF6);box-shadow:0 8px 24px rgba(99,102,241,.38)}
.nav-tab.active.nav-tab--positions{background:linear-gradient(135deg,#0EA5E9,#2563EB);box-shadow:0 8px 24px rgba(37,99,235,.35)}
.nav-tab.active.nav-tab--resume_eval{background:linear-gradient(135deg,#10B981,#059669);box-shadow:0 8px 24px rgba(5,150,105,.35)}
.nav-tab.active.nav-tab--models{background:linear-gradient(135deg,#A855F7,#EC4899);box-shadow:0 8px 24px rgba(168,85,247,.38)}
.nav-tab.active.nav-tab--smtp{background:linear-gradient(135deg,#FB923C,#EF4444);box-shadow:0 8px 24px rgba(239,68,68,.32)}
.nav-tab.active.nav-tab--superadmin{background:linear-gradient(135deg,#6366F1,#4338CA);box-shadow:0 8px 24px rgba(67,56,202,.38)}
.nav-tab.active.nav-tab--admin{background:linear-gradient(135deg,#F59E0B,#D97706);box-shadow:0 8px 24px rgba(217,119,6,.35)}
.nav-tab.active.nav-tab--analytics{background:linear-gradient(135deg,#06B6D4,#3B82F6);box-shadow:0 8px 24px rgba(59,130,246,.35)}
.nav-tab.active.nav-tab--funnel{background:linear-gradient(135deg,#8B5CF6,#6366F1);box-shadow:0 8px 24px rgba(99,102,241,.35)}
.nav-tab.active.nav-tab--profile{background:linear-gradient(135deg,#F472B6,#DB2777);box-shadow:0 8px 24px rgba(219,39,119,.35)}
.nav-user{display:flex;align-items:center;gap:12px;flex-shrink:0;padding-left:18px;border-left:1px solid #E2E8F0;min-height:44px}
.nav-user .uname{font-size:14px;font-weight:600;color:#334155}
.nav-theme-btn{width:38px;height:38px;border:none;border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#EEF2FF,#E0E7FF);color:#4F46E5;box-shadow:0 4px 12px rgba(79,70,229,.15);transition:transform .2s,box-shadow .2s}
.nav-theme-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(79,70,229,.22)}
.nav-theme-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-theme-btn .nav-theme-sun{display:none}
.nav-theme-btn.is-dark{background:linear-gradient(135deg,#312E81,#1E1B4B);color:#FDE68A}
.nav-theme-btn.is-dark .nav-theme-moon{display:none}
.nav-theme-btn.is-dark .nav-theme-sun{display:block}
.nav-user .logout{font-size:13px;font-weight:600;color:#EF4444;cursor:pointer;border:none;background:#FEF2F2;padding:8px 14px;border-radius:10px;transition:background .2s}
.nav-user .logout:hover{background:#FEE2E2}
.main{max-width:1200px;margin:0 auto;padding:24px}
.page{display:none}.page.active{display:block;animation:pageFadeIn .4s ease both}
.page .card+.card{margin-top:0}
.card{background:var(--card);border-radius:16px;padding:24px;margin-bottom:20px;box-shadow:0 8px 32px rgba(79,70,229,.08),0 0 0 1px rgba(255,255,255,.35) inset;border:1px solid var(--bd);backdrop-filter:blur(16px) saturate(1.12)}
.card-title{font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:var(--card);border-radius:16px;padding:20px;box-shadow:0 8px 32px rgba(79,70,229,.08);border:1px solid var(--bd);backdrop-filter:blur(16px) saturate(1.12);text-align:center}
.stat-card .num{font-size:32px;font-weight:800;color:var(--pri)}
.stat-card .label{font-size:13px;color:var(--txt-l);margin-top:4px}
.tbl{width:100%;border-collapse:collapse}
.tbl th,.tbl td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--bd);font-size:13px}
.tbl th{background:rgba(255,255,255,.55);font-weight:600;color:var(--txt-l);backdrop-filter:blur(8px)}
.tbl tr:hover{background:#FAFAFA}
.tbl tbody tr:nth-child(even){background:#FAFBFC}
.b2{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:.2s}
.b2-p{background:var(--pri);color:#fff}.b2-p:hover{opacity:.9}
.b2-o{background:#fff;color:var(--txt);border:1px solid var(--bd)}.b2-o:hover{background:#F8FAFC}
.badge{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600}
.bg-green{background:#D1FAE5;color:#065F46}
.bg-blue{background:#DBEAFE;color:#1E40AF}
.bg-yellow{background:#FEF3C7;color:#92400E}
.grade-badge{border-radius:50%;color:#fff;font-weight:800;display:inline-flex;align-items:center;justify-content:center}
.fg2{margin-bottom:16px}
.fg2 label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--txt)}
.fg2 input,.fg2 select,.fg2 textarea{width:100%;padding:10px 12px;border:1px solid var(--bd);border-radius:8px;font-size:14px;outline:none;transition:.2s;font-family:inherit}
.fg2 textarea{min-height:120px;resize:vertical}
.fg2 input:focus,.fg2 select:focus,.fg2 textarea:focus{border-color:var(--pri);box-shadow:0 0 0 3px rgba(79,70,229,.1)}
#toast-box{position:fixed;top:20px;right:20px;z-index:9999}
.toast{padding:12px 20px;border-radius:8px;color:#fff;font-size:14px;margin-bottom:8px;animation:si .3s;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.t-ok{background:var(--ok)}.t-err{background:var(--err)}.t-info{background:var(--pri)}
@keyframes si{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
#radar-chart{width:100%;height:400px}
@media(max-width:768px){.stats-row{grid-template-columns:repeat(2,1fr)}.login-card{padding:32px 24px}}
@keyframes fadeSlideIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ═══ 全局动态增强 ═══ */
/* 统一排版规范 */
.card-title{font-size:18px!important;font-weight:700!important;margin-bottom:16px!important;display:flex;align-items:center;gap:8px}
.card{padding:24px!important;margin-bottom:20px!important}
.b2{padding:6px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:.2s;height:36px;display:inline-flex;align-items:center;gap:4px;box-sizing:border-box}
.tbl th,.tbl td{padding:10px 14px!important;font-size:13px!important}
.fg2 input,.fg2 select{padding:8px 12px!important;border-radius:8px!important}
select,input[type=text],input[type=password],input[type=email],input[type=number],input[type=search]{padding:8px 12px;border-radius:8px;font-size:13px;border:1px solid var(--bd);transition:.2s;height:36px;box-sizing:border-box}
select:focus,input:focus{border-color:var(--pri);box-shadow:0 0 0 3px rgba(79,70,229,.1);outline:none}

/* 按钮hover浮起+阴影 */
.b2:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.12)}
.b2:active{transform:translateY(0);box-shadow:none}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(79,70,229,.3)}
.btn:active{transform:translateY(0)}

/* 卡片hover浮起 */
.card{transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,.1)}
/* 但编辑用户卡片和功能控制内嵌卡片不浮起 */
#admin-edit:hover,#perms-limits-card:hover{transform:none!important;box-shadow:0 1px 3px rgba(0,0,0,.1)!important}

/* 等级徽章弹入 */
.grade-badge{animation:badgePop .5s cubic-bezier(.34,1.56,.64,1) both}
@keyframes badgePop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}

/* 上传进度条流光 */
.upload-shimmer{position:relative;overflow:hidden}
.upload-shimmer::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.5s infinite}
@keyframes shimmer{to{left:100%}}

/* Tab页面切换动画 */
.page{display:none}
.page.active{display:block;animation:pageFadeIn .4s ease both}
@keyframes pageFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* 表格行逐行滑入 */
.tbl tbody tr{animation:rowSlide .4s ease both;transition:background .2s}
.tbl tbody tr:hover{background:#F8FAFC}
@keyframes rowSlide{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}

/* Toast增强：顶部弹入+退出缩小 */
@keyframes toastIn{from{transform:translateY(-30px) scale(.8);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
@keyframes toastOut{from{transform:scale(1);opacity:1}to{transform:scale(.7);opacity:0}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══ 全局组件统一 ═══ */
/* 统一模态弹窗 */
.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:200;align-items:center;justify-content:center}
.modal-card{background:#fff;border-radius:16px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.15)}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #E2E8F0}
.modal-body{padding:24px}
.modal-footer{padding:12px 24px;border-top:1px solid #E2E8F0;display:flex;gap:8px;justify-content:flex-end}

/* 统一提示框语义色 */
.alert{padding:12px 16px;border-radius:8px;font-size:13px;line-height:1.5;margin-bottom:12px;border:1px solid transparent}
.alert-info{background:#EFF6FF;border-color:#BFDBFE;color:#1E40AF}
.alert-success{background:#F0FDF4;border-color:#BBF7D0;color:#166534}
.alert-warning{background:#FFFBEB;border-color:#FDE68A;color:#92400E}
.alert-error{background:#FEF2F2;border-color:#FECACA;color:#991B1B}

/* 统一表格按钮 */
.tbl .b2{padding:4px 10px;font-size:12px;border-radius:6px}

/* 统一页面标题间距 */
.page>h2{margin-bottom:20px;font-size:20px;font-weight:700}

/* 统一弹窗内标题 */
.modal-card .card-title,.modal-card h2{font-size:18px!important;font-weight:700!important}
.toast{animation:toastIn .4s cubic-bezier(.34,1.56,.64,1)}
.toast.removing{animation:toastOut .3s ease both}

/* ═══ P0修复：输入框统一 ═══ */
.fg input{padding:8px 12px!important;border-radius:8px!important;height:36px!important;font-size:14px!important;box-sizing:border-box!important}
.fg2 input,.fg2 select,.fg2 textarea{padding:8px 12px!important;border-radius:8px!important;height:36px!important;font-size:14px!important;box-sizing:border-box!important}
.fg2 textarea{height:auto!important;min-height:120px}

/* ═══ P0修复：按钮统一 ═══ */
.btn{border-radius:10px!important;font-size:15px;font-weight:600;height:auto}
/* 大主按钮 */
.btn-lg{padding:12px 24px!important;font-size:15px!important;border-radius:10px!important}
/* 标准主按钮 */
.b2.b2-p{padding:8px 20px!important;font-size:14px!important;border-radius:8px}

/* ═══ P0修复：KPI卡片统一 ═══ */
.stat-card{padding:20px!important}
.stat-card .num{font-size:36px!important;font-weight:800!important}
.stat-card .label{font-size:13px!important}

/* ═══ P0修复：模态弹窗圆角统一 ═══ */
/* 所有inline style模态弹窗统一圆角 */
[id$="-modal"][style*="border-radius"],
[id$="-modal"]{border-radius:16px!important}
/* 打印/对比/评估弹窗也是16px */
#print-area,#compare-modal,#eval-modal-wrap{border-radius:16px!important}

/* ═══ P0修复：页面标题统一 ═══ */
.page>h2{font-size:20px!important;font-weight:700!important;margin-bottom:20px!important;padding-bottom:12px;border-bottom:2px solid var(--bd)}

/* ═══ 分析与评估 — 子 Tab 胶囊导航 ═══ */
#page-resume_eval .eval-page-head{margin-bottom:14px}
#page-resume_eval .eval-page-title{display:flex;align-items:center;gap:12px;margin:0!important;padding-bottom:0!important;border-bottom:none!important;font-size:22px!important;font-weight:800!important;color:#0F172A;letter-spacing:-.02em}
.eval-page-icon{width:42px;height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,#10B981,#059669);box-shadow:0 6px 20px rgba(5,150,105,.28);position:relative;overflow:hidden;flex-shrink:0}
.eval-page-icon::after{content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.3),transparent 55%);pointer-events:none}
.eval-page-icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1}
.eval-subnav{display:flex;gap:8px;align-items:center;padding:8px;margin-bottom:22px;background:linear-gradient(135deg,rgba(248,250,252,.96),rgba(238,242,255,.92));border:1px solid rgba(226,232,240,.92);border-radius:18px;box-shadow:0 4px 24px rgba(15,23,42,.05),inset 0 1px 0 rgba(255,255,255,.85);flex-wrap:wrap;overflow-x:auto;scrollbar-width:none}
.eval-subnav::-webkit-scrollbar{display:none}
.eval-sub-tab{display:inline-flex;align-items:center;gap:8px;padding:6px 16px 6px 6px;border:1px solid transparent;border-radius:14px;background:transparent;cursor:pointer;color:#64748B;font-size:13px;font-weight:700;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;flex-shrink:0;font-family:inherit}
.eval-sub-tab:hover{background:rgba(255,255,255,.88);border-color:#E2E8F0;color:#334155;box-shadow:0 4px 14px rgba(15,23,42,.06);transform:translateY(-1px)}
.eval-sub-tab.active{color:#fff;border-color:transparent;transform:translateY(-1px)}
.eval-sub-icon{width:32px;height:32px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(15,23,42,.14);position:relative;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}
.eval-sub-icon::after{content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.28),transparent 55%);pointer-events:none}
.eval-sub-icon svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1}
.eval-sub-icon--resumes{background:linear-gradient(135deg,#10B981,#059669)}
.eval-sub-icon--results{background:linear-gradient(135deg,#6366F1,#4F46E5)}
.eval-sub-icon--funnel{background:linear-gradient(135deg,#8B5CF6,#6366F1)}
.eval-sub-icon--analytics{background:linear-gradient(135deg,#06B6D4,#3B82F6)}
.eval-sub-tab:hover .eval-sub-icon{transform:translateY(-1px) scale(1.04)}
.eval-sub-tab.active .eval-sub-icon{background:rgba(255,255,255,.22)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 4px 10px rgba(0,0,0,.12)}
.eval-sub-tab--resumes.active{background:linear-gradient(135deg,#10B981,#059669);box-shadow:0 8px 22px rgba(5,150,105,.35)}
.eval-sub-tab--results.active{background:linear-gradient(135deg,#6366F1,#4F46E5);box-shadow:0 8px 22px rgba(79,70,229,.35)}
.eval-sub-tab--funnel.active{background:linear-gradient(135deg,#8B5CF6,#6366F1);box-shadow:0 8px 22px rgba(99,102,241,.35)}
.eval-sub-tab--analytics.active{background:linear-gradient(135deg,#06B6D4,#3B82F6);box-shadow:0 8px 22px rgba(59,130,246,.35)}
.eval-sub-name{line-height:1.2}
@media(max-width:620px){
  .eval-sub-tab .eval-sub-name{display:none}
  .eval-sub-tab{padding:6px}
  .eval-sub-icon{width:36px;height:36px}
  .eval-sub-icon svg{width:18px;height:18px}
}

/* ═══ 招聘漏斗看板 — 图标与布局 ═══ */
.fnl-icon{display:inline-flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;position:relative;overflow:hidden;box-shadow:0 4px 14px rgba(15,23,42,.14)}
.fnl-icon::after{content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.3),transparent 55%);pointer-events:none}
.fnl-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1;padding:22%}
.fnl-icon--xs{width:22px;height:22px;border-radius:7px}
.fnl-icon--sm{width:28px;height:28px;border-radius:8px}
.fnl-icon--md{width:36px;height:36px;border-radius:10px}
.fnl-icon--lg{width:42px;height:42px;border-radius:12px;box-shadow:0 6px 20px rgba(99,102,241,.28)}
.fnl-icon--pipe{width:44px;height:44px;border-radius:50%;box-shadow:0 6px 18px rgba(15,23,42,.16)}
.fnl-icon--stat{width:40px;height:40px;border-radius:12px}
.fnl-icon--head{width:32px;height:32px;border-radius:10px}
.fnl-icon--btn{width:22px;height:22px;border-radius:6px;box-shadow:0 2px 8px rgba(15,23,42,.12);vertical-align:-5px;margin-right:6px}
.fnl-grad--applied{background:linear-gradient(135deg,#64748B,#475569)}
.fnl-grad--screened{background:linear-gradient(135deg,#3B82F6,#2563EB)}
.fnl-grad--interview{background:linear-gradient(135deg,#F59E0B,#D97706)}
.fnl-grad--offer{background:linear-gradient(135deg,#8B5CF6,#6366F1)}
.fnl-grad--hired{background:linear-gradient(135deg,#EC4899,#DB2777)}
.fnl-grad--rejected{background:linear-gradient(135deg,#EF4444,#DC2626)}
.fnl-grad--stat_total{background:linear-gradient(135deg,#6366F1,#4F46E5)}
.fnl-grad--stat_active{background:linear-gradient(135deg,#3B82F6,#0EA5E9)}
.fnl-grad--stat_hired{background:linear-gradient(135deg,#EC4899,#F472B6)}
.fnl-grad--stat_rejected{background:linear-gradient(135deg,#EF4444,#F97316)}
.fnl-grad--stat_rate{background:linear-gradient(135deg,#10B981,#059669)}
.fnl-grad--funnel{background:linear-gradient(135deg,#8B5CF6,#6366F1)}
.fnl-grad--list{background:linear-gradient(135deg,#64748B,#475569)}
.fnl-grad--board{background:linear-gradient(135deg,#6366F1,#8B5CF6)}
.fnl-grad--refresh{background:linear-gradient(135deg,#06B6D4,#3B82F6)}
.fnl-board-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.fnl-board-title{display:flex;align-items:center;gap:12px;margin:0;font-size:18px;font-weight:800;color:#0F172A;letter-spacing:-.02em}
.fnl-board-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.fnl-filter-select{padding:6px 10px;border:1px solid var(--bd);border-radius:8px;font-size:13px;background:var(--card)}
.fnl-tool-btn{display:inline-flex!important;align-items:center;font-size:13px!important;padding:6px 12px!important}
.fnl-stats{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.fnl-stat{background:var(--card);border-radius:14px;padding:12px 14px;border:1px solid var(--bd);display:flex;align-items:center;gap:12px;min-width:130px;transition:transform .2s,box-shadow .2s}
.fnl-stat:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(15,23,42,.08)}
.fnl-stat-val{font-size:22px;font-weight:800;line-height:1.1}
.fnl-stat-lbl{font-size:12px;color:var(--txt-l);margin-top:2px}
.fnl-pipeline{background:var(--card);border-radius:16px;padding:22px 16px;border:1px solid var(--bd);margin-bottom:20px;box-shadow:0 4px 20px rgba(15,23,42,.04)}
.fnl-pipe-row{display:flex;align-items:flex-start;justify-content:center;max-width:780px;margin:0 auto}
.fnl-pipe-step{width:92px;text-align:center;flex-shrink:0}
.fnl-pipe-step--dim .fnl-icon--pipe{opacity:.45;box-shadow:none}
.fnl-pipe-step--dim .fnl-pipe-label,.fnl-pipe-step--dim .fnl-pipe-num{color:var(--txt-l)!important}
.fnl-pipe-node{position:relative;display:inline-block;margin-bottom:6px}
.fnl-pipe-ring{position:absolute;inset:-4px;border-radius:50%;border:2px solid transparent;pointer-events:none;transition:border-color .25s}
.fnl-pipe-step:not(.fnl-pipe-step--dim) .fnl-pipe-ring{border-color:currentColor;opacity:.25}
.fnl-pipe-label{font-size:12px;font-weight:700;margin-bottom:2px}
.fnl-pipe-num{font-size:18px;font-weight:800;margin:1px 0}
.fnl-pipe-pct{font-size:10px;color:var(--txt-l)}
.fnl-pipe-conn{width:26px;display:flex;align-items:center;padding-top:18px;flex-shrink:0}
.fnl-pipe-arrow{display:block;width:100%;height:2px;background:linear-gradient(90deg,#CBD5E1,#94A3B8);position:relative;border-radius:1px}
.fnl-pipe-arrow::after{content:'';position:absolute;right:-1px;top:-4px;border:5px solid transparent;border-left-color:#94A3B8}
.fnl-stage{margin-bottom:16px}
.fnl-stage-head{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:2px solid transparent;margin-bottom:10px}
.fnl-stage-head strong{font-size:15px}
.fnl-stage-badge{color:#fff;padding:3px 11px;border-radius:12px;font-size:12px;font-weight:700}
.fnl-cand-row{background:var(--card);border-radius:10px;padding:10px 16px;border:1px solid var(--bd);cursor:pointer;display:flex;align-items:center;gap:16px;transition:box-shadow .15s,transform .15s}
.fnl-cand-row:hover{box-shadow:0 4px 14px rgba(15,23,42,.08);transform:translateX(2px)}
.fnl-cand-empty{text-align:center;padding:14px;color:var(--txt-l);font-size:13px;opacity:.5}
body.dark .fnl-board-title{color:#F1F5F9}
body.dark .fnl-pipeline,body.dark .fnl-stat{box-shadow:0 4px 20px rgba(0,0,0,.2)}

/* ═══ 岗位管理页 ═══ */
#page-positions .pos-page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
#page-positions .pos-page-intro{flex:1;min-width:200px}
#page-positions .pos-page-title{display:flex;align-items:center;gap:12px;margin:0!important;padding-bottom:0!important;border-bottom:none!important;font-size:22px!important;font-weight:800!important;color:#0F172A;letter-spacing:-.02em}
.pos-page-icon,.pos-icon{display:inline-flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;position:relative;overflow:hidden;box-shadow:0 4px 14px rgba(15,23,42,.14)}
.pos-page-icon::after,.pos-icon::after{content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.3),transparent 55%);pointer-events:none}
.pos-page-icon svg,.pos-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1;padding:22%}
.pos-page-icon{width:42px;height:42px;border-radius:12px}
.pos-page-icon--positions,.pos-grad--positions{background:linear-gradient(135deg,#0EA5E9,#2563EB);box-shadow:0 6px 20px rgba(37,99,235,.28)}
.pos-icon--md{width:36px;height:36px;border-radius:10px}
.pos-icon--row{width:34px;height:34px;border-radius:10px}
.pos-icon--sm{width:28px;height:28px;border-radius:8px}
.pos-grad--ai{background:linear-gradient(135deg,#6366F1,#8B5CF6)}
.pos-grad--job{background:linear-gradient(135deg,#0EA5E9,#3B82F6)}
.pos-grad--download,.pos-grad--export{background:linear-gradient(135deg,#64748B,#475569)}
.pos-grad--import{background:linear-gradient(135deg,#10B981,#059669)}
.pos-grad--template{background:linear-gradient(135deg,#8B5CF6,#6366F1)}
.pos-ai-btn{display:inline-flex;align-items:center;gap:12px;padding:14px 28px 14px 16px;border:1px solid rgba(99,102,241,.35);border-radius:16px;cursor:pointer;
  background:linear-gradient(135deg,#EEF2FF 0%,#fff 55%,#F5F3FF 100%);color:#4338CA;font-size:16px;font-weight:800;font-family:inherit;
  box-shadow:0 8px 28px rgba(99,102,241,.18),inset 0 1px 0 rgba(255,255,255,.95);transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;overflow:hidden;flex-shrink:0}
.pos-ai-btn-glow{position:absolute;inset:-50%;background:conic-gradient(from 180deg,#6366F1,#8B5CF6,#06B6D4,#6366F1);opacity:.1;animation:posAiSpin 8s linear infinite;pointer-events:none}
@keyframes posAiSpin{to{transform:rotate(360deg)}}
.pos-ai-btn:hover{transform:translateY(-3px);border-color:rgba(99,102,241,.5);box-shadow:0 14px 36px rgba(99,102,241,.28),inset 0 1px 0 rgba(255,255,255,1)}
.pos-ai-btn-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1;
  background:linear-gradient(135deg,#6366F1,#8B5CF6);box-shadow:0 6px 18px rgba(99,102,241,.4)}
.pos-ai-btn-icon svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pos-ai-btn-label{position:relative;z-index:1;letter-spacing:.02em;white-space:nowrap}
.pos-list-card{overflow:hidden;background:#fff;border:1px solid #E8EDF5;box-shadow:0 2px 16px rgba(15,23,42,.04)}
.pos-list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap;padding-bottom:14px;border-bottom:1px solid #F1F5F9}
.pos-list-title{font-size:15px;font-weight:800;color:#1E293B;letter-spacing:-.01em}
.pos-tool-group{display:flex;flex-wrap:wrap;gap:8px}
.pos-tool-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:1px solid transparent;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}
.pos-tool-btn--label{position:relative}
.pos-tool-btn--download{color:#475569;background:#F1F5F9;border-color:#E2E8F0}
.pos-tool-btn--download:hover{color:#334155;background:#E2E8F0;border-color:#CBD5E1}
.pos-tool-btn--import{color:#047857;background:#ECFDF5;border-color:#BBF7D0}
.pos-tool-btn--import:hover{color:#065F46;background:#D1FAE5;border-color:#86EFAC}
.pos-tool-btn--export{color:#1D4ED8;background:#EFF6FF;border-color:#BFDBFE}
.pos-tool-btn--export:hover{color:#1E40AF;background:#DBEAFE;border-color:#93C5FD}
.pos-tool-btn--template{color:#6D28D9;background:#F5F3FF;border-color:#DDD6FE}
.pos-tool-btn--template:hover{color:#5B21B6;background:#EDE9FE;border-color:#C4B5FD}
.pos-table-wrap{border-radius:0;overflow:hidden;background:transparent}
#page-positions .pos-table{margin:0}
#page-positions .pos-table thead th{font-size:11px;font-weight:700;color:#94A3B8;letter-spacing:.06em;text-transform:uppercase;padding:0 18px 12px;border-bottom:none;background:transparent}
#page-positions .pos-table tbody tr.pos-row{border-bottom:1px solid #F1F5F9;animation:posRowIn .45s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--i)*.04s);transition:background .2s}
@keyframes posRowIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
#page-positions .pos-table tbody tr.pos-row:hover{background:#FAFBFF}
#page-positions .pos-table tbody tr.pos-row:last-child{border-bottom:none}
#page-positions .pos-table tbody td{padding:18px 18px;vertical-align:middle;font-size:13px}
.pos-td-title{min-width:120px}
.pos-title-text{display:block;font-size:14px;font-weight:700;color:#1E293B;line-height:1.45}
.pos-exp{display:block;margin-top:5px;font-size:11px;font-weight:500;color:#94A3B8;line-height:1.3}
.pos-lv{display:inline-block;padding:5px 12px;font-size:11px;font-weight:700;border-radius:999px;letter-spacing:.02em;white-space:nowrap}
.pos-lv--junior{background:linear-gradient(135deg,#ECFDF5,#D1FAE5);color:#047857;border:1px solid rgba(16,185,129,.2)}
.pos-lv--mid{background:linear-gradient(135deg,#EFF6FF,#DBEAFE);color:#1D4ED8;border:1px solid rgba(59,130,246,.2)}
.pos-lv--senior{background:linear-gradient(135deg,#FFFBEB,#FEF3C7);color:#B45309;border:1px solid rgba(245,158,11,.25)}
.pos-lv--expert{background:linear-gradient(135deg,#FEF2F2,#FECACA);color:#DC2626;border:1px solid rgba(239,68,68,.2)}
.pos-lv--default,.pos-lv--none{background:#F8FAFC;color:#94A3B8;border:1px solid #E2E8F0}
.pos-jd-snippet{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:#64748B;font-size:12px;line-height:1.65;max-width:300px}
.pos-jd-trigger{cursor:help;border-bottom:1px dashed rgba(99,102,241,.35);transition:color .2s,background .2s;border-radius:4px;padding:0 2px}
.pos-jd-trigger:hover{color:#4338CA;background:rgba(99,102,241,.06)}
.pos-jd-empty{color:#CBD5E1;font-size:12px}
.pos-jd-tooltip{position:fixed;z-index:10050;min-width:300px;max-width:min(460px,92vw);border-radius:14px;overflow:hidden;pointer-events:none;
  background:linear-gradient(145deg,#1E1B4B 0%,#312E81 42%,#1E293B 100%);border:1px solid rgba(129,140,248,.4);
  box-shadow:0 24px 56px rgba(15,23,42,.42),0 0 0 1px rgba(255,255,255,.06) inset,0 0 40px rgba(99,102,241,.15)}
.pos-jd-tooltip-head{padding:10px 14px;font-size:12px;font-weight:800;color:#E0E7FF;letter-spacing:.02em;
  background:linear-gradient(90deg,rgba(99,102,241,.35),rgba(6,182,212,.2));border-bottom:1px solid rgba(129,140,248,.25)}
.pos-jd-tooltip-head::before{content:'岗位要求 · ';color:#A5B4FC;font-weight:700}
.pos-jd-tooltip-body{padding:14px 16px;font-size:12px;line-height:1.8;color:#E2E8F0;white-space:pre-wrap;word-break:break-word;
  overflow-y:auto;max-height:min(320px,55vh);background:rgba(15,23,42,.25)}
.pos-jd-tooltip-body::-webkit-scrollbar{width:6px}
.pos-jd-tooltip-body::-webkit-scrollbar-thumb{background:rgba(129,140,248,.45);border-radius:999px}
#page-positions .pos-td-jd{overflow:visible}
.pos-table-wrap{overflow:visible}
.pos-list-card{overflow:visible}
.pos-td-date{font-size:12px;color:#94A3B8;white-space:nowrap}
.pos-td-actions{display:flex;gap:8px;flex-wrap:nowrap}
.pos-act{padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:transparent;transition:color .2s,background .2s;font-family:inherit;white-space:nowrap}
.pos-act--edit{color:#4F46E5}
.pos-act--edit:hover{color:#4338CA;background:#EEF2FF}
.pos-act--del{color:#94A3B8}
.pos-act--del:hover{color:#DC2626;background:#FEF2F2}
.pos-empty{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}
.pos-empty-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#EEF2FF,#E0E7FF);display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:#6366F1}
.pos-empty-icon svg{width:28px;height:28px;stroke:currentColor;fill:none;stroke-width:2}
.pos-empty-title{font-size:15px;font-weight:700;color:#475569;margin-bottom:6px}
.pos-empty-desc{font-size:13px;color:#94A3B8;margin-bottom:14px}
.pos-empty-btn{padding:8px 18px;border:none;border-radius:10px;background:linear-gradient(135deg,#6366F1,#4F46E5);color:#fff;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 6px 18px rgba(79,70,229,.3)}
.pos-empty-btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(79,70,229,.38)}
body.dark #page-positions .pos-page-title{color:#F1F5F9}
body.dark .pos-list-card{background:linear-gradient(180deg,#1E293B,#0F172A);border-color:#334155}
body.dark #page-positions .pos-table thead{background:linear-gradient(135deg,#1E293B,#334155)}
body.dark #page-positions .pos-table tbody tr.pos-row:hover{background:linear-gradient(90deg,#1E293B,#312E81)}
/* ═══ 简历上传区 — 炫酷双状态 ═══ */
.ru-card{overflow:hidden}
.ru-card-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.ru-card-icon{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#fff;box-shadow:0 4px 14px rgba(99,102,241,.3)}
.ru-card-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ru-card-title{font-size:16px;font-weight:800;color:#1E293B}
.ru-zone{position:relative;border-radius:18px;border:2px dashed rgba(99,102,241,.28);background:linear-gradient(145deg,#FAFBFF,#F5F3FF 50%,#ECFEFF);overflow:hidden;transition:border-color .25s,box-shadow .25s,background .25s;min-height:200px;display:flex;flex-direction:column}
.ru-zone--drag{border-color:#6366F1;background:linear-gradient(145deg,#EEF2FF,#E0E7FF);box-shadow:0 0 0 4px rgba(99,102,241,.12),0 12px 32px rgba(99,102,241,.15)}
.ru-zone--filled{border-color:rgba(99,102,241,.38);background:linear-gradient(180deg,#fff,#FAFBFF);box-shadow:0 8px 28px rgba(99,102,241,.08)}
.ru-zone:not(.ru-zone--filled) .ru-selected{display:none!important}
.ru-zone.ru-zone--filled .ru-idle{display:none!important}
.ru-zone--busy{border-color:rgba(99,102,241,.45);pointer-events:none}
.ru-zone--busy .ru-file-item{opacity:.85}
.ru-idle{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;cursor:pointer;position:relative;min-height:200px;flex:1}
.ru-idle-aurora{position:absolute;inset:-30%;background:conic-gradient(from 200deg,rgba(99,102,241,.08),rgba(6,182,212,.06),rgba(139,92,246,.08),rgba(99,102,241,.08));animation:ruAurora 14s linear infinite;pointer-events:none}
@keyframes ruAurora{to{transform:rotate(360deg)}}
.ru-idle-ring{position:absolute;width:120px;height:120px;border-radius:50%;border:1px solid rgba(99,102,241,.15);animation:ruRing 3s ease-in-out infinite;pointer-events:none}
@keyframes ruRing{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.12);opacity:.2}}
.ru-idle-icon{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#fff;box-shadow:0 10px 28px rgba(99,102,241,.35);position:relative;z-index:1;margin-bottom:16px}
.ru-idle-icon svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ru-idle-title{font-size:15px;font-weight:800;color:#1E293B;position:relative;z-index:1;margin-bottom:6px}
.ru-idle-hint{font-size:12px;color:#64748B;position:relative;z-index:1;margin-bottom:14px}
.ru-idle-tags{display:flex;gap:8px;position:relative;z-index:1}
.ru-idle-tags span{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.85);color:#6366F1;border:1px solid rgba(99,102,241,.18)}
.ru-selected{display:flex;flex-direction:column;flex:1;min-height:200px;padding:18px 18px 16px}
.ru-selected-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-shrink:0}
.ru-selected-meta{display:flex;align-items:center;gap:8px}
.ru-selected-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border-radius:10px;background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#fff;font-size:14px;font-weight:800;box-shadow:0 4px 12px rgba(99,102,241,.3)}
.ru-selected-label{font-size:13px;font-weight:700;color:#475569}
.ru-text-btn{border:none;background:transparent;color:#6366F1;font-size:12px;font-weight:700;cursor:pointer;padding:6px 10px;border-radius:8px;transition:background .2s}
.ru-text-btn:hover{background:#EEF2FF}
.ru-file-list{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;max-height:280px;overflow-y:auto;margin-bottom:12px}
.ru-selected-foot{flex-shrink:0;margin-top:auto}
.ru-file-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid #E8EDF5;background:#fff;animation:ruFileIn .4s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--i)*.05s)}
@keyframes ruFileIn{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:none}}
.ru-file-icon{width:36px;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.ru-file-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
.ru-file-icon--pdf{background:linear-gradient(135deg,#EF4444,#DC2626)}
.ru-file-icon--doc{background:linear-gradient(135deg,#3B82F6,#2563EB)}
.ru-file-icon--txt{background:linear-gradient(135deg,#64748B,#475569)}
.ru-file-info{min-width:0;flex:1}
.ru-file-name{display:block;font-size:13px;font-weight:700;color:#1E293B;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ru-file-size{display:block;font-size:11px;color:#94A3B8;margin-top:2px}
.ru-upload-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 20px;border:none;border-radius:14px;cursor:pointer;font-size:15px;font-weight:800;color:#fff;font-family:inherit;
  background:linear-gradient(135deg,#6366F1 0%,#8B5CF6 50%,#06B6D4 100%);background-size:200% 200%;box-shadow:0 10px 28px rgba(99,102,241,.35);transition:transform .25s,box-shadow .25s;animation:ruBtnGlow 4s ease infinite alternate}
@keyframes ruBtnGlow{0%{background-position:0% 50%}100%{background-position:100% 50%}}
.ru-upload-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 36px rgba(99,102,241,.42)}
.ru-upload-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}
.ru-upload-btn-icon{width:28px;height:28px;border-radius:8px;background:rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center}
.ru-upload-btn-icon svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.ru-progress{margin-top:16px;padding:14px 16px;border-radius:14px;background:linear-gradient(135deg,#F8FAFC,#EEF2FF);border:1px solid #E2E8F0}
.ru-progress-text{margin-bottom:8px;font-size:13px;font-weight:700;color:#1E293B;text-align:center}
.ru-progress-bar{display:flex;border-radius:10px;overflow:hidden;height:10px;background:#E2E8F0}
.ru-progress-seg{height:100%;border-right:2px solid #fff}
.ru-progress-seg--1{flex:10;background:#FEF3C7}
.ru-progress-seg--2{flex:60;background:#FFEDD5}
.ru-progress-seg--3{flex:30;background:#FEE2E2;border-right:none}
.ru-progress-fill{height:100%;width:0%;transition:width .35s cubic-bezier(.4,0,.2,1)}
.ru-progress-seg--1 .ru-progress-fill{background:linear-gradient(90deg,#FCD34D,#F59E0B)}
.ru-progress-seg--2 .ru-progress-fill{background:linear-gradient(90deg,#FDBA74,#F97316)}
.ru-progress-seg--3 .ru-progress-fill{background:linear-gradient(90deg,#FCA5A5,#EF4444)}
.ru-progress-labels{display:flex;margin-top:8px;font-size:11px;font-weight:600;color:#64748B}
.ru-progress-labels span{flex:10;text-align:center}
.ru-progress-labels span:nth-child(2){flex:60}
.ru-progress-labels span:nth-child(3){flex:30}
@media(prefers-reduced-motion:reduce){.ru-idle-aurora,.ru-idle-ring,.ru-upload-btn{animation:none}}

/* ═══ 评估结果 — 操作按钮 ═══ */
.res-act-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:none;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:transform .2s,box-shadow .2s,filter .2s;position:relative;overflow:hidden}
.res-act-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.22),transparent 55%);pointer-events:none}
.res-act-btn:hover{transform:translateY(-2px);filter:brightness(1.05)}
.res-act-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}
.res-act-icon svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.res-act-label{position:relative;z-index:1;line-height:1}
.res-act-btn--report{color:#fff;background:linear-gradient(135deg,#6366F1 0%,#4F46E5 45%,#06B6D4 100%);background-size:180% 180%;box-shadow:0 4px 16px rgba(99,102,241,.38);animation:resActGlow 5s ease infinite alternate}
@keyframes resActGlow{0%{background-position:0% 50%}100%{background-position:100% 50%}}
.res-act-btn--rec.res-act-btn--view{color:#fff;background:linear-gradient(135deg,#7C3AED,#6366F1);box-shadow:0 4px 14px rgba(124,58,237,.32)}
.res-act-btn--rec.res-act-btn--gen{color:#5B21B6;background:linear-gradient(135deg,#F5F3FF,#EDE9FE);border:1px solid #C4B5FD;box-shadow:0 2px 10px rgba(124,58,237,.12)}
.res-act-btn--int.res-act-btn--view{color:#fff;background:linear-gradient(135deg,#059669,#10B981);box-shadow:0 4px 14px rgba(5,150,105,.32)}
.res-act-btn--int.res-act-btn--gen{color:#047857;background:linear-gradient(135deg,#ECFDF5,#D1FAE5);border:1px solid #6EE7B7;box-shadow:0 2px 10px rgba(16,185,129,.12)}
.res-act-btn--gen .res-act-icon svg{stroke-width:2.2}
@media(prefers-reduced-motion:reduce){.res-act-btn--report{animation:none}}
@media(max-width:640px){
  #page-positions .pos-page-head{flex-direction:column;align-items:stretch}
  #page-positions .pos-ai-btn{width:100%;justify-content:center}
  #page-positions .pos-table tbody td{padding:14px 12px}
  #page-positions .pos-table thead th:nth-child(4),#page-positions .pos-table tbody td.pos-td-jd{display:none}
}

/* ═══ P2修复：筛选栏统一高度 ═══ */
/* 简历评估页筛选栏所有控件统一36px */
#page-resume_eval select,
#page-resume_eval input[type=text],
#page-resume_eval input[type=search]{height:36px;padding:6px 12px;font-size:13px;box-sizing:border-box}

/* ═══ P2修复：用户管理Tab按钮统一 ═══ */
#page-admin .card button[onclick*="showLevelPerms"],
#page-admin .card button[onclick*="showUsageLimits"]{padding:8px 16px!important;font-size:13px!important;height:36px!important;box-sizing:border-box!important}

/* ═══ P3修复：表格行动画限制行数避免卡顿 ═══ */
.tbl tbody tr:nth-child(n+50){animation:none}

/* ═══ P1修复：更多深色模式覆盖 ═══ */
/* 深色模式：输入框和表格已有覆盖，补充更多 */
body.dark .nav{background:linear-gradient(180deg,rgba(22,30,52,.88) 0%,rgba(11,16,32,.82) 100%);backdrop-filter:blur(18px) saturate(1.1);border-color:var(--bd);box-shadow:0 8px 32px rgba(0,0,0,.35)}
body.dark .nav-logo{color:#E2E8F0}
body.dark .nav-tab{color:#94A3B8}
body.dark .nav-tab:hover{background:#334155;border-color:#475569}
body.dark .nav-tab.active .tab-icon{background:rgba(255,255,255,.18)!important}
body.dark .nav-user{border-left-color:#334155}
body.dark .nav-user .uname{color:#E2E8F0}
body.dark .nav-user .logout{background:#3f1d1d;color:#FCA5A5}
body.dark .nav-user .logout:hover{background:#4c2020}
body.dark #page-resume_eval .eval-page-title{color:#F1F5F9}
body.dark .eval-subnav{background:linear-gradient(135deg,rgba(30,41,59,.92),rgba(15,23,42,.88));border-color:#334155;box-shadow:0 4px 24px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.04)}
body.dark .eval-sub-tab{color:#94A3B8}
body.dark .eval-sub-tab:hover{background:#334155;border-color:#475569;color:#E2E8F0}
@media(max-width:1180px){
  .nav{column-gap:12px;padding:0 16px 0 20px}
  .nav-logo{font-size:15px}
  .nav-logo span{width:32px;height:32px;font-size:13px}
  .nav-tabs{gap:8px;justify-content:flex-start;padding:0 4px}
  .nav-tab .tab-name{display:none}
  .nav-tab{padding:5px}
  .nav-tab .tab-icon{width:36px;height:36px}
}
@media(max-width:720px){
  .nav{height:68px;grid-template-columns:auto 1fr auto;column-gap:8px}
  .nav-logo span+span{display:none}
  .nav-user .uname{max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}
body.dark .page>h2{border-color:#334155}
body.dark .modal-card{background:#1E293B}
body.dark .modal-header{border-color:#334155}
body.dark .modal-footer{border-color:#334155}
body.dark .toast{box-shadow:0 4px 16px rgba(0,0,0,.4)}
body.dark .grade-badge{box-shadow:0 0 8px rgba(0,0,0,.3)}
/* 深色模式：提示框背景修复 */
body.dark [style*="background:#F0F9FF"],body.dark [style*="background:#F8FAFC"],body.dark [style*="background:#FFF7ED"]{background:#162032!important;border-color:#334155!important}
/* 深色模式：stat卡片hover */
body.dark .stat-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.3)}
/* 深色模式：badge */
body.dark .bg-green{background:#065F46;color:#D1FAE5}
body.dark .bg-blue{background:#1E40AF;color:#DBEAFE}
body.dark .bg-yellow{background:#92400E;color:#FEF3C7}

/* ═══ 全局卡片hover修正：列表卡片不浮起 ═══ */
/* 人才库卡片、权限树节点、功能控制卡片都不浮起 */
#talent-card .card:hover,
#talent-grid>div:hover,
[data-sub="admin_level_perms"] .card:hover{transform:none!important;box-shadow:0 1px 3px rgba(0,0,0,.1)!important}

/* 首页方案 A */
#page-dashboard>h2{display:none}
#page-dashboard .dash-hero{position:relative;border-radius:16px;padding:22px 24px 16px;margin-bottom:18px;background:linear-gradient(135deg,#EEF2FF 0%,#F8FAFC 55%,#ECFDF5 100%);border:1px solid rgba(79,70,229,.12);overflow:hidden}
#page-dashboard .dash-hero-glow{position:absolute;top:-40%;right:-10%;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(79,70,229,.18) 0%,transparent 70%);pointer-events:none}
#page-dashboard .dash-hero-inner{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;position:relative;z-index:1}
#page-dashboard .dash-hero-greeting{font-size:13px;color:#6366F1;font-weight:600;margin-bottom:4px}
#page-dashboard .dash-hero-title{font-size:24px;font-weight:800;color:#1E293B;letter-spacing:-.02em}
#page-dashboard .dash-hero-sub{font-size:13px;color:#64748B;margin-top:8px;max-width:520px;line-height:1.5}
#page-dashboard .dash-hero-metric{text-align:right;min-width:120px}
#page-dashboard .dash-hero-metric-label{font-size:12px;color:#64748B;font-weight:500}
#page-dashboard .dash-hero-metric-val{font-size:40px;font-weight:800;line-height:1.1;background:linear-gradient(135deg,#4F46E5,#7C3AED);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
#page-dashboard .dash-hero-metric-hint{font-size:12px;color:#94A3B8;margin-top:4px}
#page-dashboard .dash-hero-metric-hint.up{color:#059669}
#page-dashboard .dash-hero-metric-hint.down{color:#DC2626}
#page-dashboard .dash-hero-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:14px;position:relative;z-index:1}
#page-dashboard .dash-live{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#64748B}
#page-dashboard .dash-live-dot{width:8px;height:8px;border-radius:50%;background:#10B981;box-shadow:0 0 0 0 rgba(16,185,129,.5);animation:dashPulse 2s infinite}
@keyframes dashPulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.45)}70%{box-shadow:0 0 0 8px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}
#page-dashboard .dash-toolbar-select,#page-dashboard .dash-toolbar-btn{font-size:12px!important;height:32px!important;padding:4px 10px!important}
#page-dashboard .dash-more{position:relative}
#page-dashboard .dash-more summary{list-style:none;cursor:pointer}
#page-dashboard .dash-more summary::-webkit-details-marker{display:none}
#page-dashboard .dash-more-panel{position:absolute;right:0;top:calc(100% + 6px);z-index:20;min-width:200px;padding:12px;background:#fff;border:1px solid #E2E8F0;border-radius:10px;box-shadow:0 10px 30px rgba(15,23,42,.12);display:grid;gap:8px}
#page-dashboard .dash-more-label{font-size:12px;color:#64748B}
#page-dashboard .dash-customize-panel{background:#F8FAFC;border:1px solid #E2E8F0;border-radius:10px;padding:16px;margin-bottom:16px}
#page-dashboard .dash-customize-title{font-size:13px;font-weight:600;margin-bottom:10px}
#page-dashboard .dash-toggle-list{display:flex;flex-wrap:wrap;gap:8px}
#page-dashboard .dash-section-label{font-size:12px;font-weight:700;color:#94A3B8;letter-spacing:.08em;text-transform:uppercase;margin:4px 0 10px}
#page-dashboard .dash-todos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}
#page-dashboard .dash-todo-card{border:1px solid color-mix(in srgb,var(--todo-color) 18%,transparent);background:var(--todo-bg);border-radius:12px;padding:14px 16px;text-align:left;cursor:pointer;transition:transform .2s,box-shadow .2s}
#page-dashboard .dash-todo-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(15,23,42,.08)}
#page-dashboard .dash-todo-val{font-size:24px;font-weight:800;color:var(--todo-color);line-height:1.2}
#page-dashboard .dash-todo-label{font-size:12px;color:#64748B;margin-top:4px;font-weight:500}
#page-dashboard .dash-todo-pulse{animation:dashTodoPulse 2.2s ease-in-out infinite}
@keyframes dashTodoPulse{0%,100%{box-shadow:0 0 0 0 rgba(79,70,229,0)}50%{box-shadow:0 0 0 4px rgba(79,70,229,.12)}}
#page-dashboard .dash-kpi-bento{display:grid;grid-template-columns:minmax(220px,1fr) minmax(0,2fr);gap:14px;margin-bottom:22px;align-items:stretch}
#page-dashboard .dash-kpi-small-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
#page-dashboard .dash-kpi-icon{display:none}
#page-dashboard .dash-kpi-card{border-radius:14px;padding:18px 16px;position:relative;overflow:hidden;border:1px solid transparent;transition:transform .25s,box-shadow .25s}
#page-dashboard .dash-kpi-card.dash-kpi-clickable{cursor:pointer;user-select:none}
#page-dashboard .dash-kpi-card.dash-kpi-clickable::after{content:'\2192';position:absolute;right:14px;bottom:14px;font-size:15px;font-weight:700;opacity:0;transition:opacity .2s,transform .2s}
#page-dashboard .dash-kpi-card.dash-kpi-clickable:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(15,23,42,.12)}
#page-dashboard .dash-kpi-card.dash-kpi-clickable:hover::after{opacity:.4;transform:translateX(2px)}
#page-dashboard .dash-kpi-card.dash-kpi-clickable:active{transform:translateY(-1px)}
#page-dashboard .dash-kpi-card:not(.dash-kpi-clickable):hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(15,23,42,.08)}
#page-dashboard .dash-kpi-featured{min-height:100%;display:flex;flex-direction:column;justify-content:center;padding:24px 20px}
#page-dashboard .dash-kpi-featured .num{font-size:48px!important;font-weight:800!important;line-height:1}
#page-dashboard .dash-kpi-small .num{font-size:28px!important;font-weight:800!important;line-height:1.1}
#page-dashboard .dash-kpi-card .label{font-size:13px;font-weight:600;margin-top:8px}
#page-dashboard .dash-kpi-card .kpi-hint{font-size:11px;color:#64748B;margin-top:6px;min-height:16px}
#page-dashboard .dash-kpi-indigo{background:linear-gradient(145deg,#EEF2FF,#E0E7FF);border-color:rgba(79,70,229,.15)}
#page-dashboard .dash-kpi-indigo .num,#page-dashboard .dash-kpi-indigo .label{color:#4338CA}
#page-dashboard .dash-kpi-green{background:linear-gradient(145deg,#ECFDF5,#D1FAE5);border-color:rgba(16,185,129,.15)}
#page-dashboard .dash-kpi-green .num,#page-dashboard .dash-kpi-green .label{color:#047857}
#page-dashboard .dash-kpi-amber{background:linear-gradient(145deg,#FFFBEB,#FEF3C7);border-color:rgba(245,158,11,.15)}
#page-dashboard .dash-kpi-amber .num,#page-dashboard .dash-kpi-amber .label{color:#B45309}
#page-dashboard .dash-kpi-violet{background:linear-gradient(145deg,#F5F3FF,#EDE9FE);border-color:rgba(139,92,246,.15)}
#page-dashboard .dash-kpi-violet .num,#page-dashboard .dash-kpi-violet .label{color:#6D28D9}
#page-dashboard .dash-kpi-cyan{background:linear-gradient(145deg,#ECFEFF,#CFFAFE);border-color:rgba(6,182,212,.15)}
#page-dashboard .dash-kpi-cyan .num,#page-dashboard .dash-kpi-cyan .label{color:#0E7490}
#page-dashboard .dash-kpi-red{background:linear-gradient(145deg,#FFF1F2,#FFE4E6);border-color:rgba(239,68,68,.15)}
#page-dashboard .dash-kpi-red .num,#page-dashboard .dash-kpi-red .label{color:#DC2626}
#page-dashboard .dash-bento{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:16px}
#page-dashboard .dash-bento-stack .dash-bento-item{max-width:100%}
#page-dashboard .dash-bento-full{grid-column:1/-1}
#page-dashboard .dash-block{cursor:grab}
#page-dashboard .dash-chart-reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}
#page-dashboard .dash-chart-reveal.dash-revealed{opacity:1;transform:none}
#page-dashboard .dash-chart-card{margin-bottom:0!important}
#page-dashboard .dash-chart-card:hover{transform:none;box-shadow:0 1px 3px rgba(0,0,0,.1)}
/* 等级分布 — 方案A：五宫格 + 比例条 */
#page-dashboard .dash-grade-panel{overflow:hidden}
#page-dashboard .dash-grade-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:12px}
#page-dashboard .dash-grade-summary{font-size:12px;color:#64748B;white-space:nowrap}
#page-dashboard .dash-grade-summary b{color:#334155;font-weight:700}
#page-dashboard .dash-grade-body{display:flex;flex-direction:column;gap:12px}
#page-dashboard .dash-grade-hp{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:1px solid rgba(139,92,246,.22);border-radius:14px;cursor:pointer;text-align:left;
  background:linear-gradient(135deg,#F5F3FF 0%,#ECFDF5 100%);transition:transform .25s,box-shadow .25s}
#page-dashboard .dash-grade-hp:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(139,92,246,.15)}
#page-dashboard .dash-grade-hp-icon{font-size:18px;color:#8B5CF6;line-height:1}
#page-dashboard .dash-grade-hp-text{flex:1;min-width:0}
#page-dashboard .dash-grade-hp-label{display:block;font-size:11px;font-weight:600;color:#6D28D9;margin-bottom:2px}
#page-dashboard .dash-grade-hp-val{font-size:13px;color:#334155}
#page-dashboard .dash-grade-hp-val b{font-size:22px;font-weight:800;color:#5B21B6;margin-right:4px}
#page-dashboard .dash-grade-hp-track{width:72px;height:8px;border-radius:999px;background:rgba(255,255,255,.7);overflow:hidden;flex-shrink:0}
#page-dashboard .dash-grade-hp-fill{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,#8B5CF6,#10B981);animation:dashHpFill 1s cubic-bezier(.22,1,.36,1) .3s forwards}
@keyframes dashHpFill{to{width:var(--hp-pct)}}
#page-dashboard .dash-grade-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
#page-dashboard .dash-grade-cell{display:flex;flex-direction:column;align-items:center;padding:14px 8px;border:1px solid color-mix(in srgb,var(--grade-color) 20%,#E2E8F0);border-radius:14px;cursor:pointer;
  background:linear-gradient(160deg,color-mix(in srgb,var(--grade-color) 12%,#fff),#fff);transition:transform .25s,box-shadow .25s,border-color .25s;
  animation:dashGradeCellIn .55s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--i)*.06s)}
@keyframes dashGradeCellIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
#page-dashboard .dash-grade-cell:hover,#page-dashboard .dash-grade-cell--active{transform:translateY(-4px);border-color:var(--grade-color);box-shadow:0 12px 28px color-mix(in srgb,var(--grade-color) 22%,transparent)}
#page-dashboard .dash-grade-cell--zero{opacity:.42;filter:saturate(.35)}
#page-dashboard .dash-grade-cell--zero:hover{transform:none;box-shadow:none}
#page-dashboard .dash-grade-cell-badge{width:36px;height:36px;border-radius:12px;background:var(--grade-color);color:#fff;font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:8px;box-shadow:0 6px 16px color-mix(in srgb,var(--grade-color) 35%,transparent)}
#page-dashboard .dash-grade-cell-name{font-size:11px;font-weight:600;color:#64748B;margin-bottom:6px}
#page-dashboard .dash-grade-cell-num{font-size:24px;font-weight:800;color:#1E293B;line-height:1}
#page-dashboard .dash-grade-cell-pct{font-size:11px;font-weight:600;color:#94A3B8;margin-top:4px}
#page-dashboard .dash-grade-stack{margin-top:2px}
#page-dashboard .dash-grade-stack-bar{display:flex;height:12px;border-radius:999px;overflow:hidden;background:#F1F5F9;box-shadow:inset 0 1px 3px rgba(15,23,42,.06)}
#page-dashboard .dash-grade-stack-seg{height:100%;width:0;background:var(--seg-color);animation:dashGradeSegGrow 1.1s cubic-bezier(.22,1,.36,1) forwards;animation-delay:calc(var(--i)*.06s);position:relative;transition:filter .2s,opacity .2s}
#page-dashboard .dash-grade-stack-seg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.4),transparent 55%)}
#page-dashboard .dash-grade-stack-seg--active{filter:brightness(1.08);box-shadow:0 0 0 2px rgba(255,255,255,.9)}
@keyframes dashGradeSegGrow{to{width:var(--seg-pct)}}
#page-dashboard .dash-grade-stack-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
#page-dashboard .dash-grade-stack-key{font-size:11px;color:#64748B;font-weight:600;display:inline-flex;align-items:center;gap:5px}
#page-dashboard .dash-grade-stack-key i{width:8px;height:8px;border-radius:50%;background:var(--grade-color);display:inline-block}
#page-dashboard .dash-grade-panel.dash-grade-empty .dash-grade-body,#page-dashboard .dash-grade-panel.dash-grade-empty .dash-grade-summary{display:none}
#page-dashboard .dash-grade-empty-slot:empty{display:none}
@media(max-width:560px){
  #page-dashboard .dash-grade-grid{grid-template-columns:repeat(3,1fr)}
  #page-dashboard .dash-grade-cell:nth-child(4),#page-dashboard .dash-grade-cell:nth-child(5){grid-column:span 1}
  #page-dashboard .dash-grade-summary{width:100%;white-space:normal}
}
/* 等级趋势 — 炫酷面板 */
#page-dashboard .dash-trend-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:10px}
#page-dashboard .dash-trend-pills{display:flex;gap:6px;padding:4px;background:#F8FAFC;border-radius:12px;border:1px solid #E2E8F0}
#page-dashboard .dash-trend-pill{padding:6px 12px;border:none;border-radius:8px;background:transparent;font-size:12px;font-weight:600;color:#64748B;cursor:pointer;transition:all .25s}
#page-dashboard .dash-trend-pill:hover{color:#4338CA;background:rgba(99,102,241,.08)}
#page-dashboard .dash-trend-pill--active{color:#fff;background:linear-gradient(135deg,#6366F1,#4F46E5);box-shadow:0 4px 14px rgba(79,70,229,.4)}
#page-dashboard .dash-trend-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
#page-dashboard .dash-trend-stat{padding:10px 12px;border-radius:12px;border:1px solid #E2E8F0;background:#fff;position:relative;overflow:hidden}
#page-dashboard .dash-trend-stat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--trend-accent,#6366F1)}
#page-dashboard .dash-trend-stat--pace{--trend-accent:#6366F1;background:linear-gradient(160deg,#EEF2FF,#fff)}
#page-dashboard .dash-trend-stat--quality{--trend-accent:#F59E0B;background:linear-gradient(160deg,#FFFBEB,#fff)}
#page-dashboard .dash-trend-stat--peak{--trend-accent:#8B5CF6;background:linear-gradient(160deg,#F5F3FF,#fff)}
#page-dashboard .dash-trend-stat-label{display:block;font-size:11px;color:#64748B;font-weight:600;margin-bottom:4px}
#page-dashboard .dash-trend-stat-val{display:block;font-size:20px;font-weight:800;color:#1E293B;line-height:1.1}
#page-dashboard .dash-trend-stat-sub{display:block;font-size:10px;color:#94A3B8;margin-top:4px}
#page-dashboard .dash-trend-narrative{font-size:12px;color:#475569;line-height:1.55;padding:8px 12px;margin-bottom:8px;border-radius:10px;background:linear-gradient(90deg,#F8FAFC,#fff);border-left:3px solid #6366F1}
#page-dashboard .dash-trend-panel.dash-trend-empty .dash-trend-stats,#page-dashboard .dash-trend-panel.dash-trend-empty .dash-trend-narrative{display:none}
@media(max-width:560px){#page-dashboard .dash-trend-stats{grid-template-columns:1fr}}
#page-dashboard .dash-chart-hint{font-size:11px;font-weight:400;color:#94A3B8;margin-left:8px}
#page-dashboard .dash-chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:220px;padding:24px;text-align:center}
#page-dashboard .dash-chart-empty-title{font-size:15px;font-weight:600;color:#64748B;margin-bottom:8px}
#page-dashboard .dash-chart-empty-desc{font-size:13px;color:#94A3B8;line-height:1.6;max-width:360px}
#page-dashboard .dash-empty-btn{margin-top:14px;padding:8px 18px;border:none;border-radius:8px;background:#4F46E5;color:#fff;font-size:13px;font-weight:600;cursor:pointer}
#page-dashboard .dash-empty-btn:hover{background:#4338CA}
/* 通用洞察面板头 */
#page-dashboard .dash-panel-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px}
#page-dashboard .dash-panel-summary{font-size:12px;color:#64748B;white-space:nowrap}
#page-dashboard .dash-panel-summary b{color:#334155;font-weight:700}
#page-dashboard .dash-panel-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
#page-dashboard .dash-panel-chip{font-size:12px;padding:5px 12px;border-radius:20px;border:1px solid #E2E8F0;background:#F8FAFC;color:#64748B}
#page-dashboard .dash-panel-chip b{font-weight:700;color:#334155}
#page-dashboard .dash-panel-chip--up{background:linear-gradient(135deg,#ECFDF5,#F0FDF4);border-color:rgba(16,185,129,.25);color:#047857}
#page-dashboard .dash-panel-chip--down{background:linear-gradient(135deg,#FFFBEB,#FFF7ED);border-color:rgba(245,158,11,.25);color:#B45309}
#page-dashboard .dash-panel-empty-slot:empty{display:none}
#page-dashboard .dash-panel-empty .dash-panel-chips,#page-dashboard .dash-panel-empty .dash-dim-rows,#page-dashboard .dash-panel-empty .dash-score-body,#page-dashboard .dash-panel-empty .dash-pos-list,#page-dashboard .dash-panel-empty .dash-panel-summary{display:none}
/* 维度均分 */
#page-dashboard .dash-dim-panel{overflow:hidden;background:linear-gradient(180deg,#fff 0%,#FAFBFF 100%)}
#page-dashboard .dash-dim-insights{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
#page-dashboard .dash-dim-insight{padding:14px 16px;border-radius:14px;border:1px solid color-mix(in srgb,var(--dim-color) 22%,#E2E8F0);position:relative;overflow:hidden;
  background:linear-gradient(145deg,color-mix(in srgb,var(--dim-color) 10%,#fff),#fff);animation:dashPanelRowIn .5s cubic-bezier(.22,1,.36,1) both}
#page-dashboard .dash-dim-insight--top{--dim-color:#10B981}
#page-dashboard .dash-dim-insight--weak{--dim-color:#F59E0B;animation-delay:.08s}
#page-dashboard .dash-dim-insight::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--dim-color),color-mix(in srgb,var(--dim-color) 40%,#fff))}
#page-dashboard .dash-dim-insight-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.04em;padding:3px 8px;border-radius:999px;margin-bottom:8px;
  background:color-mix(in srgb,var(--dim-color) 14%,#fff);color:color-mix(in srgb,var(--dim-color) 75%,#1E293B)}
#page-dashboard .dash-dim-insight--top .dash-dim-insight-tag{background:#ECFDF5;color:#047857}
#page-dashboard .dash-dim-insight--weak .dash-dim-insight-tag{background:#FFFBEB;color:#B45309}
#page-dashboard .dash-dim-insight-name{display:block;font-size:13px;font-weight:700;color:#1E293B;margin-bottom:4px;line-height:1.3}
#page-dashboard .dash-dim-insight-val{display:block;font-size:28px;font-weight:800;color:var(--dim-color);line-height:1}
#page-dashboard .dash-dim-insight-val small{font-size:14px;font-weight:700;opacity:.75}
#page-dashboard .dash-dim-insight-track{height:6px;border-radius:999px;background:#F1F5F9;margin-top:10px;overflow:hidden}
#page-dashboard .dash-dim-insight-fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--dim-color) 35%,#fff),var(--dim-color));animation:dashPanelBarGrow .9s cubic-bezier(.22,1,.36,1) .2s forwards}
#page-dashboard .dash-dim-rows{display:flex;flex-direction:column;gap:8px}
#page-dashboard .dash-dim-row--more{display:none}
#page-dashboard .dash-dim-rows--expanded .dash-dim-row--more{display:flex}
#page-dashboard .dash-dim-row{display:flex;align-items:flex-start;gap:12px;width:100%;padding:12px 14px;border:1px solid #E8EDF5;border-radius:14px;background:#fff;cursor:pointer;text-align:left;
  transition:transform .25s,box-shadow .25s,border-color .25s;animation:dashPanelRowIn .5s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--i)*.04s)}
#page-dashboard .dash-dim-row:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--dim-color) 35%,#E2E8F0);box-shadow:0 10px 26px color-mix(in srgb,var(--dim-color) 16%,transparent)}
#page-dashboard .dash-dim-row-rank{flex-shrink:0;width:30px;height:30px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#94A3B8;background:#F8FAFC}
#page-dashboard .dash-dim-row-rank--1{background:linear-gradient(135deg,#FDE68A,#F59E0B);color:#fff;box-shadow:0 4px 12px rgba(245,158,11,.35)}
#page-dashboard .dash-dim-row-rank--2{background:linear-gradient(135deg,#E2E8F0,#94A3B8);color:#fff;box-shadow:0 4px 12px rgba(148,163,184,.3)}
#page-dashboard .dash-dim-row-rank--3{background:linear-gradient(135deg,#FED7AA,#EA580C);color:#fff;box-shadow:0 4px 12px rgba(234,88,12,.28)}
#page-dashboard .dash-dim-row-main{flex:1;min-width:0}
#page-dashboard .dash-dim-row-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:8px}
#page-dashboard .dash-dim-row-label{font-size:13px;font-weight:700;color:#1E293B}
#page-dashboard .dash-dim-row-pct{font-size:20px;font-weight:800;color:var(--dim-color);line-height:1;flex-shrink:0}
#page-dashboard .dash-dim-row-pct small{font-size:12px;font-weight:700;opacity:.7}
#page-dashboard .dash-dim-row-track{position:relative;height:10px;border-radius:999px;background:#EEF2FF;overflow:visible;margin-bottom:6px}
#page-dashboard .dash-dim-row-fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--dim-color) 20%,#fff),var(--dim-color));box-shadow:0 0 12px color-mix(in srgb,var(--dim-color) 35%,transparent);animation:dashPanelBarGrow 1s cubic-bezier(.22,1,.36,1) forwards;animation-delay:calc(var(--i)*.05s + .12s)}
#page-dashboard .dash-dim-row-dot{position:absolute;top:50%;left:0;width:10px;height:10px;border-radius:50%;background:#fff;border:2px solid var(--dim-color);transform:translate(-50%,-50%);opacity:0;animation:dashDimDotIn .6s ease forwards;animation-delay:calc(var(--i)*.05s + .7s)}
@keyframes dashDimDotIn{to{left:var(--pct);opacity:1}}
#page-dashboard .dash-dim-row-score{font-size:11px;font-weight:600;color:#64748B}
#page-dashboard .dash-dim-row-score small{font-weight:500;color:#94A3B8}
#page-dashboard .dash-dim-expand{display:block;width:100%;margin-top:10px;padding:10px 14px;border:1px dashed #CBD5E1;border-radius:12px;background:#F8FAFC;color:#64748B;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}
#page-dashboard .dash-dim-expand:hover{border-color:#6366F1;color:#4F46E5;background:#EEF2FF}
#page-dashboard .dash-dim-panel.dash-panel-empty .dash-dim-insights{display:none}
/* 评分分布 */
#page-dashboard .dash-score-body{display:flex;flex-direction:column;gap:12px}
#page-dashboard .dash-score-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
#page-dashboard .dash-score-cell{display:flex;flex-direction:column;align-items:center;padding:12px 6px;border:1px solid color-mix(in srgb,var(--score-color) 25%,#E2E8F0);border-radius:14px;cursor:pointer;
  background:linear-gradient(160deg,color-mix(in srgb,var(--score-color) 14%,#fff),#fff);transition:transform .25s,box-shadow .25s;animation:dashGradeCellIn .55s both;animation-delay:calc(var(--i)*.06s)}
#page-dashboard .dash-score-cell:hover{transform:translateY(-4px);box-shadow:0 12px 26px color-mix(in srgb,var(--score-color) 22%,transparent)}
#page-dashboard .dash-score-cell--zero{opacity:.4;filter:saturate(.4)}
#page-dashboard .dash-score-cell-range{font-size:10px;font-weight:600;color:#64748B;margin-bottom:6px}
#page-dashboard .dash-score-cell-num{font-size:22px;font-weight:800;color:#1E293B;line-height:1}
#page-dashboard .dash-score-cell small{font-size:11px;color:#94A3B8;margin-top:4px;font-weight:600}
#page-dashboard .dash-score-stack-bar{display:flex;height:12px;border-radius:999px;overflow:hidden;background:#F1F5F9;box-shadow:inset 0 1px 3px rgba(15,23,42,.06)}
#page-dashboard .dash-score-stack-seg{height:100%;width:0;background:var(--seg-color);animation:dashGradeSegGrow 1.1s cubic-bezier(.22,1,.36,1) forwards;animation-delay:calc(var(--i)*.06s)}
#page-dashboard .dash-score-stack-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
#page-dashboard .dash-score-stack-legend span{font-size:11px;color:#64748B;font-weight:600;display:inline-flex;align-items:center;gap:5px}
#page-dashboard .dash-score-stack-legend i{width:8px;height:8px;border-radius:50%;background:var(--seg-color);display:inline-block}
/* 岗位排行 */
#page-dashboard .dash-pos-list{display:flex;flex-direction:column;gap:8px}
#page-dashboard .dash-pos-row{display:grid;grid-template-columns:28px minmax(80px,1fr) 1fr 40px;gap:10px;align-items:center;width:100%;padding:10px 12px;border:1px solid #E2E8F0;border-radius:12px;background:#fff;cursor:pointer;text-align:left;
  transition:transform .25s,box-shadow .25s;animation:dashPanelRowIn .5s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--i)*.06s)}
#page-dashboard .dash-pos-row:hover{transform:translateX(4px);box-shadow:0 8px 22px rgba(99,102,241,.12);border-color:#C7D2FE}
#page-dashboard .dash-pos-row--top{border-color:rgba(245,158,11,.35);background:linear-gradient(135deg,#FFFBEB,#fff)}
#page-dashboard .dash-pos-row--2{border-color:rgba(148,163,184,.35);background:linear-gradient(135deg,#F8FAFC,#fff)}
#page-dashboard .dash-pos-row--3{border-color:rgba(180,83,9,.2);background:linear-gradient(135deg,#FFF7ED,#fff)}
#page-dashboard .dash-pos-rank{font-size:12px;font-weight:800;color:#94A3B8;text-align:center}
#page-dashboard .dash-pos-row--top .dash-pos-rank{color:#D97706}
#page-dashboard .dash-pos-title{font-size:12px;font-weight:600;color:#334155;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#page-dashboard .dash-pos-track{height:8px;border-radius:999px;background:#F1F5F9;overflow:hidden}
#page-dashboard .dash-pos-fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,#C7D2FE,#6366F1);animation:dashPosFill 1s cubic-bezier(.22,1,.36,1) forwards;animation-delay:calc(var(--i)*.08s + .1s)}
@keyframes dashPosFill{to{width:var(--pos-pct)}}
@keyframes dashPanelRowIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:none}}
@keyframes dashPanelBarGrow{to{width:var(--pct)}}
#page-dashboard .dash-pos-count{font-size:18px;font-weight:800;color:#4F46E5;text-align:right}
@media(max-width:560px){
  #page-dashboard .dash-score-grid{grid-template-columns:repeat(3,1fr)}
  #page-dashboard .dash-dim-insights{grid-template-columns:1fr}
  #page-dashboard .dash-dim-row-pct{font-size:18px}
  #page-dashboard .dash-panel-summary{width:100%;white-space:normal}
}
body.dark #page-dashboard .dash-hero{background:linear-gradient(135deg,#1E1B4B 0%,#1E293B 60%,#0F172A 100%);border-color:#334155}
body.dark #page-dashboard .dash-hero-title{color:#E2E8F0}
body.dark #page-dashboard .dash-hero-sub,body.dark #page-dashboard .dash-live{color:#94A3B8}
body.dark #page-dashboard .dash-more-panel{background:#1E293B;border-color:#334155}
@media(max-width:1024px){
  #page-dashboard .dash-kpi-bento{grid-template-columns:1fr}
  #page-dashboard .dash-kpi-small-grid{grid-template-columns:repeat(2,1fr)}
  #page-dashboard .dash-todos-grid{grid-template-columns:repeat(2,1fr)}
  #page-dashboard .dash-bento{grid-template-columns:1fr}
}
@media(max-width:640px){
  #page-dashboard .dash-kpi-small-grid,#page-dashboard .dash-todos-grid{grid-template-columns:1fr}
  #page-dashboard .dash-hero-metric{text-align:left;width:100%}
}

/* 打赏设置 — 自愿支持布局 */
.donation-panel{padding:16px 18px!important}
.donation-panel .card-title{margin-bottom:6px!important}
.donation-desc{font-size:12px;line-height:1.65;color:var(--txt-l);margin:0 0 8px;padding:10px 12px;background:rgba(79,70,229,.06);border-radius:8px;border-left:3px solid var(--pri)}
.donation-pay-tip{font-size:12px;color:var(--txt-l);margin:0 0 6px}
.donation-ref-hint{font-size:11px;color:var(--txt-l);margin:0 0 10px;opacity:.85}
.donation-qr-row{display:flex;gap:16px;margin-bottom:12px;flex-wrap:wrap}
.donation-qr-item{text-align:center;font-size:12px;color:var(--txt-l)}
.donation-qr-item img{display:block;margin-top:4px;max-width:110px;border-radius:6px;border:1px solid var(--bd)}
.donation-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.donation-amount-row,.donation-remark-row{margin-bottom:0!important}
.donation-amount-row label,.donation-remark-row label{font-size:12px}
.donation-amount-row input,.donation-remark-row input{padding:8px 10px;font-size:13px}
.donation-submit-btn{padding:8px 20px!important;font-size:13px!important;width:auto!important}
.donation-orders-wrap{margin-top:12px;font-size:12px}
@media(max-width:560px){.donation-form-row{grid-template-columns:1fr}}
.tbl-compact{font-size:12px}
.tbl-compact th,.tbl-compact td{padding:6px 8px!important}
.points-summary{font-size:12px;line-height:1.7;color:var(--txt-l);margin:0 0 10px;padding:10px 12px;background:rgba(16,185,129,.08);border-radius:8px;border-left:3px solid #10B981}
.support-note{font-size:11px;line-height:1.65;color:var(--txt-l);margin:0 0 8px;padding:8px 10px;background:rgba(107,114,128,.08);border-radius:6px}
body.dark .points-summary{background:rgba(16,185,129,.15)}
body.dark .support-note{background:rgba(107,114,128,.15)}

/* Bug反馈 + 等级弹窗 */
.bug-panel{padding:16px 18px!important}
.bug-desc{font-size:12px;line-height:1.65;color:var(--txt-l);margin:0 0 10px;padding:10px 12px;background:rgba(239,68,68,.06);border-radius:8px;border-left:3px solid #EF4444}
.bug-orders-wrap{margin-top:12px;font-size:12px}
.profile-level-link:hover{opacity:.85}
.level-modal-box{max-width:520px;width:92%;background:var(--card);border-radius:12px;padding:20px;max-height:85vh;overflow:auto}
.level-modal-item{background:var(--card);border-radius:10px;padding:12px 14px;margin-bottom:10px;border:1px solid var(--bd)}
.level-modal-name{font-size:15px;font-weight:700;margin-bottom:6px}
.level-modal-perms{margin:0;padding-left:18px;font-size:13px;line-height:1.8;color:var(--txt-l)}
body.dark .bug-desc{background:rgba(239,68,68,.12)}
.bug-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
/* 个人中心布局与按钮 */
.profile-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.profile-layout.profile-layout--single{grid-template-columns:1fr;max-width:680px}
.profile-basic-card,.profile-bug-card{min-width:0}
.profile-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.profile-name-inline{flex:1;min-width:120px;max-width:220px;padding:4px 10px;border:1px solid var(--bd);border-radius:6px;font-size:14px;background:var(--card);color:var(--txt)}
.profile-name-inline:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 2px rgba(99,102,241,.15)}
.profile-btn-name-save{padding:4px 14px;font-size:12px;font-weight:600;border:none;border-radius:6px;cursor:pointer;color:#fff;background:linear-gradient(135deg,#6366F1,#8B5CF6);box-shadow:0 2px 6px rgba(99,102,241,.3);white-space:nowrap}
.profile-btn-name-save:hover{opacity:.92;transform:translateY(-1px)}
body.dark .profile-btn-name-save{background:linear-gradient(135deg,#4F46E5,#7C3AED)}
#page-profile .profile-btn-primary{background:linear-gradient(135deg,#6366F1,#8B5CF6);color:#fff;border:none;box-shadow:0 2px 8px rgba(99,102,241,.35)}
#page-profile .profile-btn-primary:hover{opacity:.92;transform:translateY(-1px)}
#page-profile .profile-btn-secondary{background:linear-gradient(135deg,#0EA5E9,#06B6D4);color:#fff;border:none;box-shadow:0 2px 8px rgba(14,165,233,.3)}
#page-profile .profile-btn-secondary:hover{opacity:.92;transform:translateY(-1px)}
body.dark #page-profile .profile-btn-primary{background:linear-gradient(135deg,#4F46E5,#7C3AED);box-shadow:0 2px 8px rgba(79,70,229,.4)}
body.dark #page-profile .profile-btn-secondary{background:linear-gradient(135deg,#0284C7,#0891B2);box-shadow:0 2px 8px rgba(2,132,199,.35)}
@media(max-width:960px){.profile-layout{grid-template-columns:1fr;max-width:680px}}
/* 岗位弹窗：模板等级 / 使用模板 互斥高亮 + 等级同步 */
.pos-match-level-select,.pos-use-template-btn{transition:background .2s,border-color .2s,color .2s,box-shadow .2s}
.pos-match-level-select.pos-action-active{background:linear-gradient(135deg,#EEF2FF,#E0E7FF)!important;border-color:#6366F1!important;color:#4338CA!important;font-weight:600;box-shadow:0 0 0 2px rgba(99,102,241,.2)}
.pos-use-template-btn.pos-action-active{background:linear-gradient(135deg,#6366F1,#8B5CF6)!important;border-color:transparent!important;color:#fff!important;font-weight:600;box-shadow:0 2px 8px rgba(99,102,241,.35)}
.pos-use-template-btn:not(.pos-action-active){background:#fff;border:1px solid var(--bd);color:var(--txt)}
.modal-pos-level-select.pos-level-from-template{background:linear-gradient(135deg,#F0FDF4,#DCFCE7)!important;border-color:#22C55E!important;box-shadow:0 0 0 2px rgba(34,197,94,.15)}
body.dark .pos-match-level-select.pos-action-active{background:linear-gradient(135deg,#312E81,#3730A3)!important;color:#E0E7FF!important}
body.dark .pos-use-template-btn:not(.pos-action-active){background:#1E293B;border-color:#475569;color:#E2E8F0}
body.dark .modal-pos-level-select.pos-level-from-template{background:linear-gradient(135deg,#14532D,#166534)!important;border-color:#22C55E!important}
.usage-quota-hint{margin-top:8px;padding:8px 12px;border-radius:8px;font-size:12px;line-height:1.5}
.usage-quota-hint--warn{background:#FEF2F2;border:1px solid #FECACA;color:#B91C1C}
.usage-quota-hint--info{background:#EFF6FF;border:1px solid #BFDBFE;color:#1D4ED8}
.usage-quota-hint--inline{display:inline-block;margin:0;padding:4px 10px;font-size:11px;vertical-align:middle}
body.dark .usage-quota-hint--warn{background:#7F1D1D;border-color:#DC2626;color:#FCA5A5}
body.dark .usage-quota-hint--info{background:#1E3A5F;border-color:#2563EB;color:#93C5FD}
.export-btn--locked,.export-btn--locked:hover,.quota-btn--locked,.quota-btn--locked:hover{opacity:.45;cursor:not-allowed!important;filter:grayscale(.35);transform:none!important;box-shadow:none!important}
.bug-file-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.bug-file-tag{font-size:12px;padding:4px 8px;background:#F3F4F6;border-radius:6px;color:var(--txt-l)}
body.dark .bug-file-tag{background:#334155}
.contact-modal-box{max-width:360px;width:92%;background:var(--card);border-radius:12px;overflow:hidden}
.contact-modal-body{padding:20px 24px 28px;text-align:center}
.contact-qr-img{max-width:240px;width:100%;border-radius:8px;border:1px solid var(--bd)}
.contact-qr-empty{font-size:13px;color:var(--txt-l);margin:0;line-height:1.6}
.feedback-att-modal-box{max-width:720px;width:94%;background:var(--card);border-radius:12px;overflow:hidden}
.feedback-att-body{padding:16px 20px;text-align:center;min-height:120px;max-height:70vh;overflow:auto}
.feedback-att-preview{max-width:100%;max-height:60vh;border-radius:8px;border:1px solid var(--bd);cursor:zoom-in}
.feedback-att-pdf{width:100%;height:60vh;border:none;border-radius:8px;background:#fff}
.feedback-att-actions{display:flex;gap:10px;justify-content:center;padding:0 20px 20px}
.bug-att-list{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.bug-att-item{display:inline-flex;flex-direction:column;align-items:center;gap:4px;max-width:72px}
.bug-att-thumb{width:56px;height:56px;object-fit:cover;border-radius:6px;border:1px solid var(--bd);cursor:pointer}
.bug-att-btn{font-size:12px;padding:3px 8px;border:1px solid var(--bd);border-radius:6px;background:var(--card);cursor:pointer;color:var(--txt);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bug-att-btn:hover{background:#F3F4F6}
body.dark .bug-att-btn:hover{background:#334155}
.feedback-detail-box{max-width:640px;width:94%;background:var(--card);border-radius:12px;overflow:hidden;max-height:85vh;display:flex;flex-direction:column}
.feedback-detail-body{padding:16px 20px;overflow:auto;font-size:13px;line-height:1.7;flex:1}
.feedback-detail-admin{padding:0 20px 20px;border-top:1px solid var(--bd)}
.feedback-detail-reply-prev{margin-bottom:12px;padding:10px 12px;background:#EFF6FF;border-radius:8px;font-size:13px;line-height:1.6}
body.dark .feedback-detail-reply-prev{background:#1E3A5F}
.feedback-reply-cell{font-size:12px;color:var(--txt-l);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.feedback-detail-meta{color:var(--txt-l);font-size:12px;margin-bottom:12px}
.feedback-detail-content{white-space:pre-wrap;background:#F8FAFC;padding:12px;border-radius:8px;margin-bottom:12px}
body.dark .feedback-detail-content{background:#1E293B}