:root{--ink:#16231f;--muted:#728078;--green:#174f3f;--green-2:#26765d;--mint:#dff0e8;--cream:#f4f1e8;--paper:#fbfaf6;--line:#e5e7df;--amber:#d69845;--red:#b75b4d;--shadow:0 18px 46px rgba(28,45,38,.08)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--paper);color:var(--ink);font-family:"Microsoft YaHei UI","PingFang SC",Arial,sans-serif;display:flex;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:238px;background:#11241f;color:#fff;padding:30px 20px;display:flex;flex-direction:column;z-index:20}.brand{display:flex;align-items:center;gap:12px;color:#fff;text-decoration:none;padding:0 8px 36px}.brand-mark{width:42px;height:42px;display:grid;place-items:center;background:var(--cream);color:var(--green);font-family:serif;font-size:23px;border-radius:13px;transform:rotate(-3deg)}.brand b,.brand small{display:block}.brand b{letter-spacing:2px}.brand small{margin-top:5px;color:#9fb8ae;font-size:11px;letter-spacing:1px}.sidebar nav{display:grid;gap:8px}.nav-item{border:0;background:transparent;color:#9fb8ae;text-align:left;padding:13px 14px;border-radius:12px;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:.2s}.nav-item span{font-size:18px;width:20px}.nav-item:hover,.nav-item.active{background:rgba(255,255,255,.1);color:#fff}.nav-item.active{box-shadow:inset 3px 0 #d8b36a}.sidebar-note{margin-top:auto;padding:14px 10px;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:10px;align-items:flex-start}.sidebar-note b,.sidebar-note small{display:block}.sidebar-note b{font-size:12px}.sidebar-note small{color:#849c93;font-size:10px;margin-top:4px}.live-dot{width:8px;height:8px;border-radius:50%;background:#6bd6a3;box-shadow:0 0 0 5px rgba(107,214,163,.12);margin-top:3px}main{margin-left:238px;width:calc(100% - 238px);padding:0 40px 48px}.topbar{height:105px;display:flex;align-items:center;justify-content:space-between}.topbar h1{margin:2px 0 0;font-family:Georgia,"STSong",serif;font-size:29px}.eyebrow{margin:0;color:var(--green-2);font-size:10px;font-weight:700;letter-spacing:2.2px}.eyebrow.light{color:#b3d8ca}.top-actions{display:flex;align-items:center;gap:12px}.month-control{height:42px;display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:#fff;padding:0 13px;border-radius:11px;color:var(--muted);font-size:12px}.month-control input{border:0;outline:0;color:var(--ink);font:inherit}.button{height:42px;border:0;border-radius:11px;padding:0 17px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-size:13px}.button.primary{background:var(--green);color:#fff;box-shadow:0 8px 18px rgba(23,79,63,.2)}.button.ghost{background:#fff;color:var(--green);border:1px solid var(--line)}.page{display:none}.page.active{display:block;animation:fade .25s ease}@keyframes fade{from{opacity:0;transform:translateY(5px)}}.welcome-panel{position:relative;overflow:hidden;min-height:160px;border-radius:22px;padding:30px 34px;background:linear-gradient(120deg,#174d3e,#15382f);color:#fff;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow)}.welcome-panel:before{content:"";position:absolute;width:290px;height:290px;border:1px solid rgba(255,255,255,.09);border-radius:50%;right:-60px;top:-115px}.welcome-panel h2{font-family:Georgia,"STSong",serif;font-weight:500;font-size:27px;margin:9px 0}.welcome-panel p:last-child{color:#aac3ba;margin:0;font-size:13px}.orb{margin-right:50px;width:82px;height:82px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.06);position:relative}.orb span{font-family:Georgia;font-size:31px;color:#e0c078}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:18px 0}.kpi-card{background:#fff;border:1px solid var(--line);border-radius:17px;padding:19px;display:flex;align-items:center;gap:14px;min-width:0}.kpi-card.accent{background:#eef5f1}.kpi-card.warning{background:#fbf4eb}.kpi-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:var(--cream);color:var(--green);font:700 13px Georgia}.kpi-card span,.kpi-card small{display:block;color:var(--muted);font-size:11px}.kpi-card strong{display:block;font:600 24px Georgia;margin:4px 0;white-space:nowrap}.kpi-card.warning strong{color:var(--red)}.dashboard-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:16px}.panel{background:#fff;border:1px solid var(--line);border-radius:17px;padding:22px;box-shadow:0 6px 20px rgba(35,47,41,.025)}.trend-panel{min-height:335px}.payment-panel{grid-column:1/-1}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px}.panel-head h3{font-family:Georgia,"STSong",serif;margin:5px 0 0;font-size:19px}.legend{font-size:11px;color:var(--muted)}.legend i{display:inline-block;width:8px;height:8px;background:var(--green-2);border-radius:50%;margin-right:5px}.chart{height:235px}.trend-svg{width:100%;height:100%;overflow:visible}.grid-line{stroke:#e7ebe6;stroke-dasharray:3 5}.axis-label{fill:#8a958f;font-size:10px}.trend-area{fill:url(#areaGradient)}.trend-line{fill:none;stroke:var(--green-2);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.trend-dot{fill:#fff;stroke:var(--green-2);stroke-width:2}.zero-line{stroke:#cabda9;stroke-width:1}.empty-state{height:100%;display:grid;place-items:center;color:var(--muted);font-size:13px}.category-list{display:grid;gap:12px}.category-row{display:grid;grid-template-columns:70px 1fr 90px;align-items:center;gap:10px;font-size:12px}.category-row b{text-align:right;font:600 13px Georgia}.bar-track{height:7px;background:#eff1ed;border-radius:9px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,var(--green),#63a58c);border-radius:9px}.bar-fill.negative{background:linear-gradient(90deg,#c67764,#e6ad82)}.payment-list{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.payment-item{border:1px solid var(--line);border-radius:13px;padding:14px;display:flex;align-items:center;gap:11px}.payment-badge{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:var(--mint);color:var(--green);font-weight:700}.payment-item b,.payment-item small{display:block}.payment-item b{font-size:13px}.payment-item small{color:var(--muted);font-size:10px;margin-top:3px}.section-toolbar{display:flex;gap:10px;margin-bottom:15px}.search-box{flex:1;max-width:420px;height:42px;border:1px solid var(--line);border-radius:11px;background:#fff;padding:0 14px;display:flex;align-items:center;gap:8px}.search-box input{width:100%;border:0;outline:0;font:inherit}.section-toolbar select{border:1px solid var(--line);border-radius:11px;background:#fff;padding:0 12px;color:var(--ink)}.section-toolbar .button{margin-left:auto}.table-panel{padding:0;overflow:hidden}.table-summary{padding:15px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;color:var(--muted);font-size:12px}.table-summary b{color:var(--ink)}.table-scroll{overflow:auto;max-height:calc(100vh - 230px)}table{width:100%;border-collapse:collapse;white-space:nowrap}th{position:sticky;top:0;background:#f4f5f1;color:#68746e;text-align:left;font-size:10px;letter-spacing:.5px;padding:11px 13px;z-index:1}td{padding:12px 13px;border-top:1px solid #eff0ec;font-size:12px}tr:hover td{background:#fafbf8}.money{font:600 13px Georgia}.negative-text{color:var(--red)}.payment-tag{background:#eef5f1;color:var(--green);padding:4px 8px;border-radius:20px;font-size:10px}.row-actions{display:flex;gap:5px}.row-actions button{border:0;background:transparent;color:var(--muted);cursor:pointer;padding:3px}.room-intro{background:var(--cream);border:1px solid #e8e1d2;border-radius:18px;padding:25px 28px;display:flex;justify-content:space-between;align-items:center;margin-bottom:17px}.room-intro h2{font-family:Georgia,"STSong",serif;margin:6px 0}.room-intro p:last-child{margin:0;color:var(--muted);font-size:12px}.room-stat{text-align:center;border-left:1px solid #d8d1c3;padding-left:32px}.room-stat span{display:block;color:var(--muted);font-size:10px}.room-stat strong{font:600 30px Georgia}.room-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.room-card{background:#fff;border:1px solid var(--line);border-radius:15px;padding:18px;position:relative;overflow:hidden}.room-card:before{content:"";position:absolute;width:4px;inset:0 auto 0 0;background:var(--green-2)}.room-card.refund:before{background:var(--red)}.room-card-head{display:flex;justify-content:space-between;align-items:center}.room-number{font:600 22px Georgia}.room-rank{color:#a38e66;font-size:10px;background:var(--cream);padding:4px 7px;border-radius:10px}.room-income{font:600 21px Georgia;margin:15px 0 12px}.room-meta{display:flex;gap:18px;color:var(--muted);font-size:10px}.modal{display:none;position:fixed;inset:0;background:rgba(9,24,19,.55);backdrop-filter:blur(4px);z-index:50;padding:25px;overflow:auto}.modal.open{display:flex;align-items:flex-start;justify-content:center}.modal-card{background:var(--paper);border-radius:20px;width:min(780px,100%);padding:25px;margin:auto;box-shadow:0 30px 80px rgba(0,0,0,.25)}.modal-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.modal-head h2{font-family:Georgia,"STSong",serif;margin:5px 0}.icon-button{border:0;background:#e9ece7;width:34px;height:34px;border-radius:50%;font-size:23px;cursor:pointer}.form-grid{display:grid;gap:12px}.basic-fields{grid-template-columns:repeat(4,1fr)}.fee-fields{grid-template-columns:repeat(5,1fr)}label{font-size:11px;color:var(--muted)}label input,label select,label textarea{width:100%;margin-top:6px;border:1px solid var(--line);border-radius:9px;background:#fff;padding:10px;color:var(--ink);font:inherit;outline:none}label input:focus,label select:focus,label textarea:focus{border-color:#6a9b88;box-shadow:0 0 0 3px rgba(38,118,93,.08)}.form-section-title{display:flex;justify-content:space-between;align-items:center;margin:22px 0 10px;padding-top:16px;border-top:1px solid var(--line);font-size:12px}.form-section-title strong{color:var(--green);font:600 16px Georgia}.wide-field{display:block;margin-top:13px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.toast{position:fixed;right:25px;bottom:25px;background:#173d32;color:#fff;padding:12px 18px;border-radius:11px;box-shadow:var(--shadow);font-size:12px;transform:translateY(80px);opacity:0;transition:.25s;z-index:70}.toast.show{transform:none;opacity:1}.toast.error{background:#8f4238}
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.room-grid{grid-template-columns:repeat(2,1fr)}.basic-fields{grid-template-columns:repeat(2,1fr)}.fee-fields{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){body{display:block}.sidebar{position:sticky;top:0;width:100%;height:auto;padding:12px 16px;flex-direction:row;align-items:center}.brand{padding:0;margin-right:auto}.brand small,.sidebar-note{display:none}.brand-mark{width:34px;height:34px}.sidebar nav{display:flex}.nav-item{padding:9px}.nav-item span{display:none}main{margin:0;width:100%;padding:0 16px 30px}.topbar{height:auto;padding:20px 0;align-items:flex-end}.topbar .eyebrow{display:none}.topbar h1{font-size:22px}.top-actions{gap:7px}.month-control{font-size:0;padding:0 8px}.month-control input{font-size:12px}.button{padding:0 11px}.welcome-panel{padding:24px}.orb{display:none}.kpi-grid,.dashboard-grid,.room-grid{grid-template-columns:1fr}.payment-panel{grid-column:auto}.payment-list{grid-template-columns:repeat(2,1fr)}.section-toolbar{flex-wrap:wrap}.search-box{min-width:100%}.section-toolbar .button{margin-left:0}.basic-fields,.fee-fields{grid-template-columns:repeat(2,1fr)}.modal{padding:10px}.modal-card{padding:18px}.category-row{grid-template-columns:60px 1fr 75px}}
.section-toolbar #import-excel{margin-left:auto}.section-toolbar .button.compact{margin-left:0;box-shadow:none}.text-link{height:42px;display:inline-flex;align-items:center;color:var(--green);font-size:11px;font-weight:700;padding:0 4px}.button:disabled{opacity:.6;cursor:wait}
@media(max-width:760px){.section-toolbar #import-excel{margin-left:0}}
.sidebar-account{margin-top:auto;padding:14px 8px 0;border-top:1px solid rgba(255,255,255,.1);display:grid;grid-template-columns:34px 1fr 28px 28px;gap:8px;align-items:center}.account-avatar{width:32px;height:32px;border-radius:10px;background:#e8d5a2;color:#173d32;display:grid;place-items:center;font-weight:800}.account-meta b,.account-meta small{display:block}.account-meta b{font-size:11px}.account-meta small{font-size:9px;color:#829b92;margin-top:3px}.account-menu{width:28px;height:28px;border:0;border-radius:8px;background:rgba(255,255,255,.08);color:#b8c9c3;cursor:pointer}.account-menu:hover{background:rgba(255,255,255,.15);color:#fff}.password-card{width:min(440px,100%)}
.login-body{display:block;background:#edf1eb;min-height:100vh;padding:28px}.login-shell{margin:0 auto;padding:0;width:min(1050px,100%);min-height:calc(100vh - 56px);display:grid;grid-template-columns:1.05fr .95fr;border-radius:28px;overflow:hidden;background:#fff;box-shadow:0 35px 90px rgba(16,39,31,.16)}.login-brand-panel{position:relative;background:linear-gradient(145deg,#102b23,#174f3f);color:#fff;padding:48px;display:flex;flex-direction:column;overflow:hidden}.login-brand-panel:before,.login-brand-panel:after{content:"";position:absolute;border:1px solid rgba(255,255,255,.08);border-radius:50%}.login-brand-panel:before{width:440px;height:440px;right:-220px;top:-160px}.login-brand-panel:after{width:250px;height:250px;left:-150px;bottom:-100px}.login-brand{display:flex;align-items:center;gap:13px;position:relative;z-index:1}.login-brand b,.login-brand small{display:block}.login-brand b{font-size:18px;letter-spacing:2px}.login-brand small{color:#9db8ae;font-size:10px;margin-top:5px}.login-copy{margin:auto 0;position:relative;z-index:1}.login-copy h1{font:500 42px/1.35 Georgia,"STSong",serif;margin:15px 0 18px}.login-copy>p:last-child{color:#a8c2b8;font-size:13px}.login-security{font-size:10px;color:#82a99a;position:relative;z-index:1}.login-form-panel{display:grid;place-items:center;padding:50px}.login-form{width:min(350px,100%)}.login-form h2{font:600 27px Georgia,"STSong",serif;margin:7px 0}.login-hint{color:var(--muted);font-size:12px;margin:0 0 28px}.login-form label{display:block;margin-top:16px}.login-form label input{height:46px}.login-button{width:100%;height:46px;margin-top:12px}.form-error{height:18px;color:var(--red);font-size:11px;margin:10px 0 0}.login-help{display:block;text-align:center;color:#98a19c;font-size:10px;margin-top:18px}.login-body .brand-mark{transform:none}
@media(max-width:760px){.sidebar-account{display:none}.login-body{padding:0}.login-shell{min-height:100vh;border-radius:0;grid-template-columns:1fr}.login-brand-panel{min-height:220px;padding:28px}.login-copy{margin-top:40px}.login-copy h1{font-size:29px}.login-security{display:none}.login-form-panel{padding:34px 24px}}
@media(max-width:760px){.sidebar .sidebar-account{display:grid;margin:0 0 0 4px;padding:0;border:0;grid-template-columns:28px 28px}.sidebar-account .account-avatar,.sidebar-account .account-meta{display:none}}
.today-reminder{width:100%;border:1px solid #ead9b7;background:#fff8e9;border-radius:15px;padding:13px 18px;margin-bottom:15px;display:grid;grid-template-columns:36px 1fr auto auto;align-items:center;gap:12px;color:var(--ink);text-align:left;cursor:pointer}.reminder-bell{width:32px;height:32px;border-radius:10px;background:#e8bd68;color:#fff;display:grid;place-items:center;font-weight:900}.today-reminder b,.today-reminder small{display:block}.today-reminder b{font-size:12px}.today-reminder small{color:#8c7a5e;font-size:10px;margin-top:3px}.today-reminder strong{font:700 24px Georgia;color:#a86d25}.today-reminder i{font-size:11px;color:#986e35;font-style:normal}.resident-fields{grid-template-columns:repeat(3,1fr)}.compact-modal{width:min(700px,100%)}.expired-row td{background:#fff7f2}.room-toolbar{align-items:center}.room-toolbar .button{margin-left:0}.room-toolbar>select{min-width:190px}.managed-room{padding-bottom:14px}.room-address{font-size:11px;color:var(--muted);margin-top:8px}.room-occupancy{margin:18px 0 12px;color:var(--muted);font-size:11px}.room-occupancy b{font:700 27px Georgia;color:var(--green)}.status-tag{font-size:10px;border-radius:12px;padding:4px 8px;background:#edf4f0;color:var(--green)}.status-维修中{background:#fff0dc;color:#9c6725}.status-停用{background:#f1eeee;color:#765f5f}.card-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:14px;padding-top:10px;border-top:1px solid var(--line)}.card-actions button,.address-item button{border:0;background:#eef3ef;color:var(--green);padding:6px 9px;border-radius:7px;font-size:10px;cursor:pointer}.reminder-hero{background:linear-gradient(120deg,#f7ead2,#fff8ea);border:1px solid #eadfc9;border-radius:18px;padding:24px 28px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}.reminder-hero h2{font:500 27px Georgia,"STSong",serif;margin:6px 0}.reminder-hero p:last-child{font-size:12px;color:var(--muted);margin:0}.reminder-hero>div:last-child{display:flex;align-items:flex-end;gap:10px}.reminder-hero label input{display:block}.history-note{margin-left:auto;align-self:center;color:var(--muted);font-size:11px}.address-card{width:min(650px,100%)}.inline-form{display:grid;grid-template-columns:1fr 1.4fr auto;gap:8px}.inline-form input{border:1px solid var(--line);border-radius:9px;padding:10px;outline:none}.address-list{display:grid;gap:8px;margin-top:18px;max-height:410px;overflow:auto}.address-item{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);background:#fff;border-radius:11px;padding:12px}.address-item b,.address-item small{display:block}.address-item small{font-size:10px;color:var(--muted);margin-top:4px}.address-item span{display:flex;gap:5px}
@media(max-width:760px){.sidebar nav{overflow-x:auto}.nav-item{white-space:nowrap;font-size:11px}.today-reminder{grid-template-columns:32px 1fr auto}.today-reminder i{display:none}.resident-fields{grid-template-columns:repeat(2,1fr)}.reminder-hero{align-items:flex-start;gap:14px;flex-direction:column}.inline-form{grid-template-columns:1fr}.room-toolbar>select{min-width:100%}}
.resident-sync-head{display:flex;align-items:center;justify-content:space-between;margin:18px 0 10px;padding-top:15px;border-top:1px solid var(--line)}.resident-sync-head label{color:var(--ink);font-weight:700}.resident-sync-head label input{width:auto;margin:0 7px 0 0}.resident-sync-head small{color:var(--muted);font-size:10px}.resident-sync-fields{grid-template-columns:repeat(3,1fr);padding:13px;background:#f1f6f3;border-radius:12px}.resident-sync-fields.disabled{opacity:.45;pointer-events:none}
@media(max-width:760px){.resident-sync-head{align-items:flex-start;gap:8px;flex-direction:column}.resident-sync-fields{grid-template-columns:repeat(2,1fr)}}
.button.danger{background:#fff0ed;color:#a7463b;border:1px solid #efc9c3}.bulk-button{margin-left:0!important}.bulk-button:disabled{opacity:.45;cursor:not-allowed}.table-scroll input[type="checkbox"],.card-select input{accent-color:var(--green);width:15px;height:15px}.card-select{display:flex;align-items:center;gap:5px;color:var(--muted);font-size:10px;margin-bottom:9px}.card-select input{margin:0}
.field-hint{display:block;min-height:14px;margin-top:4px;color:var(--muted);font-size:9px}input:invalid+.field-hint{color:var(--red)}
