:root{--ink:#17221d;--muted:#66736c;--green:#176b4b;--green2:#0f553b;--pale:#edf5f0;--line:#dce4df;--bg:#f5f7f5;--orange:#b35b1e;--danger:#a33b36;--white:#fff;--shadow:0 10px 30px rgba(24,55,40,.07)}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font:15px/1.55 "Microsoft YaHei","PingFang SC",sans-serif}a{color:var(--green);text-decoration:none}button,input,select,textarea{font:inherit}.topbar{height:68px;background:#123f30;color:#fff;display:flex;align-items:center;padding:0 4%;gap:28px;position:sticky;top:0;z-index:10;box-shadow:0 3px 15px #0002}.brand{color:#fff;font-weight:700;font-size:18px;white-space:nowrap}.brand span,.login-logo{display:inline-grid;place-items:center;background:#d8a94e;color:#173d30;border-radius:50%;width:34px;height:34px;margin-right:7px}.nav{display:flex;align-items:center;gap:5px;flex:1}.nav a{color:#dceae4;padding:9px 11px;border-radius:7px}.nav a:hover{background:#ffffff14;color:#fff}.logout button{border:1px solid #ffffff44;background:transparent;color:#fff;border-radius:7px;padding:7px 12px}.nav-toggle{display:none}.container{max-width:1260px;margin:0 auto;padding:30px 24px 70px}.page-head{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:22px}.page-head h1{margin:0;font-size:28px}.page-head p{margin:4px 0 0;color:var(--muted)}.actions{display:flex;gap:10px;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;color:var(--ink);padding:9px 16px;border-radius:8px;cursor:pointer}.btn:hover{box-shadow:0 3px 12px #0001}.btn.primary{background:var(--green);border-color:var(--green);color:#fff}.btn.danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn.wide{width:100%}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stats article{background:#fff;border:1px solid var(--line);padding:20px;border-radius:12px;box-shadow:var(--shadow)}.stats label{display:block;color:var(--muted);margin-bottom:8px}.stats strong{font-size:26px}.stats small{color:var(--muted);margin-left:4px}.green{color:var(--green)}.orange{color:var(--orange)}.panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px;margin-bottom:20px;box-shadow:var(--shadow)}.panel h2{font-size:18px;margin:0 0 18px}.panel-head{display:flex;align-items:center;justify-content:space-between}.table-scroll{overflow:auto}table{width:100%;border-collapse:collapse;white-space:nowrap}th{text-align:left;color:var(--muted);font-weight:600;background:#fafbfa}th,td{padding:13px 12px;border-bottom:1px solid #edf0ee}tr:last-child td{border-bottom:0}.empty{text-align:center;color:var(--muted);padding:36px}.tag{display:inline-block;padding:3px 9px;background:#eef2ef;border-radius:20px;font-size:13px}.tag.active,.tag.income{background:#e5f5ec;color:#176b4b}.tag.withdrawn,.tag.expense{background:#f8ece7;color:#9b4c24}.search{display:flex;gap:10px;margin-bottom:18px}.search input{min-width:310px}.search input,.form-grid input,.form-grid select,.form-grid textarea,.filters input{border:1px solid #cbd6cf;border-radius:7px;padding:9px 10px;background:#fff}.form-panel{max-width:820px}.form-grid p{display:grid;grid-template-columns:180px 1fr;gap:15px;align-items:start;margin:0 0 16px}.form-grid label{font-weight:600;padding-top:8px}.form-grid textarea{min-height:80px}.form-grid .helptext{grid-column:2;color:var(--muted);font-size:13px}.errorlist{grid-column:2;color:var(--danger);margin:0;padding-left:18px}.form-actions{display:flex;gap:10px;margin-left:195px;margin-top:22px}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px}.panel dl,.receipt dl{display:grid;grid-template-columns:150px 1fr;margin:0}.panel dt,.panel dd,.receipt dt,.receipt dd{padding:11px;border-bottom:1px solid #edf0ee;margin:0}.panel dt,.receipt dt{color:var(--muted)}.big-number{font-size:42px;font-weight:700;margin:15px 0 24px}.big-number small{font-size:14px;color:var(--muted)}.receipt{max-width:850px;margin-left:auto;margin-right:auto}.receipt-title{text-align:center;font:700 25px/1.3 serif;margin:10px}.receipt-no{text-align:right;color:var(--muted);margin-bottom:20px}.receipt .amount{font-size:20px;font-weight:700;color:var(--green)}.receipt-foot{text-align:center;margin-top:35px}.highlight{border-left:5px solid var(--green)}.info-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.warning{background:#fff7e8;border:1px solid #f1d7a7;color:#755320;padding:12px 15px;border-radius:8px;margin:14px 0}.filters form{display:flex;gap:20px;align-items:end}.filters label{display:grid;gap:6px;color:var(--muted)}.message{padding:12px 16px;border-radius:8px;margin-bottom:18px;background:#e7f4ec;color:#17583e}.message.error{background:#f9e8e7;color:#8c302d}.login-wrap{min-height:100vh;display:grid;place-items:center}.login-card{width:min(420px,92vw);background:#fff;border:1px solid var(--line);border-radius:16px;padding:38px;box-shadow:0 18px 60px #173b2b1c;text-align:center}.login-card h1{margin:14px 0 0}.login-logo{width:58px;height:58px;margin:0;font-size:25px}.muted{color:var(--muted)}.stack p{text-align:left}.stack input{width:100%;border:1px solid #cbd6cf;border-radius:8px;padding:11px;margin-top:5px}.link{border:0;background:none;padding:0;color:var(--green);cursor:pointer}.danger-text{color:var(--danger)}td.actions{display:flex;gap:14px}canvas{width:100%}
@media(max-width:900px){.topbar{height:auto;min-height:62px;flex-wrap:wrap;padding:12px 18px}.nav-toggle{display:block;margin-left:auto}.nav{display:none;order:4;width:100%;flex-wrap:wrap}.nav.open{display:flex}.logout{margin-left:auto}.stats{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}.info-row{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.container{padding:20px 12px}.page-head{align-items:flex-start;flex-direction:column}.actions{flex-wrap:wrap}.stats{grid-template-columns:1fr 1fr;gap:10px}.stats article{padding:14px}.stats strong{font-size:20px}.panel{padding:15px}.search{flex-direction:column}.search input{min-width:0;width:100%}.form-grid p{grid-template-columns:1fr;gap:4px}.form-grid label{padding:0}.form-actions{margin-left:0}.info-row{grid-template-columns:1fr}.filters form{flex-wrap:wrap}.receipt dl{grid-template-columns:110px 1fr}}
@media print{.topbar,.page-head .actions,.page-head button,.filters{display:none!important}.container{padding:0}.panel{box-shadow:none}.stats{grid-template-columns:repeat(5,1fr)}}
.erp-shell{min-height:100vh;display:grid;grid-template-columns:248px 1fr}.sidebar{background:linear-gradient(180deg,#113c2e,#0b2c22);color:#fff;padding:20px 16px;position:sticky;top:0;height:100vh;overflow:visible;box-shadow:6px 0 24px #102d2115}.sidebar .brand{display:flex;align-items:center;gap:9px;color:#fff;margin-bottom:22px;font-size:17px}.sidebar .brand span{margin:0;flex:0 0 auto}.sidebar .nav{display:grid;gap:5px}.sidebar .nav label{color:#9fc2b3;font-size:12px;letter-spacing:.12em;margin:18px 8px 6px}.sidebar .nav a{color:#dceae4;padding:11px 12px;border-radius:9px}.sidebar .nav a:hover{background:#ffffff17;color:#fff}.workarea{min-width:0}.erp-shell .topbar{height:64px;background:#fff;color:var(--ink);justify-content:space-between;padding:0 28px;border-bottom:1px solid var(--line);box-shadow:none}.erp-shell .topbar strong{display:block}.erp-shell .topbar small{display:block;color:var(--muted);font-size:13px;margin-top:2px}.erp-shell .logout button{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:8px;padding:8px 14px}.wrap{white-space:normal;min-width:220px}.login-wrap{min-height:100vh}
@media(max-width:900px){.erp-shell{display:block}.sidebar{height:auto;position:sticky;z-index:20;padding:12px 16px;overflow:auto}.sidebar .brand{margin:0}.sidebar .nav{display:none;margin-top:12px}.sidebar.open .nav{display:grid}.erp-shell .topbar{padding:12px 18px}.container{padding-top:20px}}
.business-window{border:1px solid #9fb1c8;border-radius:10px;background:#dbe5f4;box-shadow:0 14px 40px #17456a18;margin-bottom:22px;overflow:hidden}.window-title{background:linear-gradient(#7aa6e8,#376dbf);color:#fff;font-weight:700;padding:9px 14px;letter-spacing:.03em}.window-body{padding:16px;background:#eef3fb}.window-body.two-col{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,.7fr);gap:16px}.no-shadow{box-shadow:none}.hidden{display:none!important}.quick-card{border-color:#b8c9df;background:#f8fbff}.business-window .form-grid p{grid-template-columns:150px 1fr}.business-window input,.business-window select,.business-window textarea{background:#fffef5}.business-window .panel h2{color:#204b7b}.business-window .form-actions{margin-left:165px}.business-window .warning{background:#fff8db}.tag{margin-right:4px}
@media(max-width:900px){.window-body.two-col{grid-template-columns:1fr}.business-window .form-actions{margin-left:0}}
.template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.template-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;box-shadow:var(--shadow)}.print-preview-mini{border:1px solid #cfd9d4;background:#fbfdfc;margin:14px 0;padding:18px;min-height:190px}.print-preview-mini h3{text-align:center;margin:0 0 15px}.print-preview-mini table,.print-paper table{width:100%;border-collapse:collapse;white-space:normal}.print-preview-mini th,.print-preview-mini td,.print-paper th,.print-paper td{border:1px solid #8fa1b4;padding:7px 8px}.designer-shell{display:grid;grid-template-columns:245px minmax(0,1fr);gap:0;background:#d6dce5;border:1px solid #c6cdd8;border-radius:12px;overflow:hidden}.designer-tools{background:#f8faf9;border-right:1px solid #cfd7d2;padding:14px;overflow:auto}.designer-tools h2{font-size:15px;margin:18px 0 10px}.compact-form p,.compact-form .field-row>div{display:grid;gap:5px;margin:0 0 10px}.compact-form input,.compact-form select,.compact-form textarea{width:100%;border:1px solid #cbd6cf;border-radius:7px;padding:8px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.no-indent{margin-left:0!important;flex-wrap:wrap}.designer-preview{padding:16px;overflow:auto}.preview-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-weight:700}.print-paper{background:#fff;margin:0 auto;border:1px dashed #aab5c3;box-shadow:0 8px 25px #0001;padding:18mm 18mm 12mm}.print-paper h2{text-align:center;margin:0 0 20px}.print-paper .receipt-no{text-align:left}.service-text{margin-top:18px;line-height:1.8}.print-paper .receipt-foot{text-align:right;margin-top:22px}
.brand-logo{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#fff}.camera-btn{margin-left:8px;padding:7px 12px}.camera-overlay{position:fixed;inset:0;background:rgba(0,0,0,.62);z-index:9999;display:grid;place-items:center;padding:20px}.camera-panel{background:#fff;border-radius:14px;padding:16px;box-shadow:0 25px 80px #0006;width:min(760px,96vw)}.camera-panel video{display:block;width:100%;max-height:65vh;background:#111;border-radius:10px}.camera-panel .actions{margin-top:14px;justify-content:center}.menu-sorter{list-style:none;padding:0;margin:0;display:grid;gap:8px}.menu-sorter li{background:#fff;border:1px solid #cbd6cf;border-radius:9px;padding:11px 12px;cursor:grab;box-shadow:0 2px 8px #0000000d}.menu-sorter li.dragging{opacity:.55}.menu-sorter li span{display:inline-block;margin-right:10px;background:#e5f5ec;color:#176b4b;border-radius:20px;padding:2px 8px;font-size:12px}
@media(max-width:1050px){.template-grid{grid-template-columns:1fr}.designer-shell{grid-template-columns:1fr}.designer-tools{border-right:0;border-bottom:1px solid #cfd7d2}}
@media print{.sidebar,.topbar,.page-head,.designer-tools,.preview-toolbar{display:none!important}.erp-shell{display:block}.designer-shell{display:block;border:0}.designer-preview{padding:0}.print-paper{box-shadow:none;border:0;margin:0;width:auto!important}}
.query-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr)) auto;gap:12px;align-items:end}.query-grid label{display:grid;gap:5px;color:var(--muted);font-weight:600}.query-grid input{border:1px solid #cbd6cf;border-radius:7px;padding:9px 10px;background:#fffef5}.query-actions{display:flex;gap:8px;align-items:center}
@media(max-width:1100px){.query-grid{grid-template-columns:repeat(2,minmax(150px,1fr))}.query-actions{grid-column:1/-1}}
@media(max-width:600px){.query-grid{grid-template-columns:1fr}}
.container:has(.accounting-module){max-width:none;padding:0;background:#eef2f6;min-height:calc(100vh - 64px)}
.accounting-module{display:grid;grid-template-columns:162px minmax(0,1fr);gap:0;align-items:stretch;min-height:calc(100vh - 64px);background:#eef2f6}
.accounting-content{min-width:0;padding:0 0 28px;overflow:hidden}
.accounting-side{position:sticky;top:64px;align-self:start;height:calc(100vh - 64px);background:linear-gradient(180deg,#2a73bd 0%,#2c8bd0 55%,#86cfef 100%);border-radius:0;padding:0;box-shadow:none;z-index:30;overflow:visible}
.accounting-logo{height:58px;display:flex;align-items:center;padding:0 12px;color:#fff;font-size:20px;font-weight:800;letter-spacing:.02em;background:#2a75bd}
.accounting-main,.accounting-menu>span{display:flex;align-items:center;justify-content:flex-start;gap:10px;color:#fff;padding:15px 16px;border-radius:0;font-weight:700;cursor:pointer;font-size:16px}
.accounting-main:before{content:"⌂";opacity:.9}.accounting-menu>span:before{content:"▣";opacity:.75}
.accounting-main:hover,.accounting-main.active,.accounting-menu:hover>span,.accounting-menu.active>span{background:#1e65a9;color:#fff}
.accounting-menu{position:relative}
.accounting-menu>span:after{content:"›";color:#b8d8cc}
.accounting-menu>span:after{margin-left:auto;color:#dcefff}
.accounting-submenu{display:none;position:absolute;left:100%;top:0;min-width:320px;background:#fff;border:1px solid #dce4ee;border-radius:0;padding:20px 26px;box-shadow:0 12px 35px #102d2130;z-index:70;grid-template-columns:1fr 1fr;gap:18px 34px}
.accounting-menu:hover .accounting-submenu,.accounting-menu:focus-within .accounting-submenu{display:grid;gap:4px}
.accounting-menu:hover .accounting-submenu,.accounting-menu:focus-within .accounting-submenu{display:grid;gap:18px 34px}
.accounting-submenu a{color:#394b5a;padding:0;border-radius:0;font-weight:500;font-size:16px;white-space:nowrap}
.accounting-submenu a:hover{background:transparent;color:#2e7bd2;text-decoration:underline}
.accounting-topbar{height:54px;background:#fff;border-bottom:1px solid #dfe6ef;display:flex;align-items:center;gap:18px;padding:0 18px;color:#1f2f3d}
.book-select{height:54px;min-width:220px;display:flex;align-items:center;justify-content:space-between;border-right:1px solid #e0e6ed;padding-right:12px}
.book-select span{font-size:16px}.top-icon{font-size:24px;color:#5b6570;text-decoration:none}.period-select{display:flex;align-items:center;gap:8px}.period-select label{display:flex;align-items:center;gap:8px}.period-select input{border:0;border-bottom:1px solid #cbd6e2;padding:5px 6px;background:#fff}.period-select button{border:0;background:#fff;color:#6b7885;font-size:18px}
.top-spacer{margin-left:auto}
.accounting-tabs-line{height:54px;display:flex;align-items:stretch;background:#fff;border-bottom:1px solid #dfe6ef;padding-left:22px}
.accounting-tabs-line a{display:flex;align-items:center;padding:0 28px;color:#1d2f40;border-right:1px solid transparent;font-size:16px}
.accounting-tabs-line a.active{background:#3d7fd2;color:#fff}.accounting-tabs-line small{margin-left:8px;color:inherit}
.accounting-filter{display:flex;gap:10px;align-items:end;margin:0 0 18px}
.accounting-filter label{display:grid;gap:5px;color:var(--muted);font-weight:600}
.accounting-filter input{border:1px solid #cbd6cf;border-radius:7px;padding:9px 10px;background:#fff}
.accounting-report-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.report-dl{display:grid;grid-template-columns:1fr 1fr;margin:0}
.report-dl dt,.report-dl dd{padding:12px;border-bottom:1px solid #edf0ee;margin:0}
.report-dl dt{color:var(--muted)}
.report-dl dd{text-align:right;font-weight:700}
@media(max-width:1050px){.accounting-report-grid{grid-template-columns:1fr}.accounting-filter{flex-wrap:wrap}.accounting-module{grid-template-columns:1fr}.accounting-side{position:relative;top:auto;height:auto;display:flex;flex-wrap:wrap}.accounting-logo{width:100%}.accounting-submenu{position:absolute;left:0;top:100%;min-width:260px}.accounting-menu{position:relative}.accounting-main,.accounting-menu>span{padding:10px 12px}}
.voucher-editor{display:grid;gap:16px;padding:34px 8vw 0}.voucher-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.voucher-toolbar h1{margin:0;font-size:30px;text-align:center}.voucher-toolbar p{margin:5px 0 0;color:#596978}.voucher-paper{background:#fff;border:1px solid #cdd8e3;box-shadow:none;border-radius:0;padding:34px 36px 18px;overflow:auto}.voucher-head{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:12px;align-items:center;margin-bottom:14px}.voucher-head label,.voucher-summary label{display:flex;gap:8px;align-items:center;color:#51616c}.voucher-head input,.voucher-summary input,.voucher-head select,.voucher-table input,.voucher-table select{border:0;border-bottom:1px solid #c8d3dd;border-radius:0;padding:8px;background:#fff}.voucher-no{display:inline-block;min-width:110px;border-bottom:1px solid #aeb9c4;color:#2c3e50}.voucher-summary{margin-bottom:12px}.voucher-summary input{width:min(720px,100%)}.voucher-table{min-width:1220px;border-collapse:collapse;background:#fff}.voucher-table th{background:#fff;color:#293a4a;text-align:center;border:1px solid #ccd3dc;padding:10px;font-size:16px}.voucher-table td{border:1px solid #d5dce5;padding:0;height:72px}.voucher-table input,.voucher-table select{width:100%;height:100%;border:0;border-radius:0;padding:11px 10px;background:#fff}.voucher-table .line-no{width:58px;text-align:center;color:#11243a;font-weight:700}.voucher-table .money-cell{min-width:250px;background:repeating-linear-gradient(90deg,#fff 0,#fff 18px,#e2edf8 19px,#fff 20px,#fff 39px,#ffd9d9 40px)}.voucher-foot{display:flex;justify-content:space-between;gap:16px;align-items:center;border:1px solid #ccd3dc;border-top:0;padding:16px 14px;min-width:1220px}.voucher-foot b{color:#111}
@media(max-width:900px){.voucher-toolbar{display:grid}.voucher-head{grid-template-columns:1fr}.voucher-paper{padding:12px}}
.menu-sorter li small{display:block;color:var(--muted);margin:6px 0 0 48px}.nav-tree{margin:4px 0}.nav-tree summary{color:#dceae4;padding:11px 12px;border-radius:9px;cursor:pointer;list-style:none}.nav-tree summary::-webkit-details-marker{display:none}.nav-tree summary:before{content:"▾";display:inline-block;margin-right:8px;color:#9fc2b3}.nav-tree:not([open]) summary:before{content:"▸"}.nav-tree div{display:grid;gap:4px;margin:2px 0 4px 18px}.sidebar .nav-tree a{padding:9px 12px}
.nav-flyout{position:relative;margin:4px 0}.nav-flyout>button{width:100%;border:0;background:transparent;color:#dceae4;text-align:left;padding:11px 12px;border-radius:9px;cursor:pointer}.nav-flyout>button:before{content:"›";display:inline-block;margin-right:10px;color:#9fc2b3}.nav-flyout:hover>button,.nav-flyout:focus-within>button{background:#ffffff17;color:#fff}.flyout-panel{display:none;position:absolute;left:calc(100% + 10px);top:0;min-width:185px;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:12px;padding:8px;box-shadow:0 12px 35px #102d2130;z-index:60}.nav-flyout:hover .flyout-panel,.nav-flyout:focus-within .flyout-panel{display:grid;gap:4px}.sidebar .nav .flyout-panel a{color:#24463a;padding:10px 12px;border-radius:8px}.sidebar .nav .flyout-panel a:hover{background:#edf5f1;color:#126147}
@media(max-width:900px){.flyout-panel{position:static;margin:4px 0 4px 18px;background:#ffffff12;border:0;box-shadow:none}.nav-flyout:hover .flyout-panel,.nav-flyout:focus-within .flyout-panel{display:grid}.sidebar .nav .flyout-panel a{color:#dceae4}.sidebar .nav .flyout-panel a:hover{background:#ffffff17;color:#fff}}
.clickable-stats a{color:inherit}.clickable-stats a article{height:100%;transition:.12s transform,.12s box-shadow}.clickable-stats a:hover article{transform:translateY(-2px);box-shadow:0 12px 30px rgba(24,55,40,.13)}.clickable-stats small{display:block;margin:8px 0 0;color:var(--green)}
