:root { --ink:#172033; --muted:#718096; --line:#e7ebf1; --blue:#246bfd; --blue2:#eaf1ff; --green:#159a65; --red:#dc4c4c; --bg:#f5f7fb; }
* { box-sizing:border-box; }
body { margin:0; font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif; color:var(--ink); background:var(--bg); }
button,input,select,textarea { font:inherit; }
button { cursor:pointer; }
.hidden { display:none !important; }
.muted { color:var(--muted); margin:5px 0; }
.login-page { min-height:100vh; display:grid; place-items:center; padding:24px; background:linear-gradient(145deg,#eef4ff,#f8faff 60%,#edf9f5); }
.login-card { width:min(420px,100%); background:#fff; border:1px solid #edf0f5; border-radius:22px; padding:38px; box-shadow:0 20px 50px rgba(30,52,93,.1); }
.brand-mark,.brand span { display:grid; place-items:center; width:46px; height:46px; border-radius:14px; background:var(--blue); color:#fff; font-weight:800; font-size:22px; }
h1 { margin:18px 0 4px; font-size:25px; } h2 { margin:0; font-size:22px; } h3 { margin:0 0 16px; }
label { display:grid; gap:7px; font-size:14px; color:#39445a; }
input,select,textarea { width:100%; border:1px solid #dce2eb; border-radius:10px; padding:11px 12px; background:#fff; outline:none; }
input:focus,select:focus,textarea:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(36,107,253,.1); }
textarea { min-height:100px; resize:vertical; }
form { display:grid; gap:16px; margin-top:25px; }
button { border:0; border-radius:9px; padding:10px 15px; background:#eef1f5; color:var(--ink); }
button:disabled { cursor:not-allowed; opacity:.5; }
button.primary { background:var(--blue); color:white; } button.danger { background:#fff0f0; color:var(--red); } button.success { background:#e8f7f1; color:var(--green); }
.wide { width:100%; padding:12px; }.demo-accounts { margin-top:18px; padding:12px; font-size:12px; line-height:1.7; color:var(--muted); background:var(--bg); border-radius:10px; }
.remember-me { display:flex; align-items:center; gap:8px; }.remember-me input { width:auto; }
.app { min-height:100vh; display:grid; grid-template-columns:230px 1fr; }
aside { background:#fff; border-right:1px solid var(--line); padding:24px 16px; display:flex; flex-direction:column; position:fixed; inset:0 auto 0 0; width:230px; z-index:5; }
.brand { display:flex; align-items:center; gap:11px; font-size:18px; padding:0 8px 25px; }
.brand span { width:36px; height:36px; border-radius:11px; font-size:18px; }
nav { display:grid; gap:5px; } nav button { text-align:left; color:#667085; background:transparent; padding:12px 13px; } nav button.active,nav button:hover { color:var(--blue); background:var(--blue2); }
.logout { margin-top:auto; color:#7b8495; background:transparent; text-align:left; }
main { grid-column:2; min-width:0; } header { height:86px; background:#fff; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; padding:0 30px; position:sticky; top:0; z-index:4; }
.role-badge,.status { padding:5px 10px; border-radius:999px; font-size:12px; background:var(--blue2); color:var(--blue); white-space:nowrap; }
.status.pass { background:#e8f7f1; color:var(--green); }.status.reject { background:#fff0f0; color:var(--red); }.status.wait { background:#fff6e5; color:#a66a00; }
.legacy-role { color:#a66a00; font-weight:600; }
.legacy-warning { margin:0; padding:11px 12px; border-radius:9px; background:#fff6e5; color:#8a5900; font-size:13px; line-height:1.5; }
.self-account-note { align-self:center; color:var(--muted); font-size:12px; padding:0 5px; }
.password-card { max-width:520px; }
#content { padding:26px 30px 45px; max-width:1500px; margin:auto; }
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:20px; }
.stat,.card { background:#fff; border:1px solid var(--line); border-radius:14px; padding:20px; box-shadow:0 3px 12px rgba(35,54,86,.025); }
.stat strong { font-size:28px; display:block; margin-top:8px; }.stat span { color:var(--muted); font-size:13px; }
.card + .card { margin-top:18px; }.card-head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:16px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }.form-grid .full { grid-column:1/-1; }
.currency-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.currency-card { display:grid; gap:13px; padding:16px; background:var(--bg); border:1px solid var(--line); border-radius:11px; }
.currency-card > strong { font-size:14px; color:var(--blue); }
.hint { font-size:12px; color:var(--muted); overflow-wrap:anywhere; }
.route-hint { font-size:12px; color:var(--blue); background:var(--blue2); border-radius:7px; padding:7px 9px; }
.route-hint.blocked { color:var(--red); background:#fff0f0; }
.form-section { display:flex; align-items:center; gap:9px; padding:17px 0 2px; border-top:1px solid var(--line); margin-top:4px; }
.form-section span { font-size:12px; color:var(--muted); }
.table-wrap { overflow:auto; border:1px solid var(--line); border-radius:10px; }
table { width:100%; border-collapse:collapse; font-size:13px; background:#fff; } th,td { padding:12px 13px; border-bottom:1px solid var(--line); text-align:left; white-space:nowrap; } th { color:#697386; background:#fafbfc; font-weight:600; } tr:last-child td { border:0; }
.actions { display:flex; gap:7px; }.actions button { padding:7px 10px; font-size:12px; }
.filters { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; margin-bottom:14px; }.filters button { align-self:end; }
.finance-filters { grid-template-columns:repeat(7,1fr); }
.checkbox-label { display:flex; align-items:center; gap:8px; align-self:end; min-height:40px; }.checkbox-label input { width:auto; }
.empty { color:var(--muted); padding:35px; text-align:center; }
.detail { white-space:normal; max-width:280px; line-height:1.5; }.money { font-weight:700; }
.urgency { display:inline-block; margin-top:5px; padding:3px 7px; border-radius:999px; background:#f0f2f5; color:#667085; font-size:11px; }
.urgency.urgent { background:#fff6e5; color:#a66a00; }.urgency.very { background:#fff0f0; color:var(--red); }
#toast { position:fixed; top:20px; left:50%; transform:translateX(-50%); z-index:20; background:#172033; color:white; padding:11px 18px; border-radius:10px; opacity:0; pointer-events:none; transition:.2s; }
#toast.show { opacity:1; }.menu-btn { display:none; font-size:20px; padding:5px; background:transparent; }
.modal-backdrop { position:fixed; inset:0; background:rgba(18,28,45,.45); display:grid; place-items:center; padding:20px; z-index:10; overflow:auto; }.modal { width:min(480px,100%); background:#fff; border-radius:16px; padding:22px; }
.confirm-modal { width:min(620px,100%); }.confirm-grid { display:grid; grid-template-columns:auto 1fr auto 1fr; gap:13px 18px; padding:18px; margin:18px 0; background:var(--bg); border-radius:11px; }
.confirm-grid span { color:var(--muted); font-size:13px; }.confirm-grid strong { font-size:14px; overflow-wrap:anywhere; }.confirm-grid .confirm-full { grid-column:2/-1; }.confirm-money { color:var(--blue); }.modal-actions { justify-content:flex-end; }
@media(max-width:1000px){ .stats{grid-template-columns:repeat(2,1fr)} .filters{grid-template-columns:repeat(3,1fr)} }
@media(max-width:760px){
  .app{display:block}.app aside{transform:translateX(-100%);transition:.2s;box-shadow:10px 0 30px rgba(0,0,0,.1)}.app.menu-open aside{transform:translateX(0)}
  main{display:block}header{height:74px;padding:0 16px;justify-content:flex-start;gap:12px}.menu-btn{display:block}.role-badge{margin-left:auto}h2{font-size:18px}#welcome{font-size:11px}
  #content{padding:16px}.stats{grid-template-columns:1fr 1fr;gap:10px}.stat,.card{padding:15px}.stat strong{font-size:22px}
  .form-grid,.filters,.currency-grid{grid-template-columns:1fr}.form-grid .full{grid-column:auto}.card-head{align-items:flex-start}.login-card{padding:28px 22px}
  .form-section{align-items:flex-start;flex-direction:column;gap:3px}.confirm-grid{grid-template-columns:auto 1fr;padding:14px;gap:11px}.confirm-grid .confirm-full{grid-column:2}.modal-actions button{flex:1}
  table{min-width:780px}.table-wrap{margin:0 -15px;border-radius:0;border-left:0;border-right:0}
}
