:root{font-family:system-ui,-apple-system,PingFang SC,Microsoft YaHei,sans-serif;color:#1a1a1a}body{margin:0;display:flex;justify-content:center;padding:48px 16px}.card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}input{padding:10px 12px;font-size:16px;border:1px solid #ccc;border-radius:8px}button{padding:10px 12px;font-size:16px;border:none;border-radius:8px;background:#1a1a1a;color:#fff;cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}.error{color:#c00;font-size:14px}.muted{color:#666;font-size:14px}.login{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;display:flex;flex-direction:column;align-items:center;padding:24px 28px calc(28px + env(safe-area-inset-bottom));box-sizing:border-box;overflow:auto}.login-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.login-logo{width:112px;height:112px;border-radius:26px;background:#1f6dfb;color:#fff;font-size:52px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 28px #1f6dfb52}.login-title{margin:30px 0 0;font-size:27px;font-weight:700}.login-sub{margin:12px 0 0;color:#9aa0a6;font-size:15px}.login-foot{width:100%;display:flex;flex-direction:column;align-items:center}.wx-btn{width:100%;height:54px;background:#07c160;border-radius:14px;color:#fff;font-size:17px;font-weight:600;display:flex;align-items:center;justify-content:center}.wx-badge{width:22px;height:22px;margin-right:10px;border-radius:6px;background:#fff;color:#07c160;font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.login-terms{margin:16px 0 0;color:#b6bbc2;font-size:13px}.onboard{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;max-width:480px;margin:0 auto;display:flex;flex-direction:column;padding:28px 24px calc(28px + env(safe-area-inset-bottom));box-sizing:border-box;overflow:auto}.ob-progress{display:flex;gap:8px}.ob-progress span{flex:1;height:4px;border-radius:2px;background:#1f6dfb}.ob-step{margin:20px 0 0;color:#1f6dfb;font-size:14px;font-weight:600}.ob-title{margin:8px 0 0;font-size:27px;font-weight:700}.ob-sub{margin:8px 0 0;color:#9aa0a6;font-size:15px}.ob-wx{display:flex;align-items:center;gap:12px;margin:24px 0 0;padding:16px;background:#eafaef;border:1px solid #bfe9c8;border-radius:14px}.ob-wx .wx-badge{width:48px;height:48px;margin:0;border-radius:12px;background:#07c160;color:#fff;font-size:22px}.ob-wx-name{flex:1;display:flex;flex-direction:column}.ob-wx-name strong{font-size:16px}.ob-wx-name span{margin-top:2px;color:#22a15a;font-size:13px}.ob-check{width:26px;height:26px;border-radius:50%;background:#22c55e;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px}.ob-label{margin:22px 0 8px;color:#6b7280;font-size:14px}.ob-input{padding:14px;border:1px solid #d1d5db;border-radius:12px}.ob-seg{display:flex;gap:4px;padding:4px;background:#f3f4f6;border-radius:12px}.ob-seg button{flex:1;padding:12px 0;background:transparent;color:#6b7280;border-radius:9px;font-weight:500}.ob-seg button.active{background:#fff;color:#1a1a1a;font-weight:700;box-shadow:0 1px 3px #0000001f}.ob-submit{margin-top:28px;height:52px;border-radius:14px;background:#1f6dfb;font-size:17px;font-weight:600}.ob-signout{margin-top:16px;align-self:center;color:#9aa0a6;font-size:14px;cursor:pointer}.shell{position:fixed;top:0;right:0;bottom:0;left:0;max-width:480px;margin:0 auto;background:#fff;display:flex;flex-direction:column}.shell-body{flex:1;overflow:auto}.mine{padding:28px 24px}.mine-title{margin:0 0 6px;font-size:27px;font-weight:700}.mine-empty{display:flex;flex-direction:column;align-items:center;text-align:center;margin-top:64px}.mine-empty-ico{width:96px;height:96px;border-radius:50%;background:#f2f3f5;display:flex;align-items:center;justify-content:center}.mine-empty-t{margin:20px 0 4px;color:#6b7280;font-size:18px;font-weight:600}.mine-empty .muted{margin:0}.mine-go{margin-top:24px;padding:14px 40px;border-radius:12px;background:#1f6dfb;font-size:16px;font-weight:600}.rez{margin-top:16px;padding:20px;border:1px solid #eee;border-radius:18px;box-shadow:0 6px 20px #0000000d}.rez.expired{background:#f7f8fa;box-shadow:none}.rez.expired strong,.rez.expired b{color:#9aa0a6}.rez-top{display:flex;justify-content:space-between;align-items:center}.rez-top strong{font-size:19px}.rez-tag{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:999px;font-size:13px;font-weight:600}.rez-tag i{font-size:8px;font-style:normal}.rez-tag.green{background:#e7f8ec;color:#22a15a}.rez-tag.gray{background:#eef0f2;color:#9aa0a6}.rez-info{margin:18px 0 0;display:flex;flex-direction:column;gap:6px}.rez-info .muted{font-size:13px}.rez-info b{font-size:17px}.rez-btn{width:100%;margin-top:18px;height:48px;border-radius:12px;font-size:16px;font-weight:600}.rez-btn.cancel{background:#fff;border:1px solid #f3b5b5;color:#e5484d}.rez-btn.done{background:#f2f3f5;color:#b0b5bb}.tabbar{display:flex;border-top:1px solid #eee;padding:8px 0 calc(8px + env(safe-area-inset-bottom))}.tabbar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;background:transparent;color:#9aa0a6;font-size:12px}.tabbar button.active{color:#1f6dfb}.book{padding:28px 24px}.book-hi{margin:0;color:#9aa0a6;font-size:15px}.book-title{margin:6px 0 0;font-size:27px;font-weight:700}.book-row{display:flex;justify-content:space-between;align-items:center;margin-top:28px}.book-h{font-size:17px;font-weight:700}.book-days{display:flex;gap:12px;margin-top:16px}.book-days button{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 0;border:1px solid #e5e7eb;border-radius:14px;background:#fff;color:#6b7280}.book-days button span{font-size:13px}.book-days button strong{font-size:20px;color:#1a1a1a}.book-days button.active{background:#1f6dfb;border-color:#1f6dfb}.book-days button.active span,.book-days button.active strong{color:#fff}.book-seg{display:flex;gap:4px;padding:4px;background:#f3f4f6;border-radius:10px}.book-seg button{padding:8px 20px;background:transparent;color:#6b7280;border-radius:8px;font-weight:500}.book-seg button.active{background:#fff;color:#1f6dfb;font-weight:700;box-shadow:0 1px 3px #0000001f}.book-card{margin-top:16px;padding:22px;border:1px solid #eee;border-radius:18px;box-shadow:0 6px 20px #0000000d;display:flex;flex-direction:column}.book-card-top{display:flex;justify-content:space-between;align-items:center}.book-card-top strong{font-size:20px}.book-tag{font-size:13px;font-weight:600;padding:5px 12px;border-radius:999px}.book-tag.green{background:#e7f8ec;color:#22a15a}.book-tag.orange{background:#fff3e0;color:#e08a1e}.book-tag.gray{background:#f0f1f3;color:#9aa0a6}.book-num{margin:18px 0 0;color:#9aa0a6;font-size:15px}.book-num b{margin-right:6px;color:#1f6dfb;font-size:40px;font-weight:800;vertical-align:-3px}.book-bar{height:8px;margin-top:14px;border-radius:4px;background:#eef0f2;overflow:hidden}.book-bar span{display:block;height:100%;background:#1f6dfb}.book-go{margin-top:20px;height:52px;border-radius:14px;background:#1f6dfb;font-size:17px;font-weight:700}.book-go.cancel{background:#fff;border:1px solid #f3b5b5;color:#e5484d}.admin-login{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;max-width:480px;margin:0 auto;display:flex;flex-direction:column;align-items:center;padding:24px 28px calc(28px + env(safe-area-inset-bottom));box-sizing:border-box;overflow:auto}.admin-hero{margin-top:12vh;display:flex;flex-direction:column;align-items:center;text-align:center}.admin-logo{width:96px;height:96px;border-radius:24px;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;font-size:46px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 28px #7c3aed52}.admin-title{margin:26px 0 0;font-size:26px;font-weight:700}.admin-sub{margin:12px 0 0;color:#9aa0a6;font-size:15px}.admin-form{width:100%;margin-top:40px;display:flex;flex-direction:column}.admin-label{margin-bottom:8px;color:#6b7280;font-size:15px}.admin-label~.admin-label,.admin-pw+.admin-label{margin-top:20px}.admin-input{width:100%;box-sizing:border-box;padding:15px 14px;border:1px solid #e5e7eb;border-radius:12px;background:#fafafa}.admin-input:focus{outline:none;border-color:#7c3aed;background:#fff}.admin-pw{position:relative}.admin-eye{position:absolute;top:50%;right:8px;transform:translateY(-50%);padding:6px 10px;background:transparent;color:#9aa0a6;font-size:18px}.admin-submit{margin-top:28px;height:54px;border-radius:14px;background:#7c3aed;font-size:17px;font-weight:600;letter-spacing:4px}.admin-foot{margin-top:auto;padding-top:24px;color:#b6bbc2;font-size:13px}.admin-shell{position:fixed;top:0;right:0;bottom:0;left:0;max-width:480px;margin:0 auto;background:#fff;display:flex;flex-direction:column}.admin-body{flex:1;overflow:auto;padding:28px 24px}.admin-head{display:flex;align-items:center;gap:14px}.admin-logo.sm{width:56px;height:56px;border-radius:16px;font-size:26px;box-shadow:0 8px 18px #7c3aed47}.admin-h-title{margin:0;font-size:24px;font-weight:700}.admin-h-sub{margin:4px 0 0;color:#9aa0a6;font-size:15px}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px}.admin-stat{padding:18px 12px;border:1px solid #eee;border-radius:16px;box-shadow:0 6px 18px #0000000a;display:flex;flex-direction:column;gap:8px}.admin-stat b{font-size:34px;font-weight:800;line-height:1}.admin-stat b.indigo{color:#6366f1}.admin-stat b.green{color:#22a15a}.admin-stat b.orange{color:#e0821e}.admin-stat span{color:#6b7280;font-size:14px}.admin-section{margin:32px 0 0;font-size:18px;font-weight:700}.admin-fn{width:100%;margin-top:16px;padding:18px;background:#fff;border:1px solid #eee;border-radius:18px;box-shadow:0 6px 18px #0000000a;display:flex;align-items:center;gap:16px;text-align:left}.admin-fn-ico{flex-shrink:0;width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.admin-fn-ico.blue{background:#eef1ff;color:#4f6bed}.admin-fn-ico.green{background:#eafaef;color:#22a15a}.admin-fn-txt{flex:1;display:flex;flex-direction:column;gap:4px}.admin-fn-txt strong{font-size:18px;color:#1a1a1a}.admin-fn-txt small{color:#9aa0a6;font-size:14px}.admin-fn-arr{color:#c4c9d0;font-size:22px}.admin-me{display:flex;flex-direction:column}.admin-me-title{margin:0 0 20px;font-size:27px;font-weight:700}.admin-me-card{display:flex;align-items:center;gap:16px;padding:20px;border:1px solid #eee;border-radius:18px;box-shadow:0 6px 18px #0000000a}.admin-me-card .admin-logo.sm{width:64px;height:64px;font-size:28px}.admin-me-name{font-size:22px;font-weight:700}.admin-me-sec{margin:28px 0 12px;color:#9aa0a6;font-size:15px;font-weight:500}.admin-me-list{border:1px solid #eee;border-radius:16px;box-shadow:0 6px 18px #0000000a;overflow:hidden}.admin-me-row{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px;background:#fff;color:#1a1a1a;font-size:17px;border-radius:0}.admin-me-row+.admin-me-row{border-top:1px solid #f0f0f0}.admin-me-val{color:#9aa0a6;font-size:15px}.admin-logout{margin-top:28px;height:52px;border-radius:14px;background:#fff;border:1px solid #f3b5b5;color:#e5484d;font-size:16px;font-weight:600}.admin-tabbar{display:flex;border-top:1px solid #eee;padding:8px 0 calc(8px + env(safe-area-inset-bottom))}.admin-tabbar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;background:transparent;color:#9aa0a6;font-size:12px}.admin-tabbar button.active{color:#7c3aed}.admin-page{position:fixed;top:0;right:0;bottom:0;left:0;max-width:480px;margin:0 auto;background:#fff;display:flex;flex-direction:column}.admin-topbar{display:flex;align-items:center;gap:8px;padding:16px 20px;border-bottom:1px solid #f0f0f0}.admin-topbar h1{flex:1;margin:0;font-size:21px;font-weight:700}.admin-back{width:32px;height:32px;padding:0;background:transparent;color:#1a1a1a;font-size:28px;line-height:1}.admin-add{padding:9px 16px;border-radius:12px;background:#7c3aed;color:#fff;font-size:15px;font-weight:600}.admin-page-body{flex:1;overflow:auto;padding:24px 20px calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column}.adm-room{padding:20px;margin-bottom:16px;border:1px solid #eee;border-radius:18px;box-shadow:0 6px 18px #0000000a}.adm-room.off{background:#f7f8fa;box-shadow:none}.adm-room.off strong{color:#9aa0a6}.adm-room-top{display:flex;justify-content:space-between;align-items:center}.adm-room-top strong{font-size:19px}.adm-badge{padding:5px 12px;border-radius:999px;font-size:13px;font-weight:600}.adm-badge.on{background:#eafaef;color:#22a15a}.adm-badge.off{background:#eef0f2;color:#9aa0a6}.adm-room .muted{margin:10px 0 0;font-size:14px}.adm-room-btns{display:flex;gap:12px;margin-top:18px}.adm-ghost{flex:1;height:46px;background:#fff;border:1px solid #d7dbe0;color:#1a1a1a;border-radius:12px;font-size:15px;font-weight:500}.adm-ghost.enable{border-color:#86d94a;color:#4caf13}.admin-page-body>.admin-label:first-child{margin-top:0}.admin-page-body .admin-label{margin-top:22px}.adm-slots{display:flex;gap:12px}.adm-slots button{flex:1;height:52px;background:#f7f9ff;border:1px solid #e5e7eb;color:#6b7280;border-radius:12px;font-size:16px;font-weight:500}.adm-slots button.active{background:#eef4ff;border-color:#1f6dfb;color:#1f6dfb;font-weight:600}.adm-enable{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding:18px;border:1px solid #eee;border-radius:16px}.adm-enable strong{font-size:17px}.adm-enable small{display:block;margin-top:4px;color:#9aa0a6;font-size:14px}.adm-switch{flex-shrink:0;width:52px;height:31px;padding:0;border-radius:999px;background:#d1d5db;transition:background .2s}.adm-switch.on{background:#1f6dfb}.adm-switch span{display:block;width:27px;height:27px;margin:2px;border-radius:50%;background:#fff;transition:transform .2s}.adm-switch.on span{transform:translate(21px)}.adm-save{margin-top:28px;height:54px;border-radius:14px;background:#1f6dfb;font-size:17px;font-weight:600}.adm-save.purple{background:#7c3aed}.admin-hint{margin:10px 2px 0;color:#9aa0a6;font-size:14px}.adm-days{display:flex;gap:12px}.adm-days button{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 0;border:1px solid #e5e7eb;border-radius:14px;background:#fff;color:#6b7280}.adm-days button span{font-size:13px}.adm-days button strong{font-size:20px;color:#1a1a1a}.adm-days button.active{background:#7c3aed;border-color:#7c3aed}.adm-days button.active span,.adm-days button.active strong{color:#fff}.adm-res-controls{display:flex;align-items:center;justify-content:space-between;margin-top:16px}.adm-res-controls .adm-seg{display:flex;gap:4px;padding:4px;background:#f3f4f6;border-radius:10px}.adm-res-controls .adm-seg button{padding:8px 20px;background:transparent;color:#6b7280;border-radius:8px;font-weight:500}.adm-res-controls .adm-seg button.active{background:#fff;color:#7c3aed;font-weight:700;box-shadow:0 1px 3px #0000001f}.adm-room-sel{border:none;background:transparent;color:#6b7280;font-size:15px;padding:8px 4px}.adm-res-head{display:flex;justify-content:space-between;align-items:baseline;margin-top:28px}.adm-res-title{font-size:18px;font-weight:700}.adm-res{display:flex;align-items:center;gap:14px;margin-top:16px;padding:16px 18px;border:1px solid #eee;border-radius:16px;box-shadow:0 6px 18px #0000000a}.adm-res-ico{flex-shrink:0;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.adm-res-ico.c0{background:#eef1ff;color:#4f6bed}.adm-res-ico.c1{background:#eafaef;color:#22a15a}.adm-res-ico.c2{background:#fff3e0;color:#e08a1e}.adm-res-ico.c3{background:#f3ecfe;color:#7c3aed}.adm-res-txt{display:flex;flex-direction:column;gap:4px}.adm-res-txt strong{font-size:18px}.adm-res-txt small{color:#9aa0a6;font-size:14px}.adm-res-room{flex-shrink:0;padding:5px 10px;border-radius:999px;background:#f3ecfe;color:#7c3aed;font-size:12px;font-weight:600}
