
:root{--p:#1677ff;--g:#52c41a;--o:#faad14;--r:#ff4d4f;--bg:#f0f2f5;--w:#fff;--t:#333;--t2:#999;--b:#f0f0f0;--sdw:0 2px 8px rgba(0,0,0,.06)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'PingFang SC','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--t);font-size:14px;line-height:1.5}
input,select,textarea,button{font-family:inherit;font-size:inherit}
a{color:var(--p);text-decoration:none}

/* ==== LAYOUT ==== */
.app-layout{display:flex;min-height:100vh}
.sidebar{width:208px;background:#001529;color:#fff;flex-shrink:0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}
.sidebar-logo{padding:16px 14px;border-bottom:1px solid rgba(255,255,255,.1)}
.sidebar-brand{display:flex;align-items:center;gap:10px}
.site-logo-img{width:48px;height:48px;border-radius:12px;background:#fff;padding:4px;object-fit:contain;box-shadow:0 2px 10px rgba(0,0,0,.18);flex-shrink:0}
.sidebar-logo h2{font-size:16px;font-weight:600;white-space:nowrap}
.sidebar-logo small{font-size:11px;opacity:.58;display:block;margin-top:4px}
.sidebar-menu{padding:8px 0;flex:1}
.sm-group{padding:12px 20px 4px;font-size:11px;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:1px}
.sm-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:rgba(255,255,255,.65);cursor:pointer;transition:all .2s;border-left:3px solid transparent;font-size:14px}
.sm-item:hover{color:#fff;background:rgba(255,255,255,.05)}
.sm-item.active{color:#fff;background:rgba(22,119,255,.3);border-left-color:var(--p)}
.sm-item .sm-ico{font-size:18px;width:24px;text-align:center}
.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1)}
.sidebar-footer .user-info{display:flex;align-items:center;gap:10px;cursor:pointer}
.sidebar-footer .user-info:hover{opacity:.9}
.sidebar-footer .avatar{width:36px;height:36px;border-radius:50%;background:var(--p);display:flex;align-items:center;justify-content:center;font-size:16px}
.sidebar-user-name{font-size:14px;color:#fff;max-width:128px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-sub{font-size:11px;color:rgba(255,255,255,.4)}

.main-area{flex:1;margin-left:208px;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:var(--w);height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:var(--sdw);position:sticky;top:0;z-index:90}
.topbar .bread{font-size:16px;font-weight:500;color:var(--t)}
.topbar .top-right{display:flex;align-items:center;gap:16px}
.topbar .top-right .bell{font-size:20px;cursor:pointer;color:var(--t2)}
.top-user{border:1px solid var(--b);background:var(--w);border-radius:6px;padding:5px 10px;display:inline-flex;align-items:center;gap:7px;cursor:pointer;color:var(--t);max-width:180px}
.top-user span:last-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-avatar{width:22px;height:22px;border-radius:50%;background:var(--p);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.profile-card{min-width:520px;max-width:680px}
.profile-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.profile-avatar{width:52px;height:52px;border-radius:50%;background:var(--p);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}
.profile-head h3{font-size:18px;margin:0}
.profile-head p{color:var(--t2);margin-top:4px}
.profile-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
.page-content{flex:1;padding:16px}
.page-content.fluid{padding:16px;padding-bottom:80px}
.project-fill-shell{margin-left:0;min-height:100vh}
.project-fill-topbar{width:1250px;max-width:calc(100vw - 32px);height:56px;background:var(--w);display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:var(--sdw);position:sticky;top:0;z-index:90;margin:0 auto}
.project-fill-title{font-size:16px;font-weight:600}
.project-fill-expire{font-size:12px;color:var(--t2);margin-top:2px}
.project-fill-user{display:flex;align-items:center;gap:12px}
.project-fill-user span{font-size:13px;color:var(--t2)}
.project-fill-page{width:1250px;max-width:calc(100vw - 32px);margin:0 auto}
.fill-countdown-expired{color:var(--r);font-weight:600}

/* ==== TAB BAR (mobile) ==== */
.mobile-tabs{display:none;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--w);border-top:1px solid var(--b);z-index:100;padding-bottom:env(safe-area-inset-bottom)}
.mt-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--t2);font-size:11px;cursor:pointer}
.mt-item.active{color:var(--p)}
.mt-item .mt-ico{font-size:22px}
.mobile-header{display:none;background:linear-gradient(135deg,var(--p),#0958d9);color:#fff;padding:12px 16px;position:sticky;top:0;z-index:90}
.mobile-header .mh-title{font-size:18px;font-weight:600}
.back-btn{background:none;border:none;color:#fff;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}

/* ==== CARDS & COMPONENTS ==== */
.card{background:var(--w);border-radius:10px;padding:16px;box-shadow:var(--sdw);margin-bottom:12px;cursor:pointer;transition:box-shadow .15s}
.card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08)}
.card:active{background:#fafafa}
.card-row{display:flex;align-items:center;gap:12px}
.card-between{justify-content:space-between}
.card-title{font-weight:600;font-size:15px;margin-bottom:4px}
.card-meta{font-size:12px;color:var(--t2);display:flex;gap:12px;flex-wrap:wrap}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.stat-card{background:var(--w);border-radius:12px;padding:20px;box-shadow:var(--sdw);display:flex;align-items:center;gap:16px;cursor:pointer;transition:box-shadow .15s}
.stat-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08)}
.stat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.stat-icon.b{background:#e6f4ff;color:var(--p)}.stat-icon.g{background:#f6ffed;color:var(--g)}
.stat-icon.o{background:#fff7e6;color:var(--o)}.stat-icon.r{background:#fff2f0;color:var(--r)}
.stat-num{font-size:28px;font-weight:700;line-height:1.2}
.stat-label{font-size:13px;color:var(--t2);margin-top:4px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.panel{background:var(--w);border-radius:12px;padding:20px;box-shadow:var(--sdw)}
.panel-title{font-size:16px;font-weight:600;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}

.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--b)}
th{background:#fafafa;font-weight:600;color:var(--t);white-space:nowrap}
tr:hover td{background:#fafafa}
.actions{display:flex;gap:8px}

/* ==== TAGS ==== */
.tag{display:inline-flex;padding:2px 10px;border-radius:10px;font-size:12px;font-weight:500}
.tag-g{background:#f6ffed;color:#389e0d}.tag-b{background:#e6f4ff;color:#0958d9}
.tag-o{background:#fff7e6;color:#d48806}.tag-r{background:#fff2f0;color:#cf1322}

/* ==== BUTTONS ==== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 18px;border:1px solid #d9d9d9;border-radius:8px;background:var(--w);font-size:14px;cursor:pointer;white-space:nowrap;transition:all .2s}
.btn:hover{border-color:var(--p);color:var(--p)}
.btn-p{background:var(--p);border-color:var(--p);color:#fff}.btn-p:hover{background:#4096ff;color:#fff}
.btn-d{color:var(--r);border-color:var(--r)}.btn-d:hover{background:var(--r);color:#fff}
.btn-s{height:30px;padding:0 12px;font-size:13px}
.btn-w{width:100%}
.btn-o{border-color:var(--p);color:var(--p);background:transparent}

/* ==== FORMS ==== */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:14px;font-weight:500;margin-bottom:6px;color:var(--t)}
.form-input,.form-select,.form-textarea{width:100%;height:40px;padding:0 12px;border:1px solid #d9d9d9;border-radius:8px;font-size:14px;outline:none;background:var(--w);transition:border-color .2s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--p);box-shadow:0 0 0 2px rgba(22,119,255,.15)}
.form-textarea{height:auto;min-height:70px;padding:10px 12px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-row3{grid-template-columns:1fr 1fr 1fr}
.fg{margin:0}
.fl{display:block;font-size:13px;font-weight:600;color:#4b5563;margin-bottom:6px}
.fi,.fs,.ft{width:100%;border:1px solid #d6dbe3;border-radius:8px;background:#fff;color:var(--t);outline:none;transition:border-color .18s,box-shadow .18s,background .18s}
.fi,.fs{height:40px;padding:0 12px}
.ft{min-height:92px;padding:10px 12px;resize:vertical;line-height:1.5}
.fi:focus,.fs:focus,.ft:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(22,119,255,.12)}
.fh{font-size:12px;color:var(--t2);margin-top:5px}
.project-participant-section{grid-column:1/-1;border:1px solid #e5eaf2;border-radius:10px;background:#fbfcff;padding:14px}
.project-participant-title{font-size:15px;font-weight:700;color:#1f2937;margin-bottom:12px}
.project-participant-grid{display:grid;grid-template-columns:1fr;gap:14px}
.project-participant-card{border:1px solid #e2e8f0;border-radius:10px;background:#fff;padding:12px 14px}
.project-participant-card-title{font-weight:700;color:#111827;margin-bottom:10px}
.project-participant-fields{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 12px}
.project-participant-fields .fg{min-width:0}
.project-participant-fields .fl{font-size:12px;margin-bottom:5px}
.project-participant-fields .fi,.project-participant-fields .fs{height:36px}
.project-participant-card:last-child .project-participant-fields{grid-template-columns:minmax(0,1fr)}

/* ==== MODAL ==== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:flex;align-items:center;justify-content:center}
.modal-box{background:var(--w);border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.15);width:min(680px,95vw);max-width:95vw;max-height:88vh;display:flex;flex-direction:column;overflow:hidden}
.modal-box.modal-wide{width:min(1180px,94vw);height:min(820px,90vh)}
.modal-box.modal-xl{width:min(1440px,98vw);height:min(850px,92vh)}
.modal-box.modal-form{width:min(860px,94vw)}
.modal-box.modal-wide.modal-form{width:min(1180px,94vw)}
.modal-box.modal-xl.modal-form{width:min(1440px,98vw)}
.modal-header{padding:16px 24px;border-bottom:1px solid var(--b);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--w);z-index:1}
.modal-title{font-size:17px;font-weight:600}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg);border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.modal-body{padding:24px;overflow:auto;min-height:0}
.modal-form .modal-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 18px;background:linear-gradient(#fff,#fff) padding-box}
.modal-form .modal-body>.modal-xl-content,.modal-form .modal-body>.apply-review-form{grid-column:1/-1}
.modal-form .modal-body>.fg:has(.ft){grid-column:1/-1}
.modal-form .modal-body>.form-row,.modal-form .modal-body>.form-tip{grid-column:1/-1}
.form-tip{padding:10px 12px;border-radius:8px;background:#f6f8ff;color:var(--t2);font-size:13px;line-height:1.5}
.modal-footer{padding:12px 24px;border-top:1px solid var(--b);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}

/* ==== WORKFLOW ==== */
.workflow{display:flex;justify-content:space-between;padding:20px 40px;background:var(--w);border-radius:12px;margin-bottom:20px;box-shadow:var(--sdw)}
.wf-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}
.wf-step::after{content:'';position:absolute;top:20px;left:50%;width:100%;height:3px;background:#e8e8e8;z-index:0}
.wf-step:last-child::after{display:none}
.wf-dot{width:40px;height:40px;border-radius:50%;background:#e8e8e8;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;font-size:16px;color:#999;transition:all .3s}
.wf-step.done .wf-dot{background:var(--g);color:#fff}.wf-step.active .wf-dot{background:var(--p);color:#fff}
.wf-step.done::after{background:var(--g)}.wf-step.active::after{background:var(--p)}
.wf-label{font-size:13px;color:var(--t2);margin-top:8px}
.wf-step.active .wf-label,.wf-step.done .wf-label{color:var(--t);font-weight:500}

/* ==== DETAIL ==== */
.detail-header{background:linear-gradient(135deg,var(--p),#0958d9);color:#fff;padding:24px;border-radius:12px;margin-bottom:20px}
.detail-id{font-size:12px;opacity:.7;margin-bottom:6px}
.detail-name{font-size:22px;font-weight:700;margin-bottom:10px}
.detail-tags{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.detail-tags .pass-badge{background:rgba(82,196,26,.3);border:1px solid rgba(82,196,26,.5);padding:4px 16px;border-radius:20px;font-size:13px}

.info-table{width:100%;border:1px solid var(--b);border-radius:8px;overflow:hidden}
.info-table td{padding:10px 16px;border-bottom:1px solid var(--b)}
.info-table .ilbl{background:#fafafa;width:120px;color:var(--t2);font-weight:500}
.tab-bar{display:flex;border-bottom:2px solid var(--b);margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tab-item{padding:10px 10px;cursor:pointer;color:var(--t2);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;font-size:13px;white-space:nowrap}
.tab-item:hover{color:var(--p)}
.tab-item.active{color:var(--p);border-bottom-color:var(--p);font-weight:500}

/* ==== LOGIN (desktop) ==== */
.login-page{min-height:100vh;background:linear-gradient(120deg,#102033 0%,#174f68 45%,#1c7ff2 100%);display:flex;align-items:center;justify-content:center;padding:clamp(24px,5vw,72px)}
.login-shell{width:min(1240px,100%);display:grid;grid-template-columns:minmax(520px,1fr) minmax(360px,430px);gap:28px;align-items:center}
.login-shell-fill{width:min(430px,100%);grid-template-columns:1fr;justify-content:center}
.login-shell-fill .login-box{grid-column:1;grid-row:1}
.login-box,.login-public{background:#fff;border:1px solid rgba(255,255,255,.7);border-radius:18px;box-shadow:0 22px 70px rgba(3,18,38,.28)}
.login-box{grid-column:2;grid-row:1;width:100%;min-height:560px;padding:44px 44px 38px;display:flex;flex-direction:column;justify-content:center}
.login-brand-block{text-align:center}
.login-logo{display:block;width:92px;height:92px;object-fit:contain;margin:0 auto 22px;border-radius:24px;background:#fff;padding:7px;box-shadow:0 12px 30px rgba(15,56,107,.14)}
.login-box h1{color:var(--p);font-size:25px;line-height:1.25;margin-bottom:8px}
.login-box .sub{color:var(--t2);font-size:14px}
.login-form{margin-top:38px;display:grid;gap:12px}
.login-box .fi{height:46px;border-radius:10px;background:#fbfdff;font-size:15px}
.login-box .err{color:var(--r);font-size:13px;text-align:center;min-height:20px;line-height:20px}
.login-box .login-btn{width:100%;height:52px;background:var(--p);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 10px 24px rgba(22,119,255,.28)}
.login-box .login-btn:hover{background:#4096ff}
.login-box .login-btn:disabled{opacity:.7;cursor:not-allowed}
.login-demo{text-align:center;margin-top:2px;font-size:12px;color:var(--t2)}
.login-public{grid-column:1;grid-row:1;min-height:560px;max-height:calc(100vh - 144px);padding:30px 32px;display:flex;flex-direction:column}
.lp-head{display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid #e7edf5;padding-bottom:16px;margin-bottom:16px}
.lp-kicker{font-size:12px;font-weight:700;color:#187064;margin-bottom:6px}
.lp-head h2{font-size:24px;color:#122d4f;margin-bottom:6px;line-height:1.2}
.lp-head p{font-size:13px;color:#7a8492}
.lp-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.lp-tabs button{height:34px;border:1px solid #d6dbe3;background:#fff;border-radius:18px;padding:0 14px;cursor:pointer;color:#44546a;font-size:13px;transition:all .18s}
.lp-tabs button:hover{border-color:var(--p);color:var(--p)}
.lp-tabs button.on{background:var(--p);border-color:var(--p);color:#fff;font-weight:600}
.lp-list{flex:1;overflow:auto;display:grid;align-content:start;gap:10px;padding-right:4px}
.lp-doc{display:grid;grid-template-columns:minmax(0,1fr) 24px;gap:12px;align-items:center;padding:14px 16px;border:1px solid #edf1f7;border-radius:12px;cursor:pointer;background:#fff;transition:all .15s}
.lp-doc:hover{border-color:#c9dcff;background:#f7fbff;transform:translateY(-1px);box-shadow:0 8px 18px rgba(15,50,90,.07)}
.lp-doc-title{font-size:14px;font-weight:700;color:#1f2d3d;line-height:1.45}
.lp-doc-meta{display:flex;gap:10px;align-items:center;margin-top:7px;font-size:12px;color:var(--t2)}
.lp-doc-meta span:first-child{display:inline-flex;height:20px;align-items:center;border-radius:10px;background:#edf7f4;color:#187064;padding:0 8px;font-weight:600}
.lp-doc-go{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#94a3b8;background:#f4f7fb;font-size:20px;line-height:1}
.lp-empty{height:180px;display:flex;align-items:center;justify-content:center;color:var(--t2);border:1px dashed #d6dbe3;border-radius:12px;background:#fbfcff}

/* ==== TOAST ==== */
.toast{position:fixed;top:24px;left:50%;transform:translateX(-50%);z-index:999;padding:10px 28px;border-radius:20px;color:#fff;font-size:14px;pointer-events:none;box-shadow:0 4px 12px rgba(0,0,0,.15);animation:toastIn .3s}
.toast-s{background:var(--g)}.toast-e{background:var(--r)}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ==== DARK MODE ==== */
body.dark,.dark .sidebar,.dark .topbar,.dark .card,.dark .panel,.dark .stat-card,.dark table,.dark th,.dark td,.dark .modal-box,.dark .info-table,.dark .detail-header{background:#141414!important;color:#e0e0e0!important}
body.dark{--bg:#0a0a0a;--w:#141414;--t:#e0e0e0;--t2:#888;--b:#2a2a2a;--sdw:0 2px 8px rgba(0,0,0,.3)}
.dark .sidebar{background:#0a0a0a!important}.dark .topbar,.dark .card,.dark .panel,.dark .stat-card,.dark .modal-box,.dark .detail-header{background:#1a1a1a!important;border-color:#2a2a2a!important}
.dark input,.dark select,.dark textarea{background:#1a1a1a;color:#e0e0e0;border-color:#333}
.dark th{background:#1a1a1a}.dark .info-table .ilbl{background:#1a1a1a}
.dark .form-input:focus,.dark .form-select:focus,.dark .form-textarea:focus{box-shadow:0 0 0 2px rgba(22,119,255,.3)}
.dark .btn{background:#2a2a2a;border-color:#444;color:#ccc}
.dark .btn:hover{border-color:var(--p);color:var(--p)}
.dark .btn-p{background:var(--p);color:#fff}.dark .btn-o{background:transparent}
.dark .login-box,.dark .login-public{background:#1a1a1a}.dark .login-box h1{color:var(--p)}
.dark .topbar .bread{color:#e0e0e0}
.dark-mode-toggle{position:fixed;bottom:80px;right:20px;z-index:60;width:40px;height:40px;border-radius:50%;background:#333;color:#ffd700;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.dark .dark-mode-toggle{background:#555;color:#fff}
@media(min-width:768px){.dark-mode-toggle{bottom:30px;right:30px}}

/* ==== NOTIFICATION CENTER ==== */
.notif-panel{position:fixed;top:56px;right:10px;width:320px;max-height:400px;background:var(--w);border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,.15);z-index:300;overflow-y:auto;display:none}
.notif-panel.show{display:block}
.notif-item{padding:12px 16px;border-bottom:1px solid var(--b);cursor:pointer;font-size:13px}
.notif-item:hover{background:var(--bg)}
.notif-item .time{font-size:11px;color:var(--t2);margin-top:4px}
.notif-badge{position:absolute;top:2px;right:-6px;background:var(--r);color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center}

/* ==== ECHARTS CONTAINER ==== */
.chart-box{width:100%;height:300px;margin-top:10px}

/* ==== DASHBOARD BUILDER ==== */
.dash-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.dash-head h2{font-size:18px;line-height:1.2;margin-bottom:4px}
.dash-head p{font-size:13px;color:var(--t2)}
.dash-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.dash-year-select{height:38px;border:1px solid var(--line);border-radius:8px;background:var(--w);padding:0 12px;font-size:14px;color:var(--t)}
.dash-cols-label{height:38px;display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:8px;background:var(--w);padding:0 10px;font-size:13px;color:var(--t2);white-space:nowrap}
.dash-cols-select{height:30px;border:0;background:transparent;font-size:14px;color:var(--t);outline:0}
.dash-edit-tip{padding:10px 12px;border:1px solid #d6e4ff;background:#f6f9ff;color:#0958d9;border-radius:10px;font-size:13px;margin-bottom:12px}
.dash-grid{display:grid;grid-template-columns:repeat(var(--dash-columns,6),minmax(0,1fr));gap:16px;align-items:stretch}
.dash-widget{min-width:0}
.dash-stat{grid-column:span 1}
.dash-third{grid-column:span 2}
.dash-half{grid-column:span 3}
.dash-full{grid-column:1/-1}
.dash-widget>.panel,.dash-widget>.stat-card{height:100%;margin-bottom:0}
.dash-widget-tools{display:grid;grid-template-columns:auto minmax(12px,1fr) auto auto auto;gap:6px;align-items:center;background:#f8fafc;border:1px dashed #bdd7ff;border-radius:10px;padding:7px 8px;margin-bottom:8px}
.dash-widget-tools b{font-size:13px;color:#0958d9}
.dash-stat-card{min-height:98px}
.dash-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.dash-action-grid .card{text-align:center;padding:18px 10px;margin-bottom:0}
.dash-action-ico{font-size:26px;margin-bottom:4px}
.dash-overview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.dash-overview-item{height:78px;border:1px solid var(--b);border-radius:8px;background:#fff;padding:10px 12px;display:flex;align-items:flex-start;justify-content:space-between;flex-direction:column;cursor:pointer;color:var(--t);text-align:left}
.dash-overview-item:hover{border-color:var(--p);box-shadow:0 8px 22px rgba(22,119,255,.10)}
.dash-overview-item span{font-size:13px;color:var(--t2)}
.dash-overview-item b{font-size:26px;line-height:1;color:var(--t)}
.dash-catalog{min-height:520px}
.dash-catalog-group{margin-bottom:18px}
.dash-catalog-group h3{font-size:13px;color:var(--t2);font-weight:600;margin-bottom:8px}
.dash-catalog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.dash-catalog-card{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:10px;align-items:center;text-align:left;border:1px solid #e5edf8;background:#fff;border-radius:10px;padding:12px;cursor:pointer;transition:all .15s;color:var(--t)}
.dash-catalog-card:hover{border-color:var(--p);background:#f7fbff}
.dash-catalog-card.added{opacity:.62;cursor:default;background:#f8fafc}
.dash-catalog-icon{width:44px;height:44px;border-radius:12px;background:#f0f6ff;display:flex;align-items:center;justify-content:center;font-size:22px}
.dash-catalog-card b{display:block;font-size:14px;margin-bottom:3px}
.dash-catalog-card p{font-size:12px;color:var(--t2);line-height:1.45}
.dash-catalog-card span{font-size:12px;color:var(--p);white-space:nowrap}
.dash-branch-preview{display:grid;gap:8px}
.dash-branch-row{display:grid;grid-template-columns:minmax(0,1fr) 90px 90px;gap:10px;align-items:center;border:1px solid var(--b);border-radius:8px;padding:10px 12px;cursor:pointer}
.dash-branch-row:hover{background:#f7fbff;border-color:#c9dcff}
.dash-branch-row b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-branch-row span{font-size:12px;color:var(--t2)}
.dash-fallback-bars{display:flex;align-items:flex-end;gap:4px;height:260px;padding:0 10px}
.dash-fallback-bars div{cursor:pointer;flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.dash-fallback-bars span{font-size:11px;color:var(--t2)}
.dash-fallback-bars i{display:block;width:80%;min-height:4px;background:var(--p);border-radius:4px 4px 0 0}
.dash-fallback-bars b{font-size:10px;color:var(--t2);font-weight:400}
.dash-fallback-pie{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap;min-height:260px}
.dash-fallback-pie>div{width:142px;height:142px;border-radius:50%;flex-shrink:0}
.dash-fallback-pie section{font-size:12px}
.dash-fallback-pie p{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.dash-fallback-pie i{width:10px;height:10px;border-radius:50%;display:inline-block}
.dash-mini-table{font-size:12px}
.dash-mini-table th,.dash-mini-table td{padding:8px 10px}
.dash-rank-list,.dash-log-list{display:grid;gap:8px}
.dash-rank-row{display:grid;grid-template-columns:28px minmax(70px,1fr) minmax(0,2fr) 54px;gap:8px;align-items:center;border:1px solid var(--b);border-radius:8px;padding:9px 10px;cursor:pointer}
.dash-rank-row:hover{background:#f7fbff;border-color:#c9dcff}
.dash-rank-row span{width:24px;height:24px;border-radius:12px;background:#edf4ff;color:var(--p);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.dash-rank-row b{font-size:13px}
.dash-rank-row em{font-style:normal;color:var(--t2);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-rank-row strong{text-align:right;color:var(--p);font-size:13px}
.dash-log-list>div{border:1px solid var(--b);border-radius:8px;padding:9px 10px;background:#fff}
.dash-log-list b{display:block;font-size:13px;margin-bottom:2px}
.dash-log-list span{display:block;color:var(--t2);font-size:12px}
.dash-log-list p{color:var(--t2);font-size:12px;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* JS-generated compact classes */
.wf{display:flex;justify-content:space-between;padding:20px 40px;background:var(--w);border-radius:12px;margin-bottom:20px;box-shadow:var(--sdw)}
.ws{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}
.ws::after{content:'';position:absolute;top:20px;left:50%;width:100%;height:3px;background:#e8e8e8;z-index:0}
.ws:last-child::after{display:none}
.wd{width:40px;height:40px;border-radius:50%;background:#e8e8e8;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;font-size:16px;color:#999;transition:all .3s}
.ws.done .wd{background:var(--g);color:#fff}.ws.on .wd{background:var(--p);color:#fff}
.ws.done::after{background:var(--g)}.ws.on::after{background:var(--p)}
.wl{font-size:13px;color:var(--t2);margin-top:8px}
.ws.on .wl,.ws.done .wl{color:var(--t);font-weight:500}
.dh{background:linear-gradient(135deg,var(--p),#0958d9);color:#fff;padding:24px;border-radius:12px;margin-bottom:20px}
.did{font-size:12px;opacity:.7;margin-bottom:6px}
.dnm{font-size:22px;font-weight:700;margin-bottom:10px}
.dtags{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.dtags .pass-badge{background:rgba(82,196,26,.3);border:1px solid rgba(82,196,26,.5);padding:4px 16px;border-radius:20px;font-size:13px}
.tbar{display:flex;border-bottom:2px solid var(--b);margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tbar::-webkit-scrollbar{display:none}
.ti{padding:10px;cursor:pointer;color:var(--t2);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;font-size:13px;white-space:nowrap}
.ti:hover{color:var(--p)}
.ti.on{color:var(--p);border-bottom-color:var(--p);font-weight:500}
.fli{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--b);background:var(--w);border-radius:8px;margin-bottom:4px}
.fli .ic{font-size:24px;flex-shrink:0;width:40px;text-align:center}
.file-thumb{width:40px;height:40px;border:1px solid var(--b);border-radius:7px;object-fit:cover;flex-shrink:0;background:#f5f8fc}
.fli .if{flex:1;min-width:0}
.fli .if .n{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fli .if .s{font-size:11px;color:var(--t2);margin-top:2px}
.file-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--b);background:#fff}
.file-item .ic{font-size:24px;flex-shrink:0;width:40px;text-align:center}
.file-item .if{flex:1;min-width:0}
.file-item .if b{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upload{margin-bottom:14px}
.file-group{border:1px solid var(--b);border-radius:10px;overflow:hidden;margin-top:10px;background:#fff}
.file-group-title{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#f6f9ff;font-size:13px;font-weight:700;color:var(--t)}
.file-group-title span{font-size:12px;font-weight:500;color:var(--t2)}
.file-group-actions{display:flex;align-items:center;gap:8px}
.file-upload-status{font-size:12px;color:var(--t2);padding:0 14px;background:#fff}
.file-empty{padding:12px 14px;color:var(--t2);font-size:13px;background:#fff}
.file-status-box{display:flex;align-items:center;gap:10px;justify-content:space-between;padding:10px 14px;border-radius:10px;margin-bottom:10px;font-size:13px}
.file-status-box.ok{background:#f6ffed;border:1px solid #b7eb8f;color:#389e0d}
.file-status-box.bad{background:#fff2f0;border:1px solid #ffccc7;color:#cf1322}
.file-status-box span{color:inherit;opacity:.85}
.issue-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.issue-help{font-size:12px;color:var(--t2);margin-top:2px}
.issue-pair{border:1px solid var(--b);border-radius:10px;background:#fff;margin-top:8px;overflow:hidden}
.issue-pair-head{display:flex;align-items:center;gap:10px;justify-content:space-between;padding:8px 14px;background:#f6f9ff;border-bottom:1px solid var(--b)}
.issue-pair-head>div{display:flex;align-items:center;gap:12px}
.issue-pair-head span{font-size:12px;color:var(--t2)}
.issue-head-actions{display:flex;align-items:center;gap:8px}
.issue-del-btn{height:26px;padding:0 9px;font-size:12px}
.issue-meta-grid{display:grid;grid-template-columns:136px 128px 150px 128px 190px minmax(140px,1fr) 96px;gap:6px 8px;align-items:end;padding:8px 14px;border-bottom:1px solid var(--b);background:#fbfdff}
.issue-meta-grid label{font-size:12px;color:var(--t2);display:grid;gap:3px}
.issue-meta-grid .fi{height:31px;font-size:12px;padding:0 9px;border-radius:7px}
.issue-meta-grid .issue-remarks{grid-column:auto}
.issue-pair-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0}
.issue-cell{padding:8px 14px 10px;min-width:0}
.issue-cell+.issue-cell{border-left:1px solid var(--b)}
.issue-cell-title{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:700;font-size:13px;margin-bottom:6px}
.issue-cell-title span{font-weight:500;color:var(--t2);font-size:12px}
.issue-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end}
.issue-upload-status{font-size:12px;color:var(--t2)}
.issue-cell .fli{padding:7px 8px;gap:8px;margin-bottom:3px;border-radius:7px}
.issue-cell .fli .ic{width:30px;font-size:20px}
.issue-cell .fli .if .n{font-size:13px}
.issue-cell .fli .btn-s{height:28px;padding:0 10px}
.issue-cell .file-empty{padding:8px 0;font-size:12px}
.todo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.todo-card{display:flex;justify-content:space-between;align-items:center;gap:12px;border:1px solid var(--b);border-radius:10px;padding:12px 14px;background:#fff;cursor:pointer;transition:all .16s}
.todo-card:hover{border-color:#c9dcff;background:#f7fbff}
.todo-card b{display:block;font-size:14px;margin-bottom:3px}
.todo-card span{display:block;font-size:12px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}
.todo-card strong{min-width:42px;height:42px;border-radius:21px;display:flex;align-items:center;justify-content:center;font-size:20px;background:#f6ffed;color:#389e0d}
.todo-card strong.r{background:#fff2f0;color:#cf1322}
.todo-card strong.g{background:#f6ffed;color:#389e0d}
.backup-status-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:12px}
.backup-status-card{border:1px solid var(--b);border-radius:10px;background:#fbfdff;padding:12px}
.backup-status-card span{display:block;font-size:12px;color:var(--t2);margin-bottom:6px}
.backup-status-card b{font-size:16px;color:var(--t)}
.backup-status-card b.ok{color:#389e0d}.backup-status-card b.bad{color:#cf1322}
.prebox{max-height:220px;overflow:auto;background:#0f172a;color:#e5e7eb;border-radius:6px;padding:10px;font-size:12px;line-height:1.5;white-space:pre-wrap}
@media(max-width:1100px){.issue-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.issue-meta-grid .issue-remarks{grid-column:span 2}.todo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.backup-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.issue-pair-grid{grid-template-columns:1fr}.issue-cell+.issue-cell{border-left:0;border-top:1px solid var(--b)}}
.tg{display:inline-flex;padding:2px 10px;border-radius:10px;font-size:12px;font-weight:500}
.tg-g{background:#f6ffed;color:#389e0d}.tg-b{background:#e6f4ff;color:#0958d9}
.tg-o{background:#fff7e6;color:#d48806}.tg-r{background:#fff2f0;color:#cf1322}
.material-cell{cursor:pointer}
.material-cell:hover .tg{box-shadow:0 0 0 1px rgba(22,119,255,.24);filter:brightness(.97)}
.cr{display:flex;align-items:center;gap:12px}
.cb{justify-content:space-between}
.tt{font-weight:600;font-size:15px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mt{font-size:12px;color:var(--t2);display:flex;gap:12px;flex-wrap:wrap}
.rs{text-align:center;padding:20px;margin-top:10px;background:#f6ffed;border:2px solid var(--g);border-radius:10px}
.rs .rt{font-size:16px;font-weight:600;color:var(--g);margin-bottom:8px}
.rs .rb{font-size:14px;line-height:1.6;color:#389e0d}
.rs.rs-pending{background:#fff7e6;border-color:var(--o)}
.rs.rs-pending .rt{color:#d48806}
.rs.rs-pending .rb{color:#8c6d1f}
.qr-modal-content{display:grid;gap:14px;text-align:center}
.qr-preview{min-height:220px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border:1px solid var(--b);border-radius:12px}
.qr-preview img{width:220px;height:220px;object-fit:contain}
.qr-copy-row{display:flex;gap:8px;align-items:center}
.qr-copy-row .fi{height:38px;font-size:13px}
.qr-actions{display:flex;justify-content:center}
.qr-tip{font-size:12px;color:var(--t2)}
.emp{text-align:center;padding:40px;color:var(--t2)}
.emp .eico{font-size:48px;margin-bottom:12px}
.spin{text-align:center;padding:40px}
.spin::after{content:'';display:inline-block;width:32px;height:32px;border:3px solid var(--b);border-top-color:var(--p);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.pg{display:flex;gap:6px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.pg button{min-width:36px;height:36px;border:1px solid var(--b);border-radius:6px;background:var(--w);cursor:pointer;font-size:13px;color:var(--t)}
.pg button.on{background:var(--p);color:#fff;border-color:var(--p)}
.pg button:disabled{opacity:.3;cursor:not-allowed}

.ledger-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#f6f9ff;border:1px solid #d6e4ff;border-radius:8px;padding:10px 12px;margin-bottom:12px}
.ledger-summary b{font-size:15px}
.ledger-summary span{font-size:12px;color:var(--t2);background:var(--w);border-radius:12px;padding:2px 8px}
.dash-total-row td{background:#f6f9ff;font-weight:700;border-top:1px solid #d6e4ff}
.dash-sort-label{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:13px;color:var(--t2)}
.dash-sort-select{height:32px;min-width:128px;border:1px solid #d6dbe3;border-radius:8px;background:var(--w);padding:0 9px;color:var(--t);font-size:13px}
.ledger-panel,.project-ledger-panel{padding:14px 12px 10px}
.ledger-title,.project-ledger-title{margin-bottom:8px}
.ledger-title .btn-g,.project-ledger-title .btn-g{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.ledger-filterbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.ledger-filterbar select,.ledger-filterbar input[type=month],.ledger-filterbar input[type=date],.ledger-filterbar>input[type=text],.ledger-filterbar>input:not([type]){height:36px;border:1px solid #d6dbe3;border-radius:8px;background:var(--w);padding:0 9px;color:var(--t);font-size:13px}
.ledger-search{position:relative;flex:0 1 420px;min-width:260px}
.ledger-search input{width:100%;height:36px;border:1px solid #d6dbe3;border-radius:18px;padding:0 38px 0 14px;background:var(--w);font-size:13px;color:var(--t)}
.ledger-search span{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--t2);font-size:16px}
.ledger-count{font-size:12px;color:var(--t2);margin:6px 0 8px}
.ledger-count b{color:var(--p);font-weight:600}
.expert-filterbar .ledger-search{flex-basis:300px}
.expert-filterbar select{width:132px}
.expert-filterbar .expert-company-select{width:190px}
.expert-table table{table-layout:fixed;min-width:1500px}
.expert-table th,.expert-table td{white-space:normal;vertical-align:middle}
.expert-table th:nth-child(1),.expert-table td:nth-child(1){width:92px;text-align:center}
.expert-table th:nth-child(2),.expert-table td:nth-child(2){width:128px}
.expert-table th:nth-child(3),.expert-table td:nth-child(3){width:190px}
.expert-table th:nth-child(4),.expert-table td:nth-child(4){width:150px}
.expert-table th:nth-child(5),.expert-table td:nth-child(5){width:150px}
.expert-table th:nth-child(6),.expert-table td:nth-child(6){width:220px}
.expert-table th:nth-child(7),.expert-table td:nth-child(7){width:210px}
.expert-table th:nth-child(8),.expert-table td:nth-child(8){width:170px}
.expert-table th:nth-child(9),.expert-table td:nth-child(9){width:86px}
.expert-table th:nth-child(10),.expert-table td:nth-child(10){width:92px}
.expert-table td:nth-child(8){line-height:1.55}
.expert-table td:nth-child(8)>div{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.expert-table td.row-action-cell{overflow:visible;text-overflow:clip}
.expert-table td:nth-child(10) .btn,.expert-table .actions .btn{height:30px;padding:0 12px}
.expert-name-link{border:0;background:transparent;color:var(--p);font-weight:700;text-align:left;padding:0;cursor:pointer;line-height:1.45;max-width:100%;display:inline-block}
.expert-name-link:hover{text-decoration:underline}
.expert-major-box{display:flex;flex-wrap:wrap;gap:8px;padding:8px 0}
.expert-major-option{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 10px;border:1px solid var(--b);border-radius:8px;background:#f7faff;font-size:13px;color:var(--t);cursor:pointer}
.expert-major-option input{margin:0}
.expert-photo-thumb,.expert-photo-empty{width:58px;height:70px;border-radius:8px;margin:0 auto;display:flex;align-items:center;justify-content:center;object-fit:cover;border:1px solid var(--b);background:#f5f8fc;color:var(--p);font-weight:700}
.expert-photo-large{width:156px;height:204px;border-radius:8px;object-fit:cover;border:1px solid var(--b);background:#f5f8fc}
.expert-profile{display:grid;grid-template-columns:190px minmax(0,1fr);gap:18px;align-items:start}
.expert-profile-side{display:grid;gap:12px;align-content:start}
.expert-profile-main{min-width:0}
.expert-file-card{border:1px solid var(--b);border-radius:8px;background:#fff;padding:10px;display:grid;gap:8px}
.expert-file-title{font-size:13px;font-weight:700;color:var(--t)}
.expert-file-body{font-size:13px;color:var(--t)}
.expert-application-list{display:grid;gap:8px}
.expert-application-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px;border:1px solid var(--b);border-radius:8px;background:#fafcff}
.expert-application-row>div:first-child{min-width:0}
.expert-application-row b{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.expert-application-row .btn-g{display:flex;gap:4px;flex-wrap:nowrap}
.workload-filterbar .ledger-search{flex-basis:320px}
.workload-filterbar input[type=number]{width:96px;height:36px;border:1px solid #d6dbe3;border-radius:8px;background:var(--w);padding:0 9px;color:var(--t);font-size:13px}
.workload-filterbar select{width:150px}
.review-filterbar .ledger-search{flex-basis:360px}
.review-filterbar select{width:150px}
.review-filterbar input[type=month]{width:138px}
.archive-filterbar .ledger-search{flex-basis:360px}
.archive-filterbar select{width:142px}
.archive-filterbar input[type=month]{width:138px}
.project-tabs{display:flex;gap:7px;flex-wrap:wrap;overflow:visible;padding:4px 0 10px;border-bottom:1px solid var(--b);margin-bottom:10px;scrollbar-width:none}
.project-tabs::-webkit-scrollbar{display:none}
.project-tab{height:34px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;border:1px solid #d6dbe3;background:var(--w);border-radius:8px;padding:0 13px;cursor:pointer;font-size:13px;font-weight:600;color:var(--t);transition:all .18s}
.project-tab:hover{border-color:var(--p);color:var(--p)}
.project-tab.on{background:var(--p);border-color:var(--p);color:#fff}
.project-tab span{min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;background:#f4f7fb;color:var(--t2);font-size:11px;font-weight:500;padding:0 6px}
.project-tab.on span{background:rgba(255,255,255,.22);color:#fff}
.project-filterbar{display:grid;grid-template-columns:minmax(260px,420px) 138px 150px 150px 150px;gap:8px;align-items:center;margin-bottom:8px}
.project-filterbar select{height:36px;border:1px solid #d6dbe3;border-radius:8px;background:var(--w);padding:0 9px;color:var(--t);font-size:13px}
.project-search{position:relative}
.project-search input{width:100%;height:36px;border:1px solid #d6dbe3;border-radius:18px;padding:0 38px 0 14px;background:var(--w);font-size:13px;color:var(--t)}
.project-search span{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--t2);font-size:16px}
.project-count{font-size:12px;color:var(--t2);margin:6px 0 8px}
.project-count b{color:var(--p);font-weight:600}
.project-ledger-table{overflow-x:auto}
.project-ledger-table table{table-layout:fixed;font-size:13px;min-width:1380px}
.project-ledger-table th,.project-ledger-table td{white-space:nowrap;padding:9px 9px;overflow:hidden;text-overflow:ellipsis}
.project-ledger-table th:nth-child(1),.project-ledger-table td:nth-child(1){width:86px}
.project-ledger-table th:nth-child(2),.project-ledger-table td:nth-child(2){width:320px;min-width:0;white-space:normal}
.project-ledger-table th:nth-child(3),.project-ledger-table td:nth-child(3){width:104px}
.project-ledger-table th:nth-child(4),.project-ledger-table td:nth-child(4){width:78px}
.project-ledger-table th:nth-child(5),.project-ledger-table td:nth-child(5){width:170px}
.project-ledger-table th:nth-child(6),.project-ledger-table td:nth-child(6){width:104px}
.project-ledger-table th:nth-child(7),.project-ledger-table td:nth-child(7){width:112px}
.project-ledger-table th:nth-child(8),.project-ledger-table td:nth-child(8){width:96px}
.project-ledger-table th:nth-child(9),.project-ledger-table td:nth-child(9){width:230px}
.project-ledger-table td.row-action-cell{overflow:visible;text-overflow:clip}
.project-ledger-table .btn-g{display:flex;gap:4px;flex-wrap:nowrap;align-items:center}
.project-ledger-table .btn{height:28px;padding:0 9px;font-size:12px;border-radius:7px}
.row-menu{position:relative;display:inline-flex}
.row-menu-panel{display:none;position:absolute;right:0;top:32px;z-index:120;min-width:148px;background:#fff;border:1px solid var(--b);border-radius:8px;box-shadow:0 12px 28px rgba(0,0,0,.14);padding:5px}
.row-menu-panel.show{display:grid;gap:3px}
.row-menu-panel button{width:100%;height:30px;border:0;background:#fff;border-radius:6px;text-align:left;padding:0 10px;cursor:pointer;color:var(--t);font-size:13px}
.row-menu-panel button:hover{background:#f3f7ff;color:var(--p)}
.row-menu-panel button.danger{color:var(--r)}
.list-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:8px 0}
.list-toolbar select{height:32px;border:1px solid #d6dbe3;border-radius:8px;background:#fff;padding:0 8px;font-size:13px;color:var(--t)}
.column-setting-tip{font-size:12px;color:var(--t2);margin-bottom:10px}
.column-setting-list{display:grid;gap:7px;max-height:58vh;overflow:auto}
.column-setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--b);border-radius:8px;padding:8px 10px;background:#fff}
.column-setting-row label{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--t)}
.column-setting-row .btn-g{display:flex;gap:6px}
.project-name-link{border:0;background:transparent;color:var(--p);font-weight:700;text-align:left;padding:0;cursor:pointer;line-height:1.45;max-width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.project-name-link:hover{text-decoration:underline}
.td-sub{font-size:11px;color:var(--t2);margin-top:2px}
.branch-order-tip{font-size:13px;color:var(--t2);margin-bottom:12px;line-height:1.6}
.branch-order-list{display:grid;gap:8px}
.branch-order-row{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid #e8eef7;background:#fbfdff;border-radius:8px;padding:9px 10px}
.branch-order-index{width:30px;height:30px;border-radius:15px;background:#edf4ff;color:var(--p);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.branch-order-name{min-width:0}
.branch-order-name b{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.branch-order-name span{font-size:12px;color:var(--t2)}
.branch-order-actions{display:flex;gap:6px;align-items:center}
.branch-box{border:1px solid var(--b);border-radius:10px;margin-bottom:12px;overflow:hidden;background:var(--w)}
.branch-head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;background:#f6f9ff;border-bottom:1px solid var(--b)}
.branch-head span{font-size:12px;color:var(--t2);font-weight:400}
.project-node{padding:12px 14px;border-bottom:1px solid var(--b)}
.project-node:last-child{border-bottom:none}
.project-line{display:flex;justify-content:space-between;align-items:center;gap:12px}
.review-list{margin-top:10px;border-left:3px solid #d6e4ff;padding-left:10px;display:grid;gap:6px}
.review-node{display:grid;grid-template-columns:150px 1fr 110px 90px;gap:8px;align-items:center;padding:8px 10px;border-radius:8px;background:#fafafa;font-size:12px;cursor:pointer}
.review-node:hover{background:#f0f5ff}

/* ==== ORGANIZATION / PERMISSION PAGE ==== */
.org-page{display:grid;grid-template-columns:var(--org-tree-width,320px) 6px minmax(0,1fr);gap:8px;height:calc(100vh - 88px);min-height:520px}
.org-tree-panel,.org-detail-panel{background:var(--w);border-radius:8px;box-shadow:var(--sdw);border:1px solid var(--b);min-width:0}
.org-tree-panel{padding:12px;display:flex;flex-direction:column;gap:10px;overflow:hidden}
.org-resizer{width:6px;border-radius:6px;cursor:col-resize;background:transparent;position:relative}
.org-resizer::after{content:'';position:absolute;top:12px;bottom:12px;left:2px;width:2px;border-radius:2px;background:#d9e2ef;transition:background .15s}
.org-resizer:hover::after,.org-resizing .org-resizer::after{background:var(--p)}
body.org-resizing{cursor:col-resize;user-select:none}
.org-tree-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.org-search{height:34px;border:1px solid #d9e2ef;border-radius:4px;background:#fff;display:flex;align-items:center;gap:6px;padding:0 8px}
.org-search input{border:0;outline:0;min-width:0;flex:1;font-size:13px;background:transparent}
.org-search span{color:#9aa6b2;font-size:13px}
.org-tree{flex:1;overflow:auto;min-height:0;padding-right:4px;overscroll-behavior:contain}
.org-tree::-webkit-scrollbar,.org-detail-panel::-webkit-scrollbar{width:10px;height:10px}
.org-tree::-webkit-scrollbar-thumb,.org-detail-panel::-webkit-scrollbar-thumb{background:#cfd8e6;border:3px solid #fff;border-radius:10px}
.org-tree::-webkit-scrollbar-track,.org-detail-panel::-webkit-scrollbar-track{background:#f5f7fb;border-radius:10px}
.org-tree-node{height:32px;display:grid;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:4px;padding-left:calc(var(--level)*16px + 6px);border-radius:4px;cursor:pointer;color:#263445;font-size:13px}
.org-tree-node:hover{background:#f2f7ff}
.org-tree-node.active{background:#e6f4ff;color:var(--p);font-weight:600}
.org-tree-icon{color:#5f6f83;font-size:13px;text-align:center}
.org-tree-toggle{width:20px;height:20px;border:0;background:transparent;color:#5f6f83;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1}
.org-tree-toggle:hover{background:#dbeafe;color:var(--p)}
.org-tree-spacer{color:#5f6f83;font-size:13px;text-align:center}
.org-tree-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.org-tree-count{min-width:18px;height:18px;padding:0 6px;border-radius:9px;background:#eef3fa;color:#6b7786;font-size:12px;display:flex;align-items:center;justify-content:center}
.org-tree-note{font-size:12px;color:var(--t2);line-height:1.6;padding:8px 6px}
.org-detail-panel{padding:18px;overflow:auto;min-height:0;overscroll-behavior:contain}
.org-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:1px solid var(--b);padding-bottom:14px}
.org-detail-head h3{font-size:18px;margin:0 0 10px}
.org-meta{display:flex;gap:18px;flex-wrap:wrap;color:#223047;font-size:13px}
.org-tabs{display:flex;gap:0;margin-top:14px;border-bottom:1px solid var(--b)}
.org-tabs button{height:34px;min-width:86px;padding:0 18px;border:1px solid var(--b);border-bottom:0;background:#fff;cursor:pointer;color:#243246}
.org-tabs button+button{border-left:0}
.org-tabs button.on{color:var(--p);background:#f8fbff;font-weight:600}
.org-toolbar{display:flex;align-items:center;gap:10px;margin:14px 0}
.org-toolbar .slim{width:min(460px,100%)}
.org-check{font-size:13px;color:#475569;display:flex;align-items:center;gap:5px}
.org-info-card{padding:18px 8px}
.org-info-title{font-weight:700;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.org-info-card .info-table{width:min(720px,100%)}
.org-info-card .info-table th{width:150px}

@media(max-width:980px){
  .org-page{grid-template-columns:1fr}
  .org-resizer{display:none}
  .org-tree-panel{max-height:380px}
  .org-detail-head{flex-direction:column}
}

/* ==== PRINT STYLES ==== */

@media(max-width:768px){
  .mobile-header{display:flex!important;align-items:center;justify-content:space-between}
  .mobile-tabs{display:flex!important}
  .sidebar,.topbar{display:none!important}
  .main-area{margin-left:0!important}
  .page-content{padding:12px;padding-bottom:80px}
  .stats-grid{grid-template-columns:1fr 1fr!important;gap:8px}
  .dash-head{display:grid;gap:10px}
  .dash-actions{justify-content:flex-start}
  .dash-grid{grid-template-columns:1fr 1fr;gap:10px}
  .dash-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dash-half,.dash-third,.dash-full{grid-column:1/-1!important}
  .dash-catalog-grid{grid-template-columns:1fr}
  .dash-widget-tools{grid-template-columns:1fr auto auto auto}
  .dash-widget-tools span{display:none}
  .todo-grid{grid-template-columns:1fr}
  .backup-status-grid{grid-template-columns:1fr}
  .issue-meta-grid{grid-template-columns:1fr}
  .issue-meta-grid .issue-remarks{grid-column:auto}
  .expert-profile{grid-template-columns:1fr}
  .expert-profile-side{justify-items:start}
  .dash-branch-row{grid-template-columns:1fr}
  .stat-card{padding:12px}
  .stat-icon{width:36px;height:36px;font-size:18px}
  .stat-num{font-size:18px}
  .grid-2{grid-template-columns:1fr}
  .workflow{padding:12px 4px}
  .tab-item{font-size:12px;padding:8px 6px}
  .table-wrap table{font-size:12px}
  .project-filterbar{grid-template-columns:1fr}
  .project-tab{height:34px;padding:0 12px;font-size:13px}
  .project-ledger-table td:nth-child(2){min-width:220px}
  .modal-box{max-width:100%!important;border-radius:16px 16px 0 0!important;position:fixed!important;bottom:0}
  .profile-card{min-width:0;width:100%}
  .profile-actions{flex-direction:column}
  .profile-actions .btn{width:100%}
  .modal-form .modal-body{grid-template-columns:1fr}
  .modal-form .modal-body>.fg:has(.ft){grid-column:auto}
  .search-box,.ledger-filterbar{flex-direction:column;align-items:stretch}
  .search-box input,.search-box select,.ledger-search,.ledger-filterbar select,.ledger-filterbar input[type=month],.ledger-filterbar input[type=date],.ledger-filterbar>input[type=text],.ledger-filterbar>input:not([type]){width:100%;min-width:0}
  .form-row{grid-template-columns:1fr}
  .project-participant-grid,.project-participant-fields{grid-template-columns:1fr}
  .project-line{align-items:flex-start;flex-direction:column}
  .review-node{grid-template-columns:1fr;gap:4px}
  .qr-copy-row{display:grid;grid-template-columns:1fr}
  .qr-copy-row .btn{width:100%}
  .login-page{align-items:flex-start;padding:16px}
  .login-shell{grid-template-columns:1fr;gap:14px}
  .login-box{grid-column:auto;grid-row:auto;order:1;width:100%;min-height:auto;padding:30px 22px;border-radius:16px}
  .login-logo{width:78px;height:78px;margin-bottom:16px}
  .login-box h1{font-size:22px}
  .login-form{margin-top:26px}
  .login-public{grid-column:auto;grid-row:auto;order:2;min-height:auto;max-height:none;padding:20px 16px;border-radius:16px}
  .lp-head h2{font-size:18px}
  .lp-tabs{gap:6px}
  .lp-tabs button{font-size:12px;padding:0 10px}
  .lp-list{max-height:none;overflow:visible}
  .lp-doc{grid-template-columns:minmax(0,1fr) 22px;padding:12px 13px}
}
.import-error-box{max-height:56vh;overflow:auto}
.import-error-box ol{margin:10px 0 0 20px;padding:0}
.import-error-box li{margin:6px 0;line-height:1.5;color:#b42318}
@media print{
  .sidebar,.topbar,.mobile-tabs,.mobile-header,.fab,.dark-mode-toggle,.btn-fab,.tab-bar,.notif-panel{display:none!important}
  .main-area{margin-left:0!important}.page-content{padding:0!important}
  body{background:#fff!important;color:#000!important}
}
.tab-bar::-webkit-scrollbar{display:none}
