:root{color:#1f2a44;background:#f4f7fb;font-family:Inter,Microsoft YaHei,PingFang SC,Arial,sans-serif;font-synthesis:none;line-height:1.5;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:flex;min-height:100vh;background:#f4f7fb}.sidebar{position:sticky;top:0;width:244px;height:100vh;flex:0 0 244px;overflow-y:auto;border-right:1px solid #e6edf7;background:#fff;padding:20px 14px;z-index:20}.brand,.login-logo{display:flex;align-items:center;gap:12px}.brand{margin-bottom:22px;padding:0 6px}.brand strong,.login-logo strong{display:block;color:#0b2d5c;font-size:20px}.brand span,.login-logo span{display:block;color:#7b89a4;font-size:12px}.brand-mark{display:grid;width:42px;height:42px;place-items:center;border-radius:12px;background:linear-gradient(135deg,#1d7bf0,#0ba8d6);color:#fff;font-weight:800}.brand-mark.large{width:54px;height:54px;border-radius:16px;font-size:24px}.nav-group{margin-bottom:18px}.nav-group p{margin:0 0 8px;padding:0 10px;color:#93a0b8;font-size:12px;font-weight:700}.nav-group button{display:flex;align-items:center;width:100%;min-height:38px;gap:10px;border:0;border-radius:8px;margin:2px 0;padding:9px 11px;background:transparent;color:#65728a;text-align:left}.nav-group button:hover{background:#f0f6ff;color:#1d7bf0}.nav-group button.active{background:#e9f3ff;color:#1267ce;font-weight:700}.main{min-width:0;flex:1;padding:22px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.topbar h1{margin:0;color:#122241;font-size:24px}.topbar p,.panel-title p{margin:3px 0 0;color:#73819b;font-size:13px}.topbar-actions,.button-row{display:flex;align-items:center;gap:10px}.mobile-only{display:none}.icon-button,.ghost-button,.primary-button,.text-button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;gap:7px;border-radius:8px;border:1px solid #dce6f5;background:#fff;color:#315071;white-space:nowrap}.icon-button{width:38px;padding:0}.icon-button.mobile-only{display:none}.ghost-button{padding:0 13px}.primary-button{border-color:#1d7bf0;background:#1d7bf0;color:#fff;box-shadow:0 8px 18px #1d7bf038}.primary-button.compact{min-height:38px;padding:0 14px}.text-button{min-height:auto;padding:0;border:0;background:transparent;color:#1267ce;font-weight:700}.danger-text{color:#d93434}.page-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:16px}.stat-grid{display:grid;grid-column:1 / -1;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stat-card,.panel{border:1px solid #e4ebf6;border-radius:8px;background:#fff;box-shadow:0 10px 28px #1f35580d}.stat-card{position:relative;min-height:122px;padding:18px}.stat-icon{display:grid;width:38px;height:38px;place-items:center;border-radius:8px;background:#ecf5ff;color:#1d7bf0}.stat-card p{margin:14px 0 2px;color:#74829a;font-size:13px}.stat-card strong{display:block;color:#122241;font-size:25px}.stat-card span{color:#93a0b8;font-size:12px}.panel{padding:18px}.page-panel{min-height:calc(100vh - 112px)}.panel.wide{grid-column:1 / -1}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.panel-title h2{margin:0;color:#122241;font-size:18px}.todo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.todo-card{display:flex;align-items:center;gap:12px;border-radius:8px;padding:15px;background:#f7faff}.todo-card strong,.todo-card span{display:block}.todo-card strong{color:#42516a}.todo-card span{color:#122241;font-size:20px;font-weight:800}.todo-card.danger{color:#d93434;background:#fff4f4}.todo-card.warn{color:#b77900;background:#fff8e7}.todo-card.info{color:#1267ce;background:#eef6ff}.chart-panel{min-height:330px}.table-wrap{width:100%;overflow-x:auto;border:1px solid #e6edf7;border-radius:8px}table{width:100%;min-width:960px;border-collapse:collapse}th,td{border-bottom:1px solid #edf2f8;padding:12px 13px;color:#3a4962;font-size:13px;text-align:left}th{background:#f8fbff;color:#6b7890;font-weight:700}tbody tr:hover{background:#fbfdff}tbody tr:last-child td{border-bottom:0}.mono{color:#1267ce;font-family:Cascadia Mono,Consolas,monospace;font-size:12px}.note-cell{max-width:260px;color:#53627c;line-height:1.65;white-space:normal}.note-cell span{display:block}.profit-positive{color:#157347;font-weight:800}.balance-cell{color:#a16000;font-weight:800}.profit-negative{color:#d93434;font-weight:800}.row-check{width:16px;height:16px}.pill{display:inline-flex;align-items:center;justify-content:center;min-width:62px;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700}.status-进行中,.pay-已审核{color:#1267ce;background:#e8f3ff}.status-待审核,.pay-待审核{color:#a16000;background:#fff3d6}.status-待收款{color:#b42318;background:#fff0ee}.status-已完成{color:#157347;background:#e8f7ef}.status-已取消,.pay-已驳回{color:#6b7280;background:#edf0f4}.login-page{display:grid;min-height:100vh;place-items:center;padding:32px;background:linear-gradient(180deg,#fff9,#f4f7fbe6),radial-gradient(circle at 25% 35%,rgba(29,123,240,.12),transparent 24%),#f5f8fc}.system-portal{min-height:100vh;display:grid;place-items:center;padding:36px;background:linear-gradient(135deg,#eff7ffeb,#f7fcf9f5),radial-gradient(circle at 18% 18%,rgba(20,149,232,.16),transparent 28%),radial-gradient(circle at 84% 78%,rgba(30,150,112,.12),transparent 26%),#f5f9fc}.portal-card{display:grid;width:min(1040px,100%);min-height:560px;grid-template-columns:minmax(320px,.95fr) minmax(420px,1.05fr);overflow:hidden;border:1px solid rgba(220,230,245,.9);border-radius:8px;background:#ffffffe0;box-shadow:0 28px 70px #26406029}.portal-visual{position:relative;overflow:hidden;min-height:560px;background:linear-gradient(180deg,#ffffff14,#1252811f),linear-gradient(145deg,#dff2ff,#bfe4f7 48%,#eef8f3)}.travel-sun{position:absolute;top:64px;right:78px;width:86px;height:86px;border-radius:50%;background:#ffd37a;box-shadow:0 18px 50px #f5a5244d}.travel-mountain{position:absolute;left:50%;width:430px;height:430px;transform:translate(-50%) rotate(45deg);border-radius:8px}.mountain-back{bottom:-250px;margin-left:-74px;background:#95c7dc}.mountain-front{bottom:-282px;margin-left:96px;background:#2f8e7d}.travel-route{position:absolute;left:66px;right:66px;bottom:86px;height:3px;border-radius:999px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.9) 0 16px,transparent 16px 28px)}.travel-route:before,.travel-route:after{content:"";position:absolute;top:-7px;width:17px;height:17px;border:3px solid #fff;border-radius:50%;background:#1d7bf0}.travel-route:before{left:0}.travel-route:after{right:0}.portal-badge{position:absolute;left:34px;top:34px;border:1px solid rgba(255,255,255,.58);border-radius:999px;padding:8px 14px;background:#ffffff6b;color:#0b4b6d;font-size:13px;font-weight:800;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.portal-content{display:flex;flex-direction:column;justify-content:center;gap:28px;padding:54px}.portal-heading{max-width:560px}.portal-heading .brand-mark{margin-bottom:18px}.portal-heading h1{margin:4px 0 0;color:#122241;font-size:38px}.portal-heading p{margin:12px 0 0;color:#66758f;line-height:1.8}.system-grid{display:grid;grid-template-columns:1fr;gap:12px}.system-card{display:grid;min-height:86px;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;border:1px solid #dce6f5;border-radius:8px;background:#fff;color:#122241;padding:16px;text-align:left;box-shadow:0 18px 45px #2640601a}.system-card:hover{border-color:#1d7bf0;background:#f8fbff;transform:translateY(-2px)}.system-card strong{display:block;font-size:21px}.system-card small{display:block;margin-top:3px;color:#71809a}.portal-footnotes{display:flex;gap:10px;flex-wrap:wrap}.portal-footnotes span{border:1px solid #dce6f5;border-radius:999px;padding:7px 11px;background:#fff;color:#52637c;font-size:12px;font-weight:700}.login-logo{position:fixed;top:48px}.login-card{display:grid;width:min(920px,100%);grid-template-columns:minmax(0,.9fr) minmax(340px,1fr);overflow:hidden;border-radius:8px;background:#fff;box-shadow:0 22px 55px #26406024}.login-pitch{min-height:430px;padding:58px 48px;background:linear-gradient(150deg,#0c62cf,#1495e8);color:#fff}.app-icon{display:grid;width:62px;height:62px;place-items:center;border-radius:18px;margin-bottom:26px;background:#ffffff2e;font-weight:800}.login-pitch h2{margin:0 0 10px;font-size:26px}.login-pitch p,.login-pitch li{color:#ffffffdb}.login-pitch ul{margin:28px 0 0;padding-left:18px}.login-form{display:flex;flex-direction:column;justify-content:center;gap:18px;padding:52px 48px}.eyebrow{margin:0 0 2px;color:#6c7b91;font-size:13px;font-weight:700}.login-form h1{margin:0;color:#132846;font-size:26px}.switch-system-login{width:100%;min-height:46px;border:1px solid #b9d8ff;border-radius:8px;background:linear-gradient(180deg,#f7fbff,#eef6ff);color:#1267ce;font-size:15px;font-weight:900;box-shadow:0 10px 24px #1d7bf01a}.switch-system-login:hover{border-color:#1d7bf0;background:#eaf4ff}.login-error{border:1px solid #ffd6d1;border-radius:8px;background:#fff5f4;color:#b42318;padding:10px 12px;font-size:13px;font-weight:700}.login-notice{border:1px solid #ccebdd;border-radius:8px;background:#effaf4;color:#157347;padding:10px 12px;font-size:13px;font-weight:700}.auth-tabs,.auth-methods{display:grid;gap:8px}.auth-tabs{grid-template-columns:repeat(2,minmax(0,1fr));border:1px solid #dce6f5;border-radius:8px;padding:4px;background:#f7faff}.auth-methods{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-tabs button,.auth-methods button{min-height:36px;border:0;border-radius:6px;background:transparent;color:#65728a;font-weight:800}.auth-tabs button.active,.auth-methods button.active{background:#fff;color:#1267ce;box-shadow:0 8px 18px #26406014}.auth-methods button{border:1px solid #dce6f5;background:#fff}.auth-methods button.active{border-color:#1d7bf0;background:#eef6ff}.code-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}label{display:flex;flex-direction:column;gap:7px;color:#43516a;font-size:13px;font-weight:700}.label-title{display:inline-flex;align-items:center;gap:4px;min-height:18px}.required-star{color:#d93434;font-size:15px;font-weight:900;line-height:1}input,select,textarea{width:100%;border:1px solid #dce6f5;border-radius:8px;outline:none;background:#fff;color:#1f2a44}input,select{height:40px;padding:0 12px}textarea{min-height:96px;resize:vertical;padding:11px 12px}input:focus,select:focus,textarea:focus{border-color:#1d7bf0;box-shadow:0 0 0 3px #1d7bf01f}.check-row{flex-direction:row;align-items:center;font-weight:500}.check-row input{width:16px;height:16px}.filters,.inline-form{display:flex;align-items:end;gap:12px;margin-bottom:16px;flex-wrap:wrap}.search-box,.select-box{display:flex;flex-direction:row;align-items:center;height:40px;gap:8px;border:1px solid #dce6f5;border-radius:8px;background:#fff;padding:0 12px;color:#7c8aa3}.search-box{min-width:min(420px,100%);flex:1}.search-box input,.select-box select{height:36px;border:0;padding:0;box-shadow:none}.select-box{min-width:170px}.status-select{width:104px;height:32px;padding:0 8px;border-radius:999px;font-size:12px;font-weight:700}.error-box{display:flex;flex-direction:column;gap:4px;border:1px solid #ffd6d1;border-radius:8px;margin-bottom:14px;padding:12px 14px;background:#fff5f4;color:#b42318;font-size:13px}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.form-grid .full,.form-actions{grid-column:1 / -1}.form-grid .half{grid-column:span 1}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.inline-form label{min-width:220px}.save-success{color:#157347;font-size:13px;font-weight:800}.route-price-periods{display:grid;min-width:440px;gap:8px}.route-price-period{display:grid;grid-template-columns:22px 1fr 1fr 84px 34px;align-items:center;gap:6px}.route-price-period span{display:grid;width:22px;height:22px;place-items:center;border-radius:999px;background:#eef6ff;color:#1267ce;font-size:12px;font-weight:800}.route-price-period input{min-width:0;height:34px;padding:0 8px;font-size:12px}.compact-period-button{width:fit-content;min-height:32px;padding:0 10px;font-size:12px}.profit-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.profit-summary article{border:1px solid #e6edf7;border-radius:8px;background:#fbfdff;padding:16px}.profit-summary span,.profit-summary small{display:block;color:#73819b;font-size:12px}.profit-summary strong{display:block;margin:4px 0;color:#122241;font-size:23px}.profit-summary .positive{border-color:#ccebdd;background:#effaf4}.profit-summary .positive strong{color:#157347}.profit-summary .negative{border-color:#ffd6d1;background:#fff5f4}.profit-summary .negative strong{color:#d93434}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#0a182a52;z-index:40}.modal{width:min(960px,100%);max-height:calc(100vh - 48px);overflow-y:auto;border-radius:8px;background:#fff;padding:20px;box-shadow:0 22px 60px #0a182a3d}.modal-form{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detail{min-height:74px;border:1px solid #e6edf7;border-radius:8px;padding:12px;background:#fbfdff}.detail span{display:block;color:#7b88a0;font-size:12px}.detail strong{display:block;margin-top:4px;color:#122241;word-break:break-word}.wide-detail{grid-column:1 / -1}.empty-state{display:flex;min-height:calc(100vh - 112px);flex-direction:column;align-items:center;justify-content:center;text-align:center}.empty-icon{display:grid;width:72px;height:72px;place-items:center;border-radius:18px;margin-bottom:18px;background:#ecf5ff;color:#1d7bf0}.empty-state h2{margin:0 0 8px}.empty-state p{max-width:560px;margin:0;color:#6f7d94}.placeholder-list{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:22px}.placeholder-list span{border-radius:999px;background:#eef6ff;color:#1267ce;padding:8px 12px;font-size:13px;font-weight:700}@media(max-width:1180px){.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.page-grid{grid-template-columns:1fr}}@media(max-width:860px){.sidebar{position:fixed;left:-270px;transition:left .2s ease}.sidebar.open{left:0}.mobile-only,.icon-button.mobile-only{display:inline-flex}.main{padding:16px}.topbar{align-items:flex-start}.topbar-actions{flex-wrap:wrap;justify-content:flex-end}.login-card,.portal-card{grid-template-columns:1fr}.portal-content{padding:34px 26px}.portal-visual{min-height:230px}.travel-sun{top:34px;right:42px;width:62px;height:62px}.travel-mountain{width:300px;height:300px}.mountain-back{bottom:-188px}.mountain-front{bottom:-206px}.portal-heading h1{font-size:30px}.system-grid{grid-template-columns:1fr}.login-pitch{min-height:auto;padding:38px 30px}.login-form{padding:34px 30px}.login-logo{position:static;margin-bottom:24px}.login-page{display:block}.form-grid,.profit-summary,.todo-grid,.detail-grid{grid-template-columns:1fr}.form-grid .half,.wide-detail{grid-column:auto}}@media(max-width:620px){.stat-grid{grid-template-columns:1fr}.topbar{flex-wrap:wrap}.topbar h1{font-size:20px}.panel-title,.filters,.inline-form{align-items:stretch;flex-direction:column}.button-row{flex-wrap:wrap}}
